Contenido

Cuidando la base de datos de nuestro WordPress

17 oct

+ 19

WordPress, es un conjunto de ficheros .php, que realizan consultas a una base de datos (generalmente MySQL) para obtener la información que nosotros, y nuestros usuarios, generamos. Aunque hay una infinidad de plugins, quizás los más olvidados y a su vez, los más importantes son aquellos que nos permiten optimizar nuestra base de datos.

La base de datos de WordPress

La BD (base de datos en adelante) se compone de 10 tablas inicialmente, y en ella nos encontramos las tablas necesarias para almacenar los datos que componen nuestro blog, artículos, comentarios, categorías,…

Todo está en la base de datos, y por ese motivo es conveniente cuidarla, ya sea mediante herramientas externas o plugins.

Herramientas externas

Muchos podemos disponer de otras herramientas para optimizar o analizar nuestras bases de datos sin necesidad de instalar un nuevo plugin en nuestro WordPress. Un ejemplo de estas herramientas es phpMyAdmin.

phpmyadmin
(Ver Imagen)

Plugins

Mediante plugins, podemos realizar prácticamente las mismas tareas que con aplicaciones externas, con la diferencia de que todo está en nuestro WordPress. Esto supone una ventaja a la hora de ofrecer una opción a un cliente de poder optimizar o analizar la base de datos de su WordPress, evitándole tener que usar otras herramientas externas al panel de administración.

WP-Optimize

Hay muchos plugins que nos permiten tener una gestión completa las tablas de WordPress, y WP-Optimize es uno de ellos.

wp-optimize
(Ver Imagen)

Entre las opciones que dispone, vemos que podemos realizar funciones de limpieza de forma sencilla:

  • Borrar todas las revisiones de nuestros artículos
  • Borrar todos los comentarios marcados como SPAM
  • Borrar todos los comentarios marcados como inapropiados

Además de mostrarnos de un vistazo el estado de nuestras tablas, informándonos de las que necesitan ser optimizadas.

wp-optimize-tables
(Ver Imagen)

Adminer

adminer
(Ver Imagen)

Adminer, es otro plugin para nuestro WordPress que nos proporciona las herramientas necesarias para cuidar nuestras base de datos. En este caso, nos ofrece un sustituto perfecto de phpMyAdmin, ideal para aquellos usuarios que no disponen de esta opción en su hosting.

adminer-gestion
(Ver Imagen)

Optimize DB

Quizás el plugin (Optimize DB) de optimización de BD que he visto, pero hace lo que tiene que hacer. En caso de que haya alguna tabla con residuo a optimizar nos aparecerá en nuestro panel de administración, en caso contrario no nos molestará, dejándonos trabajar sin ningún problema.

screenshot-1
(Ver Imagen)

WordPress Database Table Optimizer

Otro plugin que únicamente nos permite optimizar nuestras tablas y que realizar su trabajo de una forma eficiente. Ideal, para aquella gente que solo quiere optimizar cada X tiempo.

database-tabler-optimizer
(Ver Imagen)

WP DBManager

WP DBManager es un suite de opciones para nuestro WordPress en forma de plugin. Con él podremos realizar las tareas más comunes con nuestra base de datos (optimizar, analizar, reparar,..).

DBManager-optimize
(Ver Imagen)

Entre las opciones del plugin, nos encontramos con la posibilidad de hacer backups de nuestra BD, borrar o vaciar tablas o  ejecutar sentencias SQL sobre las tablas.

DBManager-backup
(Ver Imagen)

Conclusión

Después de ver estas herramientas, hemos de pensar en cuidar lo que hace posible que nuestro WordPress sea lo que és.

Comprobando si un plugin está activo en WordPress

7 sep

+ 0

WP-Engineer, muestra un interesante código que nos permite comprobar si un plugin está activo o no. Ideal para reusar código de otros plugins desde los nuestros.

// Cargamos todos los plugins activos
$plugins = get_option('active_plugins');

// Plugin que deseamos comprobar
$required_plugin = 'debug_queries/debug_queries.php';

// booleano que activamos si el plugin está activo
$debug_queries_on = FALSE;

// Comprobamos que el plugin está entre los activos.
if ( in_array( $required_plugin , $plugins ) ) {

 // Activamos el booleano en caso de estar activo.
 $debug_queries_on = TRUE;
}

Muy interesante y práctico.

Compatibilidad de plugins en WordPress

3 jun

+ 2

La compatibilidad de plugins de WordPress, generalmente es un problema que muchos nos encontramos a la hora de tener que actualizarlos o instalarlos en nuestras distintas versiones de WordPress.

Por ello, se ha creado WordPress Plugin Compatibility Check,  un aplicación que intenta recopilar todos los plugins disponibles en el repositorio oficial de WordPress y reportar la compatibilidad con cosas como la versión mínima o máxima, la posibilidad de funcionar en servidores con PHP4, capacidad de sacar el plugin de wp-content o si este está harcodeado en el código,,.. incluso si este usa o no la librería wpdb para interactuar con la base de datos o algún método obsoleto y retirado del código de WordPress.

Actualmente tienen más de 5.000 plugins introducidos, lo que aproximadamente hace más de un 63% de los plugins disponibles.

10 plugins de WordPress que te ayudarán a ahorrar tiempo

28 may

+ 5

SixRevision ha realizado un listado de 10 plugins de WordPress con los que seguro que ahorrarás tiempo en todo lo relacionado con el blog.

  1. Post Ideas: Es un plugin sencillo que se encarga de gestionar de una forma cómoda esos miniborradores que puedes usar para almacenar ideas para futuros posts.
  2. Tidy Up: Plugin que se encarga de detectar errores en tu HTML y lo limpia (mañana lo probaré a ver que significa eso de limpiar :D)
  3. Pages+: Ideal para los blogs que tienen muchas páginas, gestiona muy eficientemente el trabajo con ellas.
  4. Mass Post Manager: Realizar tareas comunes como “Cerrar comentarios”, “Eliminarlos”, … a un conjunto de posts a la vez.
  5. WordPress Attachment Manager: Interesante plugin que te permite generar listas de elementos adjuntados al post.
  6. Survey Gizmo: Plugin ideal para gestionar tus encuestas. Dispone de una versión FREE bastante completa.
  7. Tweetable Twitter: Plugin que integra tu WordPress con Twitter, y además envia los posts automáticamente a twitter para mántener a tus followers informados.
  8. Secure Files: Te ayudará a gestionar esos ficheros que únicamente los usuarios registrados deben poder descargar.
  9. SmartVideoPlus: Plugin múltimedia con el que podrás integrar vídeos en tu WordPress más cómodamente.
  10. Sticky Post: Los usuarios de WordPress 2.7 ya lo tienen integrado en el núcleo de WordPress, pero los usuarios de versiones más antiguas podrán decidir cómodamente que post quedará marcado como sticky en su Blog.

Stealth Login, añade un grado de seguridad más a tu WordPress

26 may

+ 6

En PuntoGeek me he encontrado un interesante plugin que nos permite añadir un grado más de seguridad a nuestros blogs. Se trata de Stealth Login, un plugin que mediante un una serie de reglas en el fichero .htaccess hará que nuestro fichero wp-login.php y el directorio wp-admin/ sean reemplazados por los nombres que nosotros le indiquemos.

screenshot-11
(Ver Imagen)

Este sería el estado inicial, el fichero .htaccess que WordPress nos añade por defecto. Una vez modificadas las opciones disponibles, obtendremos un resultado similar a este.

screenshot-2
(Ver Imagen)

La idea es realmente buena, ya que te dá completo control sobre el nombre que tu quieras ponerle a tu pantalla de login y a tu panel de administración. Además, si algo falla, siempre puedes borrar directamente el fichero .htaccess desde el FTP y volver a empezar desde donde WordPress te lo deja originalmente.

Descargar

Puedes descargar directamente desde la página oficial de WordPress.

¿Como y donde puedo extender WordPress?

22 may

+ 14

¿Estás pensando en añadir una funcionalidad a WordPress y no sabes por donde empezar a extenderlo? ¿te gustaría hacer las tareas más comunes de tu día a día con el blog sean más fáciles? Pues solo necesitas conocer, como actuar frente a esta pregunta.

¿Como y donde puedo extender WordPress?

WordPress, por defecto, nos presenta 3 formas de extender las funcionalidades de WordPress:

  1. Mediante actions.
  2. Mediante filters.
  3. Mediante declaración de funciones.

Todas ellas sin necesidad de tocar el código propio del núcleo de WordPress, evitando así tener que hacer modificaciones cada vez que actualicemos nuestro Wordpres.

Extender WordPress mediante Actions

Uno de los métodos que podemos usar y que están disponibles el la API de WordPress es el uso de actions. Como su nombre indica, actions son las acciones definidas por el equipo de WordPress en las que podremos añadir nuestras propias funcionalidades.

<?php add_action($tag, $function_to_add, $priority = 10, $accepted_args = 1); ?>

Esta función que tanto hemos visto en plugins o código que hemos mostrado para extender WordPress, hace una función muy importante y cada parámetro aporta un grado más de personalización.

  • $tag: Nombre del action (ahora los veremos).
  • $function_to_add: Nombre de la función que ejecutaremos al activarse el action ($tag).
  • $priority: Prioridad de ejecución, de menor a mayor.
  • $accepted_args: Aceptamos (o no) el paso de parámetros a nuestra función.

Ejemplo:

<?php
define("TWITTER_USER", 'username');
define("TWITTER_PASS", 'password');
define("TWITTER_MESSAGE", '[Post] %name%: %link% <-- %title%');

function update_twitter($post_ID = '')  {
	$curl_handle = curl_init();

	// Nombre del blog
	$message = str_replace("%name%", get_bloginfo('name'), TWITTER_MESSAGE);

	// Cargamos el post
	$post = get_post($post_ID);

	// Enlace y título
	$message = str_replace("%link%", $post->guid, $message);
	$message = str_replace("%title%", $post->post_title, $message);

	// Enviamos el Tweet
	curl_setopt($curl_handle, CURLOPT_URL, 'http://twitter.com/statuses/update.xml');
	curl_setopt($curl_handle, CURLOPT_CONNECTTIMEOUT, 2);
	curl_setopt($curl_handle, CURLOPT_RETURNTRANSFER, 1);
	curl_setopt($curl_handle, CURLOPT_POST, 1);
	curl_setopt($curl_handle, CURLOPT_POSTFIELDS, "status=$message";
	curl_setopt($curl_handle, CURLOPT_USERPWD, TWITTER_USER.":"TWITTER_PASS);
	$buffer = curl_exec($curl_handle);
	curl_close($curl_handle);
  return $post_ID;
}
// Añadimos funcionalidad a publish_post
add_action('wp_insert_post', 'update_twitter');
?>

No le hagais mucho caso al código, es ilustrativo y puede producir un funcionamiento erroneo en WordPress

En este código, vemos lo sencillo que es añadir una funcionalidad a nuestro WordPress. En este caso, estamos añadiendo al action wp_insert_post la función update_twitter(). En este caso, una vez hayamos pulsado el botón de publicar en nuestro WordPress, este ejecutará la función update_twitter() y esta enviará a Twitter un aviso de un nuevo artículo.

¿Donde se extienden los actions?

Este ejemplo solo debe servir para hacernos una idea de como añadir funcionalidades a nuestro WordPress, lo interesante es que debemos conocer los actions disponibles para extender nuestro WordPress.

La API nos muestra un listado bastante detallado de los action disponibles. Pero si tenemos alguna duda lo mejor es siempre revisar el código.

En el fichero post.php del directorio wp-includes/ podemos encontrar en la línea 1534 la llamada do_action() que lanzará las acciones asociadas al nombre wp_insert_post.

[...]
	wp_transition_post_status($post_status, $previous_status, $post);

	if ( $update)
		do_action('edit_post', $post_ID, $post);

	do_action('save_post', $post_ID, $post);
	do_action('wp_insert_post', $post_ID, $post);

	return $post_ID;
}
[...]

do_action(), es la función encargada de lanzar el array de acciones asociadas a la key definida por el primer parámetro. En este caso wp_insert_post, lanzará nuestra función que recibirá por parámetro $post_ID que estamos pasando con el do_action(). Suplementaríamente estamos paando un segundo parámetro con $post, que contiene el objeto con los valores que componen el post que acabamos de insertar en la BD.

Revisando el código de WordPress encontraremos una infinidad de do_action() que permiten extender WordPress en casi todos los puntos en los que queramos añadir una nueva funcionalidad.

Mediante filters

Los filters, están mucho más extendidos por el núcleo de WordPress. Como su nombre indica, sirven para filtrar variables que nos podemos encontrar en cualquier funcionalidad de WordPress.

Al igual que los actions, podemos extender la funcionalidad de nuestro WordPress en ellos.

Ejemplo

<?php
	function noShowIPs($IP = '') {
		// Mostramos solo los primeros 7 carácteres
		return substr($IP, 0, 7);
	}
	// Aplicamos el filtro
	add_filter('get_comment_author_IP', 'noShowIPs');
?>

En este pequeño ejemplo, indicamos que no queremos mostrar la IP completa del usuario que comenta en nuestro WordPress cuando se usa la función get_comment_author_IP(). Mediante un substr() devolvemos los 7 primeros dígitos de $IP.

¿Donde se extienden los filters?

Al igual que los actions, los filters están en los ficheros que componen WordPress. En el ejemplo que hemos montado previamente hemos hecho uso de get_comment_author_IP() que se encuentra en el fichero comment-template.php del directorio wp-includes/. Si nos dirigimos a la línea 173 veremos el siguiente código.

[...]
function get_comment_author_IP() {
	global $comment;
	return apply_filters('get_comment_author_IP', $comment->comment_author_IP);
}
[...]

apply_filters() es el do_action() de los filters, ya que se encarga de recorrer el array de filtros definidos para la key establecida y los va aplicando uno trás otro. En nuestro caso, recibimos la IP del comentarista para posteriormente devolver una IP recortada.

Mediante declaración de funciones

Esta forma, es quizas la más obvia, pero no por ello deja de ser potente.

En muchos casos, usamos plugins por que son más fáciles de instalar, pero bien bien, podrían ser sustituidos por funciones alojadas en ficheros concretos de WordPress. Obtendríamos el mismo resultado.

Ejemplo

<?php
function ult_comments($cuantos = 5) {
    global $wpdb;
    $comentarios = $wpdb->get_results($wpdb->prepare("
                            SELECT  wc.comment_date, wc.comment_author, wp.post_title, wp.guid, wp.comment_count
                            FROM ".$wpdb->comments." as wc, ".$wpdb->posts." as wp
                            WHERE wc.comment_post_ID = wp.ID
                            AND  wc.comment_approved = '1'
                            AND wc.comment_type = ''
                            ORDER BY wc.comment_date DESC LIMIT 0,%d;",$cuantos ));
    foreach ($comentarios as $comentario) {
			echo '<li>
				<a href="'.$comentario->guid.'" title="'.$comentario->post_title.'">'.$comentario->post_title.'
				  <small>'.$comentario->comment_count.'</small>
                                </a>
        			<small>Por '.$comentario->comment_author.' hace '.since_date($comentario->comment_date).'</small>
                              </li>';
    }
}
?>

Uno de los puntos recomendados para alojar este tipo de funciones, es el fichero functions.php de nuestro theme. Todas las funciones definidas en él serán visibles desde nuestro themes, plugins, …

En este caso, definimos esta función que nos devolverá los últimos 5 comentarios del blog en el fichero functions.php. Una vez definida, podremos usarla en nuestro theme, donde más rábia nos dé, simplementa llamándola.

<ul>
<?php ult_comments(10); // 10 últimos comentarios ?>
</ul>

¿Que podemos hacer con todo esto?

Pues lo que queramos, podemos hacer que WordPress se transforme a nuestra voluntad. Nos permite desde añadir funcionalidades que nos ayudan en el día a día, hasta cambiar el concepto de blog por el de CMS, Miniblog, …

Edito:

NUNCA SE DEBE TOCAR EL CÓDIGO DE WORDPRESS

Este artículo intenta mostrar las diferentes formas de extender WordPress, sin necesidad de tocar los ficheros que componen el núcleo de WordPress, osea la raíz y wp-includes/ y wp-admin/. Para poder extenderlo puedes hacer uso de los fichero functions.php de tu theme o generar un plugin con dichas funcionalidades dentro.

La limitación, está en nuestra cabeza :D

6 plugins para el mantenimiento de tu WordPress

10 may

+ 8

Muchas veces no tenemos tiempo para dedicarle al blog el mantenimiento que se merece, por ello debemos delegar ciertas tareas a plugins que las realicen por nosotros. Estos 6 plugins se encargan de realizar las más básicas tareas que nuestro WordPress puede necesitar períodicamente.

  1. Broken link checker: Se encarga de revisar los enlaces salientes de nuestro blog y comprobar que estos están activos aún o no. Muy útil para artículos antiguos.
  2. WP AntiVirus: Un completo set que revisa periódicamente los posibles fallos de seguridad de WordPress.
  3. Akismet: El archiconocido sistema anti spam de WordPress.
  4. www Redirect: Evitando www de la ruta del blog, evitamos que Google pueda pensar que tenemos contenido duplicado.
  5. WP Database Backup: Crea una copia de seguridad de nuestros datos. Dispone de la capacidad de enviar una copia por email. Áltamente recomendable
  6. WP Security Scan: Otro plugin encargado de buscar posible fallos de seguridad en el sistema.

ComentaWP, haz que tus comentarios lleguen a twitter

5 may

+ 8

Anoche Oscar Barber me  muestra comentaWP. Un plugin para WordPress, desarrollado por Miquel Laboria y Oriol Farré que nos permitirá informar en Twitter de los comentarios que se realizan en tu blog.

Instalación

La instalación es igual a la de todos los plugins de WordPress, únicamente tendremos que realizar estos 3 pasos y podemos empezar a configurarlo.

  1. Descargamos el plugin
  2. Descomprimimos el ficheros y lo subimos a nuestro wordpress en la carpeta wp-content/plugins/
  3. Activamos directamente desde el panel administrador.

Configuración

Para personalizar la apariencia que nuestros comentarios tendrán en Twitter, debemos conocer unos parámetros que podemos modificar y que indicarán los datos del usuario que está comentando.

screenshot-1
(Ver Imagen)

Descargar

Podemos descargarlo directamente desde el directorio de WordPress.

Plugin oficial de Bitacoras.com para nuestro WordPress

15 abr

+ 0

Desde Bitacoras.com nos informan de la aparición del plugin oficial con el que podremos integrarnos un poco más con Bitacoras.com.Lo podemos descargar directamente desde el repositorio de WordPress.

WordPress 2.8 con un editor de código decente

21 feb

+ 1

WordPress 2.8 integrará CodePress, una mejora visual al editor de plugins/themes que nos permitirá visualizar más claramente el código de nuestros plugins y themes desde el panel administrador. Por el momento, podemos seguir usando el plugin del que salió dicha funcionalidad o alguna alternativa que hicimos por aquí hace ya más de un año.