Busca nos campos personalizados do WordPress

13 de março de 2011 ~ 4 comentários ~ Tags:, ,

Os campos personalizados é um recurso usado no WordPress para que o autor de um post possa armazenar dados a sua escolha. Você pode usar esse recurso de várias formas: mostrar imagens personalizadas, falar o que você está ouvindo durante a escrita do post, adicionar informação pessoal e muito mais. Em um blog sobre livros, você pode usar tal recurso para criar os campos “Autor”, “Editora”, “Ano” e por aí vai.

Estou trabalhando em um projeto que utiliza os campos personalizados na área de Imprensa, onde cada post aponta em que tipo de imprensa determinada informação foi postada: Rádio, TV, Internet, Jornal. Como dito acima, criar o campo personalizado é simples. Difícil é filtrar os posts de acordo com o valor do campo.

A solução

Descobri um plugin chamado Search Custom Fields. Numa explicação rápida, ele adiciona os Campos Personalizados na query de busca de posts.

Antes:

  1. <a href="/?s=minhabusca">minha busca</a>

Depois:

  1. <a href="?meucampopersonalizado=Veículo&s=meuvalordocampopersonalizado">minha busca pelo campo personalizado</a>

Na documentação do plugin, o autor mostra como turbinar o campo de busca do WordPress. Ao invés disso, escrevi uma pequena função para listar os valores de um atributo personalizado:

  1. function list_custom_fields($metakey, $output) {
  2.     // based on http://sixrevisions.com/wordpress/custom-fields-search/
  3.     global $wpdb;
  4.     $items = $wpdb->get_col($wpdb->prepare("SELECT DISTINCT meta_value FROM $wpdb->postmeta WHERE meta_key = %s ORDER BY meta_value ASC", $metakey) );
  5.     if ($items) {
  6.         if ($output == "dropdown") { // display values in a select
  7.             echo "<form action=\"/\" method=\"get\"><input type=\"hidden\" name=\"key\" value=\"$metakey\" /><select name=\"s\" onchange=\"this.form.submit();\"><option></option>";
  8.             foreach ($items as $item) {
  9.               echo "<option value=\"" . $item . "\">" . $item . "</option>";
  10.             }
  11.             echo "</select></form>";
  12.         } else if ($output == "list") { // display values in a list
  13.             echo "<ul>";
  14.             foreach ($items as $item) {
  15.               echo "<li><a href=\"/?s=$item&key=$metakey\">$item</a></li>";
  16.             }
  17.             echo "</ul>";
  18.         }
  19.     }
  20. }

Coloque a função acima no arquivo functions.php do seu tema e chame-a, de duas formas, em seu sidebar, por exemplo:

  1. < ?php if(function_exists('list_custom_fields')) list_custom_fields("Veículo", "dropdown"); ?>

…para mostrar os valores do campo personalizado “Veículo” em select do HTML ou…

  1. < ?php if(function_exists('list_custom_fields')) list_custom_fields("Veículo", "list"); ?>

…para mostrar os valores do campo personalizado “Veículo” em uma lista.


Projetos no GitHub

23 de janeiro de 2011 ~ Comente! ~ Tags:,

Estou movendo aos poucos algumas coisinhas para o GitHub. Já estão lá:

Em breve criarei novos repositórios lá.


Alternativas ao PHPMyAdmin

22 de agosto de 2009 ~ 2 comentários ~ Tags:, ,

O PHPMyAdmin é quase uma unanimidade em gerenciadores de banco de dados MySQL. Mas existe vida além dele. Vamos lá:

SQL Buddy

O SQL Buddy é uma alternativa bacana, com bonita interface e traduzido para vários idiomas, incluindo português.

sqlbuddy

Adminer

Já o Adminer é um app em php feito em 1(!) único arquivo. Possui diversas traduções (nenhuma ainda em português) mas é altamente indicado o mantermos em nossos servidores para uma rápida manutenção.

adminer


Todo lists para o Textmate

22 de agosto de 2009 ~ Comente! ~ Tags:,

Fica a dica para quem usa o Textmate: Tasks é um bundle para o Textmate que permite a criação de Todo lists bonitinhas.

Tasks

A instalação é fácil:

  1. mkdir -p ~/Library/Application\ Support/TextMate/Bundles
  2. cd ~/Library/Application\ Support/TextMate/Bundles
  3. git clone git://github.com/henrik/tasks.tmbundle.git Tasks.tmbundle
  4. osascript -e 'tell app "TextMate" to reload bundles'

Depois disso, todos os arquivos .todo, .todolist e .tasks serão formatados de acordo com o bundle.


Data URI

7 de junho de 2009 ~ 2 comentários ~ Tags:,


Spoiler: o conteúdo abaixo não funciona no Internet Explorer.

Em 2005 o Irapuan Martinez falou do Acid 2 e de um recurso interessantíssimo, que acabei de testar: Dat URI (que existe desde 98).

Dat URI, em poucas palavras, é a possibilidade de inserir conteúdo dentro de um arquivo HTML sem a necessidade de linkar o arquivo. Assim, a imagem ao lado poderia ser inserida com:

Continue lendo →


Protegendo projetos com o .htaccess

16 de julho de 2008 ~ 2 comentários ~ Tags:, ,

O Apache pode te ajudar a proteger um projeto com seu sistema de autenticação. E isso é mais fácil do que você pensa. Para tal, crie um arquivo .htaccess com o seguinte conteúdo:

  1. AuthUserFile /home/leonardo/public_html/project/.htpasswd
  2. AuthGroupFile /dev/null
  3. AuthName "Restricted Access"
  4. AuthType Basic
  5. <limit GET>
  6. require valid-user
  7. </limit>

Após isso, crie um .htpasswd com os dados de usuário e senha (atenção ao caminho do arquivo). A senha é criptografada e o conteúdo do arquivo é algo como o seguinte:

  1. leo:4tHAiRmQ4OpjM

Para criptografar a senha use um dos vários serviços por aí existentes. Para proteger um projeto em Rails, a solução também funciona bem, desde que seu .htaccess esteja na pasta public de sua aplicação


Usando ApacheBench para testes: Apache/mod_rails e Nginx/mongrel

15 de julho de 2008 ~ 4 comentários ~ Tags:, , ,

O ApacheBench é um software do Apache usado para fazer testes de perfomance de servidores web, independente do servidor usado. Isso é muito útil para comparar o desempenho de diversas configurações, mas nem sempre pode apresentar a realidade do ambiente.

O ApacheBench é distribuído nos ambientes Linux pelo pacote apache2-utils – versões para Mac OS e Windows podem ser encontradas no site do software. Em distribuições como o Ubuntu, para instalá-lo basta um apt-get install apache2-utils (como super-usuário). A partir daí, o comando ab fica disponível em seu terminal e é só correr para o abraço!

Um teste pode ser feito com o comando:

  1. ab -n 100 -c 5 http://www.leonardofaria.net/

O Flag ‘-n’ indica o número de requisições, enquanto a opção ‘-c’ indica a ocorrência de conexões simultâneas. A saída do comando acima é semelhante a:

  1. This is ApacheBench, Version 2.0.40-dev < $Revision: 1.146 $> apache-2.0
  2. Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
  3. Copyright 2006 The Apache Software Foundation, http://www.apache.org/
  4.  
  5. Benchmarking www.leonardofaria.net (be patient).....done
  6.  
  7.  
  8. Server Software:        Apache/2.2.8
  9. Server Hostname:        www.leonardofaria.net
  10. Server Port:            80
  11.  
  12. Document Path:          /
  13. Document Length:        0 bytes
  14.  
  15. Concurrency Level:      5
  16. Time taken for tests:   16.460184 seconds
  17. Complete requests:      100
  18. Failed requests:        0
  19. Write errors:           0
  20. Non-2xx responses:      100
  21. Total transferred:      41600 bytes
  22. HTML transferred:       0 bytes
  23. Requests per second:    6.08 [#/sec] (mean)
  24. Time per request:       823.009 [ms] (mean)
  25. Time per request:       164.602 [ms] (mean, across all concurrent requests)
  26. Transfer rate:          2.43 [Kbytes/sec] received
  27.  
  28. Connection Times (ms)
  29.               min  mean[+/-sd] median   max
  30. Connect:      255  291  21.2    287     361
  31. Processing:   442  506 131.1    485    1732
  32. Waiting:      438  492  42.9    484     655
  33. Total:        698  797 137.9    774    2040
  34.  
  35. Percentage of the requests served within a certain time (ms)
  36.   50%    774
  37.   66%    804
  38.   75%    812
  39.   80%    818
  40.   90%    878
  41.   95%    925
  42.   98%    982
  43.   99%   2040
  44.  100%   2040 (longest request)

Dezenas de possibilidades podem ser traçadas com esses testes.
Nos meus benchmarks, realizei basicamente 2 testes: a renderização do index.html default do framework e a renderização de um Time.Now do Ruby. Em ambos os testes, o desempenho do nginx + mongrel_cluster foi superior ao Apache + mod_rails. Esse teste também foi feito por aí, e com resultados semelhantes ao meu.

Desse modo, em uma balança estão Apache/mod_rails e Nginx/mongrel_cluster. De um lado, pesam a facilidade de deployment e o crescente uso em shared hosts. De outro lado pesam a rapidez do servidor e a ‘dificuldade’ do deployment. E aí? De que lado você vai ficar?


Gmail + WordPress = post por email

4 de junho de 2008 ~ 8 comentários ~ Tags:, ,

Eu já tinha visto o recurso de post por email mas nunca havia testado. É muito simples. Vamos lá:

  1. No adminstrador do WordPress, escolha Options -> Writing.
  2. Em ‘Posts por e-mail’, defina:
    • Mail Server: ssl://pop.gmail.com – Port: 995
    • Login Name: usuario@gmail.com
    • Password: : suasenha, naturalmente ;)
  3. Agora, basta enviar o post para o destinatário definido no adminstrador.

Dica extra

É possível passar a categoria do post no assunto da mensagem. Basta colocar o seu respectivo id entre colchetes. Exemplo: supondo que a categoria wordpress tenha ID = 5, o assunto da sua mensagem seria: [5] título do meu post exemplo.


Sobre Controle de Versão

31 de maio de 2008 ~ Comente! ~ Tags:,

Na disciplina de Engenharia de Software que faço no curso de Sistemas de Informação da Faculdade Pitágoras, fiz um trabalho introdutório sobre Sistemas de Controle de Versão. O trabalho está abaixo e também disponível em PDF.

Continue lendo →


Como você desenvolve suas aplicações

5 de abril de 2008 ~ 1 comentário ~ Tags:

[update 04/04/08] migrei da dreamhost para railsplayground e ainda estou acertando umas coisinhas [plugins & layout] na casa nova. Dá série uma imagem vale mais que mil palavras:


Página 1 de 212

Últimos textos do blog

Tagcloud

abraweb acadêmico actionscript ajax apache apple arteccom asp autosimulado backup benchmark beta bh blogosfera bookmarklet bookmarklets brasil browser censura chrome chucknorris cms codestacker concurso crítica css dashboard deployment desenvolvimento design dicas divinópolis dotmac download dreamhost economia editor empreendedorismo empreendorismo encontro estatísticas extreme programming feedburner firefox fireworks flash flickr ftp game git globo gmail golive google greasemonkey guerrilha hack host howto htaccess html humor ie inss internet banking iphone ipod is® javascript jquery layout leopard linux listas live locomotive mac meme microsoft miguxês minasonrails mod_rails mp3 msn mysql off tropic opensocial opera orkut oscommerce parser passenger pc personalidade pesquisa php plugin plugins pog portfolio produtividade publicidade rails raspberry refurbished regex resenha review ria rss ruby rádio safari sandbox screencast screensaver script.aculo.us seo shoutcast silverlight software spam startup stevejobs subversion suporte swf switch são paulo teste textmate trabalho tumblelog tumblr tutorial twitter ui uml usabilidade validação viral wallop web2.0 webalizer webdesign webdevelopment webkit webmail webmobile webobjects webstandards windows wordpress xml yahoo youtube

Veja todos os textos →