Cómo ver todos los custom fields asignados a un post

En varias ocasiones he necesitado ver los custom fields almacenados en la base de datos relativos a un post en concreto. Esto es posible verlo en la base de datos, filtrando la tabla wp_post_meta por el ID de post correspondiente.

Sin embargo, he preparado un código que permite verlo directamente desde el back de WordPress al editar un post, cosa que lo hace mucho más práctico. Aquí va el código en cuestión:


function add_cfs_metabox() {
	add_meta_box(
		'add_cfs_metabox_content',
		'Custom Fields used',
		'add_cfs_metabox_content',
		'post',
		'side',
		'default'
	);
}
add_action( 'add_meta_boxes', 'add_cfs_metabox' );

function add_cfs_metabox_content(){
    global $post;
    $myvals = get_post_meta($post->ID);
    foreach($myvals as $key=>$val){
        echo $key . ' : ' . $val[0] . '<br/>';
    }
}

En el caso que el post type no sea «post» sino otro de custom, podéis cambiar el cuarto parámetro «post» por lo que sea.

El resultado en el back, se ve así:

Si queréis que solo salgan los nombres de los custom fields y que no salgan los privados (que con el plugin ACF básicamente la lista se duplica) podéis usar este código para la segunda función:

function add_cfs_metabox_content(){
    global $post;
    $myvals = get_post_meta($post->ID);
    foreach($myvals as $key=>$val)
    {
        if($key[0] != '_') echo $key.'<br/>';
    }
}

De esta forma, el resultado queda así:

¡Espero que os sirva de ayuda!

Guía de diseño del proceso de compra de WooCommerce

Estructura para el diseño del carrito de WooCommerce

Es posible mostrar una calculadora de precio de envío en el carrito, en caso de no estar logueado en la web y tener perfil te permite saber el coste del envío antes de rellenar el checkout.

Estructura para el diseño del checkout de WooCommerce

Estructura para el diseño de la página de confirmación de compra de WooCommerce

Error SMTP de validación de certificado SSL en WordPress

Normalmente utilizo un plugin para enviar los emails de WordPress vía SMTP. Recientemente me he encontrado con este error en algunos WordPress que gestiono después de haber activado un certificado de seguridad SSL en el servidor.

Warning: stream_socket_enable_crypto(): SSL operation failed with code 1. OpenSSL Error messages:
error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed in /home/www/wp-includes/class-smtp.php on line 344

En vez de gestionarlo con un plugin puedes añadir este código en tu fichero functions.php:

add_action('phpmailer_init','send_smtp_email');
function send_smtp_email( $mail )
{
    // Define que estamos enviando por SMTP
    $mail->isSMTP();
 
    // La dirección del HOST del servidor de correo SMTP p.e. smtp.midominio.com
    $mail->Host = "ruta del servidor";
 
    // Uso autenticación por SMTP (true/false)
    $mail->SMTPAuth = true;
 
    // Puerto SMTP - Suele ser el 25, 465 o 587
    $mail->Port = "587";
 
    // Usuario de la cuenta de correo
    $mail->Username = "usuario";
 
    // Contraseña para la autenticación SMTP
    $mail->Password = "contrasena";
 
    // El tipo de encriptación que usamos al conectar - ssl (deprecated) o tls
    $mail->SMTPSecure = "ssl";
 
    $mail->From = "mail@dominio.com";
    $mail->FromName = "Tu nombre";
	
	// Esto es lo que soluciona el error de validación
	$mail->SMTPOptions = array(
		'ssl' => array(
			'verify_peer' => false,
			'verify_peer_name' => false,
			'allow_self_signed' => true
		)
	);

}

Custom opengraph image with Yoast SEO

Yoast SEO plugin automatically add the featured image of posts as an image opengraph meta tag. If you want to override or customize this setting, you can make use of filter.

In this case, we needed to display a custom featured image of a taxonomy which is assigned to the tax with a custom field added by ACF plugin.


function my_own_og_function() {

	if(is_tax('tax_name')){
		$tax_name = get_term_by('slug', get_query_var('tax_name'), 'tax_name');
		$img = get_field('image', 'tax_name_'.$tax_name->term_id);
		if($img){
			$GLOBALS['wpseo_og']->image_output( $img['sizes']['large'] );
		}
	}
    
}
add_action( 'wpseo_opengraph', 'my_own_og_function', 29 );

Optimizar vídeo para web con Handbrake

El formato de vídeo para web más universal es el mp4. Para exportar un mp4 comprimido y optimizado para web os recomendamos Handbrake, un programa gratuito para Mac.

HandBrake soporta múltiples formatos de vídeo. Para exportar un vídeo a mp4 optimizado para web hay que hacer click en Source, abrir el vídeo en cuestión y marcar las siguientes opciones:

handbrake-mp4-video-web-optimized

 

Subir archivos de tipo SVG a WordPress

WordPress tiene restringida la subida de ficheros de formatos determinados. Uno de ellos es el SVG, cada vez más usado en el mundo web. Para poder subir ficheros SVG en WordPress, es necesario añadir este filtro en functions.php.

function llos_mime_types($mimes) {
 $mimes['svg'] = 'image/svg+xml';
 return $mimes;
}
add_filter('upload_mimes', 'llos_mime_types');

Error 500 con AJAX Thumbnail Rebuild, imposible regenerar las imágenes

Si la librería de tu WordPress pesa mucho, es posible que AJAX Thumbnail Rebuild no te permite regenerar las imágenes por falta de memoria de tu hosting. Mi servidor tiene un límite de 256MB de memoria, y en este caso la página web tiene unas 7.000 imágenes.

Para solventar el problema he sustituido la función del fichero php del plugin:

$attachments =& get_children( array(
'post_type' => 'attachment',
'post_mime_type' => 'image',
'numberposts' => -1,
'post_status' => null,
'post_parent' => null, // any parent
'output' => 'object',
) );

Por esta función que consume menos recursos y me ha permitido lanzar la opción de regenerar sin problemas.

$attachments = $wpdb->get_results("SELECT id, post_title FROM {$wpdb->posts} WHERE post_type='attachment' AND post_mime_type LIKE 'image%'");