Manipulando campos BLOB com symfony 1.2 e Propel 1.3

Estou começando a dar meus primeiros passos com o symfony 1.2. Acabei de perder 1 hora pesquisando sobre como manipular campos *BLOB* no MySQL.

Tenho uma tabela que possui uma coluna imagem do tipo BLOB. Quando tento obter o valor desta coluna com o *$objeto->getImagem()*, o retorno é um *resource* (vardump: Resource id #403). Antigamente, no symfony 1.0, o próprio método era responsável por ‘converter’ o resource para string.

Agora, pesquisando na internet, descobri um modo de fazer esta ‘conversão’. Podemos fazer override da função getImagem() ou criar uma nova. No meu caso, resolvi criar uma função nova. Considerando minha tabela noticia:

_lib/model/Noticia.class.php_

class Noticia extends BaseNoticia
{
    public function getPathImg() {
        $content="";
        if (is_resource($this->getImagem())) {
          while(!feof($this->getImagem())){
                    $content.= fread($this->getImagem(), 1024);
                  }
                  rewind($this->getImagem());
                  return ‘/uploads/banners/’.$content;
                } else return ‘/uploads/banners/’.$this->getImagem();   
    }
}
 

Achei esta dica no site do propel, em: “http://propel.phpdb.org/trac/ticket/672″:http://propel.phpdb.org/trac/ticket/672

Pelo status do ticket, este retorno passou a ser um resource por questão de flexibilidade e performance.

Gostaria de obter comentários sobre performance e/ou sugestão sobre esta solução que achei.

Valeu!