Saltar al contenido

El blog de Skatox Entradas

QR-DA: San Cristóbal

El próximo sábado 28 de noviembre se realizará en la ciudad de San Cristóbal (bueno técnicamente es en Palo Gordo el sector al lado de la ciudad), el 2do QR-DA, una reunión de programadores con el fin de colaborar con fundaciones sin fines de lucro. En esta ocasión, se decidió colaborar con la herramienta de código abierto EventoL, la cual se espera utilizar en las distintas sedes del FLISOL 2016.

Así que si deseas reunirte con buenos programadores de todas partes del país, pasar un buen rato con comida y bebidas, compartir tus conocimientos informáticos para una buena causa, promover software y mas. ¡Entonces no dudes en asistir a este evento!

El documento oficial con información del evento, posadas, ubicación se encuentra disponible aquí. Y si desean mas información, pueden comunicarse con Richzendy o Tatica quienes son los organizadores del evento.

¡Happy Hacking!

1 comentario

Agregar rutas personalizadas en el API REST de WooCommerce

WooCommerce es una excelente plataforma para montar tu propia tienda en línea. Aunque mucha gente piensa que WordPress sigue siendo solo una plataforma para blogs, desde hace años se ha cambiado el funcionamiento interno para soportar todo tipo de contenido. WooCommerce es un ejemplo de ellos, pues este plugin permite soportar todo el contenido requerido en una tienda en línea como: productos, órdenes, pagos, descuentos, entre otros. Además de incluir una API REST para realizar acciones adicionales sobre él.

API REST

El plugin incluye una API REST para las operaciones mas básicas (se debe activar previamente), permitiendo comunicación hacia o desde aplicaciones externas, extendiendo aún mas las posibilidades de procesos que se pueden implementar en la tienda. Sin embargo, si manejas flujos de compras personalizados o deseas realizar acciones mas allá de las disponibles en el API por defecto, puedes agregar las tuyas tal como se explicará a continuación.

Desarrollo del plugin

El plugin se divide en 2 archivos, el principal para definir el plugin como tal y permitirle indicar a WordPress en que momento se va a cargar el segundo archivo, que contiene los métodos que responden a las rutas personalizadas del API.

Cargador de la clases

Para modificar WordPress, siempre es recomendable hacerlo a través de plugins, por eso el primer paso es definir un plugin como cualquier otro y dentro del constructor de la clase del plugin, indicar a WooCommerce que luego de cargar el código necesario para implementar el API (a través del hook woocommerce_api_loaded) se deben agregar la(s) clase(s) que implementan las rutas personalizadas (a través del hook woocommerce_api_classes), este código lo pueden ver a continuación:

/**
 * Custom API REST path  class
 *
 * @package MyPlugin
 * @author Skatox
 */
class WC_API_Custom extends WC_API_Resource
{

    const PATH = '/custom';

    /**
     * Function to define each of the custom path
     */
    public function register_routes($routes)
    {
        //GET Request
        $routes[self::PATH . '/orders'] = array(
            array(array($this, 'listShippingOrders'), WC_API_Server::READABLE),
        );

        //POST Request
        $routes[self::PATH . '/orders/(?P<order_id>\d+)/fulfillments.json'] = array(
            array(array($this, 'createItem'), WC_API_Server::CREATABLE | WC_API_Server::ACCEPT_DATA),
        );

        //PUT Request
        $routes[self::PATH . '/variants/(?P<id>\d+).json'] = array(
            array(array($this, 'updateItem'), WC_API_Server::EDITABLE | WC_API_Server::ACCEPT_DATA),
        );

        return $routes;
    }

    public function listShippingOrders($fields = null, $filter = array(), $status = null, $page = 1)
    {
        $wcApiOrders = new WC_API_Orders($this->server);
        $orders = $wcApiOrders->get_orders($fields, $filter, $status, $page);

        //Removes orders without shipping methods
        foreach ($orders['orders'] as $key => $order)
        {
            if (empty($order['shipping_methods'])) {
                unset($orders['orders'][$key]);
                continue;
            }
        }

        return $order;
    }

    public function createItem($order_id, $data)
    {
        //Do insert proccess and then return the response array
    }

    public function updateItem($id, $data)
    {
        //Do update proccess and then return the response array

    }
}

Leyendo observarán que es un plugin de WordPress donde la clase WD_API_LOADER registra los hooks mencionados anteriormente, para inyectar en el momento que Woocommerce carga sus clases del API, las clases que instancia los procesos personalizados a ser implementados en el API.

Al final es recomendable instanciar la clase en un objeto, de este modo es posible acceder a los métodos de forma global desde plugines externos, como por ejemplo para detener la carga de las clases o implementar modificaciones permitiendo dar mayor flexibilidad al plugin.

Clase con los métodos de la API REST

El siguiente paso corresponde a crear la clase que responde a las peticiones HTTP del API. En este ejemplo, se define una constante con el PATH personalizado y en el constructor se definen las rutas personalizadas y el método que se debe llamar que responderá a la petición realizada. Si observas, el parámetro recibido es un array donde la llave representa la ruta relativa del API y como valor, otro arreglo con el nombre de la función a procesar la petición y las banderas del tipo de petición. Estas últimas banderas permiten definir el tipo de petición a recibir, por ejemplo
WC_API_Server::READABLE indica que lee datos desde la petición tal como es una petición GET,
WC_API_Server::ACCEPT_DATA permite decir que lea el cuerpo de la petición y permite leer información para peticiones POST y PUT, entre otros.

/**
 * Custom API REST path  class
 *
 * @package MyPlugin
 * @author Skatox
 */
class WC_API_Custom extends WC_API_Resource
{

    const PATH = '/custom';

    /**
     * Function to define each of the custom path
     */
    public function register_routes($routes)
    {
        //GET Request
        $routes[self::PATH . '/orders'] = array(
            array(array($this, 'listShippingOrders'), WC_API_Server::READABLE),
        );

        //POST Request
        $routes[self::PATH . '/orders/(?P<order_id>\d+)/fulfillments.json'] = array(
            array(array($this, 'createItem'), WC_API_Server::CREATABLE | WC_API_Server::ACCEPT_DATA),
        );

        //PUT Request
        $routes[self::PATH . '/variants/(?P<id>\d+).json'] = array(
            array(array($this, 'updateItem'), WC_API_Server::EDITABLE | WC_API_Server::ACCEPT_DATA),
        );

        return $routes;
    }

    public function listShippingOrders($fields = null, $filter = array(), $status = null, $page = 1)
    {
        $wcApiOrders = new WC_API_Orders($this->server);
        $orders = $wcApiOrders->get_orders($fields, $filter, $status, $page);

        //Removes orders without shipping methods
        foreach ($orders['orders'] as $key => $oreder)
        {
            if (empty($oreder['shipping_methods'])) {
                unset($oreders['orders'][$key]);
                continue;
            }
        }

        return $order;
    }

    public function createItem($order_id, $data)
    {
        //Do insert proccess and then return the response array
    }

    public function updateItem($id, $data)
    {
        //Do update proccess and then return the response array

    }
}

Una vez que proceses la petición, si necesitas devolver un objeto JSON, simplemente debes retornar un array con la información deseada y automáticamente Woocommerce se encargará de transformarlo en un objeto JSON e imprimirlo en la salida.

Recomendaciones

Como podrás observar, no es difícil. En caso que no sepas como desarrollar debido a la poca documentación. Te recomiendo leer el código fuente de las clases del API de Woocommerce, son fáciles de entender, creadas por el mismo equipo del plugin y verás como están creados los métodos existentes. Una de las mejores clases para guiarte, es la de productos que se encuentra ubicada en la ruta wp-plugins/woocommerce/includes/api/class-wc-api-products.php, pues es muy completa y posee todas las operaciones REST soportadas.

Recuerda crear un plugin para esto, evita colocarlo en el functions.php pues será difícil de mantener y dificulta migrar de tema (porque el API dependerá de ésta). Finalmente, recuerda respetar el estándar REST, he visto gente que implementa todo en POST y agrega incompatibilidades a aplicaciones.

Ya depende de tu imaginación, descubrir como extender las funcionalidades de WooCommerce a través de un API REST personalizado.

2 comentarios

Mis artículos en la semana de WordPress de Oja.la

En el blog de Oja.la, están celebrando la semana de WordPress y publicarán una serie de mis artículos (con un poco de mas mejoras y mas contenido) sobre este maravilloso CMS. Así que les invito leer el blog de Oja.la y aumentar sus conocimientos de WordPress.

A continuación les dejo enlazado el primer artículo publicado sobre como aumentar la seguridad de WordPress en 2 pasos.

Deja un comentario

¿Cómo dar a conocer tu marca, aplicación o sitio web a través del email marketing?

Hoy en día, es común (al menos en Venezuela) montar tu negocio desde tu casa y ofrecer tus productos a través de Internet, permitiendo ahorrar el costo de: un local, parte del personal, costo de transporte a tu oficina, entre otros.

Al principio, puede ser difícil dar a conocer tu servicio o producto, generalmente sueles abrir cuentas de redes sociales para promocionar tu producto entre tus amigos y conocidos. Pero en corto tiempo, puedes llegar a un punto donde no puedes hacer crecer aún mas tu sector de mercado, o en el mejor de los casos, tienes tantos posibles clientes que es difícil manejar la comunicación con todos ellos o enviar mensajes personalizados a cada uno de ellos. Además, recientemente a muchas personas les molesta ver publicidad en sus redes sociales y consideran invasivo ver publicaciones sobre ofertas de productos, poniendo dificultades a este medio.

Mail masivo

A pesar de que el correo electrónico es el medio de comunicación mas antiguo en Internet, sigue siendo el mas utilizado, lejos de estar obsoleto y el mas personal (por eso los sitios nos preguntas nuestro correo como medio de identificación). Ademas, debido a lo privado/personal del mismo, es casi seguro que los mensajes que recibimos en nuestra bandeja de correo, serán leídos.

Por esta razón, siempre es el medio preferido para hacer mercadeo a través de Internet, porque suele incrementar las ventas. Ademas, utilizando herramientas como Mailrelay (el cual está disponible totalmente en español y su interfaz es muy intuitiva de utilizar) que permite realizar muchas operaciones con las direcciones de correos para gestionar tu marketing como: crear listas de correos (para segmentar el mercado por edad, tipo, entre otros), gestionar campañas y sobre todo llevar el registro de los enlaces abiertos desde los correos electrónicos enviados.

Este último punto, es el mas importante (y la razón de no enviar correos desde tu cuenta personal) pues te permite realizar campañas, los cuales son correos con contenido y enlaces a tus sitios web con mayor información sobre una promoción o venta, por ejemplo, se acerca diciembre y puedes realizar una campaña de ofertas navideñas, en el correo das un abreboca del contenido, captas la atención del lector, el mismo hará clic y visitará tu sitio para mayor información de tu producto. Al usar las herramientas mencionadas, obtendrás muchas estadísticas que te permitirán conocer si el correo es un éxito, que campaña fue la mejor, puedes realizar pruebas entre segmentos de mercado y ver cual te va mejor, entre otras. Es decir, puedes tener una retroalimentación y mejorar tu forma de darte a conocer.

Recuerda que los usuarios suelen recibir varios correos al día, intenta ser llamativo con el contenido pero no abusar de mucha publicidad
Recuerda que los usuarios suelen recibir varios correos al día, intenta ser llamativo con el contenido pero no abusar de mucha publicidad

Si eres novato como yo y deseas aprender mas sobre el tema, puedes empezar con este libro titulado los 7 aspectos clave del éxito en email marketing o consulta sobre manuales sobre email Marketing, con esta información tendrás las bases para iniciarte en el envío de mail masivo y así dar a conocer tu producto a un sector mas amplio de personas. Recuerda preparar primero tus campañas y tomar en cuenta los consejos para hacer marketing por correo electrónico.

¡Éxitos y deseo que puedas dar a conocer tu producto!

Deja un comentario