Jonatan Flores Mango Argentina payments pagos startup equipo

Estamos muy contentos de darle la bienvenida al equipo de Mango a Jonatan Flores.

Durante estos últimos 5 años, Jonatan estuvo haciendo hermosos diseños en proyectos para diferentes marcas líderes y startups alrededor de 15 países, con clientes tan variados como Coca-Cola, Walmart, Desk.com y MuleSoft.

En Mango, Jonatan se desempeñará como Lead Designer creando productos bellos, sofisticados y profesionales; enfocándose no sólo en el aspecto, sino también en la usabilidad e interacción con nuestros usuarios.

En su tiempo libre, Jonatan disfruta de cocinar, correr y desde hace 2 años retomó el disfrute por leer. No es un ávido amante de los deportes, pero le gusta mucho la natación (que desea empezar nuevamente con muchas ansias).

Pueden seguir a Jonatan en sus perfiles de dribbble y Twitter.

¡Bienvenido Jonatan!

¿Querés trabajar en el equipo de Mango? Tenemos todas estas búsquedas abiertas. ¡Postulate ahora!

Creando módulos de front-end con browserify design UI UX javascript

En los últimos años el desarrollo de front-end creció tanto que hoy contamos con una gran variedad de herramientas, frameworks y librerías para construir aplicaciones que corren casi exclusivamente en el navegador (SPA).

La clave a la hora de hacer una SPA es trabajar con pequeños módulos. Esto nos va a ayudar a escribir código mucho más fácil de mantener, refactorizar (en caso de ser necesario) y testear sin volvernos locos.

La idea del post es que construyamos juntos un módulo de front-end utilizando Browserify (y otras herramientas), para que nuestros días como frontenders sean más felices.

Para empezar, vamos a definir que un módulo está formado por:

  • JavaScript
  • Templates (html)
  • Stylesheets (css, less, sass)
  • Assets (imágenes, fuentes)

Y vamos a utilizar la siguiente estructura de archivos y directorios:

|-- module_name/
|   |-- index.js
|   |-- template.jade
|   |-- index.css
|   |-- package.json
|   |-- Readme.md
|   |-- history.md
|   |-- assets/
|   |-- test/

JavaScript

Un módulo de JavaScript es uno o más archivos de código simple que expone solamente aquellas propiedades y métodos necesarios para su uso.

Trabajar de una manera modular nos permite que el código sea independiente, desacoplado, fácil de mantener y reutilizable (DRY).

La versión actual de JavaScript (ES5) no ofrece una forma nativa para trabajar con módulos (pronto va a ser posible!). De todos modos, gracias al aporte de la comunidad, hoy contamos con varios proyectos que nos permiten hacerlo de una forma muy simple.

Hola Browserify!

“Browserify lets you require(‘modules’) in the browser by bundling up all of your dependencies.” – Browserify.org

Browserify es una herramienta open source que nos permite crear módulos en el cliente, utilizando la misma sintaxis que en Node (CommonJS). Por lo tanto, vamos a poder requerir y exportar módulos y manejar sus dependencias como en Node pero en el browser.

Una gran ventaja es que nos permite usar npm para instalar y manejar las dependencias de nuestros módulos. Por lo que podemos «requerir» cualquier módulo que se encuentre publicado en npm, o bien, utilizar módulos privados.

@substack (la mente brillante detrás de todo esto) se tomo el trabajo de portar algunos módulos core de Node para que los podamos utilizar en el navegador y así poder reutilizar al máximo nuestro código (Isomorphic JavaScript).

Para instalarlo, tenemos que correr el siguiente comando en la consola:

$ npm install browserify -g

A modo de ejemplo, vamos a crear el módulo Modal: va a tener como dependencia al módulo «events» (que ofrece Browserify) y exponer los métodos .show() y .hide().

Ya estamos en condiciones de ponernos manos a la obra y codear:

// index.js

'use strict';

/**
 * Module dependencies.
 */
var Emitter = require('events').EventEmitter;
var inherits = require('util').inherits;

/**
 * Creates a new Modal.
 * @constructor
 * @augments Emitter
 * @returns {modal} - Returns a new instance of Modal.
 * @example var modal = new Modal(options);
 */
function Modal(options) {

  // some code

}

/**
 * Inherits
 */
inherits(Modal, Emitter);

/**
 * Shows a modal.
 * @function
 * @returns {modal}
 * @example modal.show();
 */
Modal.prototype.show = function() {

  // some code

  this.emit('show');
};

/**
 * Hides a modal.
 * @function
 * @returns {modal}
 * @example modal.hide();
 */
Modal.prototype.hide = function() {

  // some code

  this.emit('hide');
};

/**
 * Expose Modal
 */
module.exports = Modal

Ahora, tenemos que generar el archivo «.js» que vamos a incluir en nuestro HTML. Para eso, corremos el siguiente comando en la consola:

$ browserify -r ./index.js:modal -o bundle.js

Nota: les recomiendo que lean la documentación para conocer todos los parámetros que podemos utilizar.

Ya podemos agregar en nuestro HTML el archivo «bundle.js» y empezar a utilizar el Modal.

// index.html

<script src="bundle.js"></script>
<script>
  var Modal = require(‘modal’);
  var dialog = new Modal(options);
  dialog.show();
</script>

Transformaciones

Antes de incluir los diferentes archivos de JavaScript en el bundle (archivo) final, Browserify nos permite pre-procesarlos utilizando una serie de transformaciones. Son muy útiles a la hora de compilar CoffeeScript, minificar el código o compilar templates.

Para utilizarlas, primero tenemos que instalarlas y luego indicar su nombre mediante el parámetro «-t» al generar el bundle.

Supongamos que el código anterior lo escribimos en CoffeScript y ahora necesitamos compilar los «.coffee» a «.js» para poder utilizarlos. Para esto, hay una transformación que se llama coffeeify.

$ npm install coffeeify
$ browserify -t coffeeify index.coffee -o bundle.js

Templates

Como sistema de templates vamos a utilizar Jade, ya que ofrece una sintaxis muy simple y ágil, además de ser muy potente.

Si bien, Jade es un sistema de templates que fue diseñado para funcionar en el server, para nosotros es una ventaja ya que el día de mañana podríamos renderizar las vistas de nuestra aplicación tanto en el cliente, como desde el server, utilizando los mismos templates.

Algo que tenemos que tener en cuenta es que Browserify solamente nos permite requerir archivos cuya extensión sea «.js» o «.json». Es por eso, que para requerir los templates tenemos que utilizar una transformación para compilar los archivos «.jade» a funciones de JavaScript: jadeify.

Primero, instalamos la transformación:

$ npm install jadeify -g

Ahora, vamos a crear el template del Modal:

// template.jade

.modal.modal-hide
  .modal-container
    i.modal-close &times;
    .modal-content

Requerimos el template en el JavaScript del Modal:

// index.js

... 

/**
 * Template
 */
var template = require(‘./template.jade’);

...

/**
 * Expose Modal
 */
module.exports = Modal;

Y por último, generamos el nuevo bundle utilizando la transformación para compilar los templates:

$ browserify -r ./index.js:modal -t jadeify -o bundle.js

Stylesheets

Para trabajar con los archivos CSS estamos utilizando un fork de npm-css. Éste módulo nos permite manipular archivos de CSS y sus dependencias, de la misma forma que npm con módulos de JavaScript. En vez de usar «require()», vamos a usar «@import» poder requerir el CSS de otros módulos.

$ npm install npm-css -g

Vamos a agregar normalize.css como dependencia del Modal para luego poder importarlo.

// package.json

...
  "dependencies": {
    "normalize.css": "^3.0.1"
  },
...
// index.css

@import 'normalize.css';

.modal {
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.8);
  display: table;
  height: 100%;
  width: 100%;
  z-index: 9999;
}

...

Ya podemos crear el «bundle.css» con el siguiente comando:

$ npm-css index.css -o bundle.css

¡Con esto ya tendríamos terminado nuestro primer módulo! Pueden revisar en detalle el código del ejemplo completo en Github.

Automatización y Testeos

En este momento, estamos trabajando para automatizar estos procesos y ser mucho más ágiles. De todos modos, podemos usar Grunt o Gulp, ya que ambos ofrecen una gran variedad de plugins o tasks para trabajar con Browserify, Jade y CSS (en la versión que subí a Github, utilicé Gulp).

En Mango, además de CasperJS, usamos Mocha e Istanbul (code coverage) para testear los módulos. Mocha es un framework de testeo que corre en el navegador y también desde la consola, al igual que Istanbul.

Utilizamos scripts de npm para automatizar algunos tests. Lamentablemente no es posible con todos ya que a veces es necesario que se ejecuten sí o sí en el browser (en un futuro post contaremos más detalles).

Esperamos que haya sido de interés y puedan empezar a escribir los módulos de sus front-ends utilizando Browserify.

Cualquier duda que tengan sobre las herramientas que usamos o de front-end en general pueden consultarme vía Twitter a @pazguille.

En las próximas semanas, vamos a seguir compartiendo experiencias y herramientas, así que seguimos en contacto.

¡Bueno, esto fue todo; espero que les haya gustado y hasta la próxima!

🙂

GPG  proteger e-mails privacidad heartbleed NSA

Hoy en día – más que nunca – nuestra privacidad es un tema de gran prioridad. Luego de las revelaciones de la NSA que se hicieron públicas hace aproximadamente un año atrás, de la mano de Edward Snowden, nos hacen considerar que debemos proteger cada vez más los medios que utilizamos para enviar y recibir información: ya sea correo electrónico, acceso a sitios webs, mensajes de texto y demás medios que hoy son los que usa el mundo hiperconectado.

Cada día, más personas relacionadas a los ámbitos informáticos como así también usuarios tradicionales tratan en mayor medida de proteger la información que transita por internet. Es por ello, que en este post trataremos de enfocarnos en uno de los medios de comunicación más utilizados pero poco seguro: los e-mails.

Repasando brevemente su historia, el e-mail es el medio de comunicación más simple de utilizar por cualquier usuario promedio de internet desde hace varias décadas para intercambiar información de todo tipo. Pero este servicio – principalmente en sus comienzos – no fue creado con la palabra «seguridad» en mente. Miles de servidores se comunican mediante enlaces inseguros, direcciones que pueden ser falsificadas, y sin validar ningún tipo de información que proteja nuestra identidad o privacidad.

Una forma simple de resolver esta problemática es utilizar la herramienta de cifrado PGP (Pretty Good Privacy), haciendo uso de su version Open Source, GPG (GNU Privacy Guard). Esta herramienta nos permite generar una llave pública y privada de forma tal que al enviar un correo, el remitente cifre el contenido con nuestra llave pública para posteriormente el destinatario al recibirlo lo pueda descifrar con su correspondiente llave privada. En Mango hacemos uso de esta y otras técnicas que presentaremos en próximos posts.

En este ejemplo, haremos foco en cómo hacer uso de esta técnica implementando la aplicación Mailvelope para navegadores Chrome o Firefox, pero es posible portar el uso de GPG directamente en varios clientes de correo como Mozilla Thunderbird, Mail de Mac, Outlook y muchos más como así también en distintos sistemas operativos, ya sea en Linux, Windows, Mac OS X, iOS, Android, y más.

Implementando Mailvelope

Como primer paso, debemos instalar la extensión para nuestro navegador siguiendo el instructivo de este vínculo.

Una vez instalada, debemos generar nuestras llaves pública y privada. Para ello accedemos a la configuración de Mailvelope haciendo click en el ícono de la extensión que se encuentra en la barra de menú del navegador, y posteriormente a la solapa “Generate Key”.

Dentro de esta, veremos varios campos a completar, un ejemplo de que datos colocar son los siguientes:

PGP-Mango-1(Click para ampliar)

Creadas nuestras llaves, debemos exportar la llave pública, que enviaremos a las personas que deseen cifrar los correos que nos envíen. Para esto, accedemos a la solapa “Display Keys” y haremos click en la opción “Export > Display Public Key > Copy to Clipboard” sobre la cuenta que contiene las llaves que acabamos de crear.

PGP-Mango-2(Click para ampliar)

A partir de ahora, poseemos una llave privada y pública que podemos enviarle a las personas que deseemos para así poder enviarnos correos cifrados de manera segura.

Hecho lo anterior, enviemos un correo de prueba.

Correo de Prueba

Utilizando una cuenta de Gmail redactaremos un nuevo correo, en este veremos algo similar a lo siguiente:

PGP-Mango-3(Click para ampliar)

En la parte superior derecha veremos un recuadro. Haciendo click en el mismo podremos acceder a las opciones de Mailvelope que nos permitirán decidir que llave publica utilizaremos para el/los destinatario/s del correo que deseamos enviar. En este caso seleccionaremos «openpgp@getmango.com».

PGP-Mango-4(Click para ampliar)

Luego de esto, enviaremos el correo normalmente con la variante de que el contenido del mismo se encuentra cifrado.

Al recibirlo, la aplicacion nos mostrara nuestro correo cifrado  y nos permitirá descifrar este ingresando la contraseña que ingresamos al momento de crear nuestras llave publica y privada.

PGP-Mango-5(Click para ampliar)

¡Eso es todo!

De ahora en más podemos enviar y recibir correos de manera más confidencial, asegurándonos que únicamente nosotros tengamos acceso a leer esta información.

¡Esperamos que esta herramienta les resulte tan útil como a nuestro equipo a la hora de enviar información sensible usando correo electrónico!

Guillermo Paz Mango Argentina payments pagos startup equipo

Estamos muy contentos de darle la bienvenida a Guillermo Paz al equipo de Mango.

Guille pasó los últimos 5 años en MercadoLibre donde cumplió funciones como Desarrollador Frontend Senior y fue uno de los responsables de Chico UI, una librería open source que ofrece un conjunto de componentes UI para la construcción de frontends.

En Mango, Guillermo se desempeñará como Desarrollador Frontend Senior y Evangelizador de Producto, lo que le permitirá trabajar en el corazón de los productos de Mango y adicionalmente colaborar estrechamente con la comunidad de desarrolladores para que puedan sacar el mayor provecho de nuestras soluciones.

Cuando Guille no está trabajando en los productos Mango, disfruta de ver series y películas, jugar al fútbol (gran defensor por derecha), jugar con su PS3 (su preferido: God of War), patinar en longboard, aprender sobre nuevas tecnologías web y seguir experimentando con JavaScript.

Pueden seguir a Guillermo en su perfil de GitHub y su cuenta de Twitter.

¡Bienvenido a Mango!

¿Querés trabajar en el equipo de Mango? Tenemos todas estas búsquedas abiertas. ¡Postulate ahora!