Módulo de Banwire para WHMCS

Aprovechando que desarrollé el módulo de Banwire para magento, hice el módulo para WHMCS ya que es un sistema que utilizo para hacer cargos a mis clientes (sobre todo de hospedaje web).

El módulo de Banwire para WHMCS permite hacer cargos a tarjeta Visa, Master Card y American Express funcionando de forma transparente (utilizando la API de Pago Pro), de esta forma el usuario nunca deja la página para hacer el pago.

Puse el módulo a la venta por si alguien se encuentra interesado.

Módulo de Banwire para Magento

Desarrollé el módulo de Banwire para Magento debido a que algunos usuarios tenían problemas realizando la contratación de Banorte Payworks (este año hicieron un poco más largo el proceso de solicitud).

El módulo permite capturar los fondos de tarjetas de crédito (Visa, Master Card y American Express) en tiempo real y etiqueta la orden en base al resultado, todo el procedimiento es transparente para el usuario ya que se realiza en la tienda online sin llevar al usuario a una página externa (como lo es con PayPal).

Al igual que mis otros módulos si alguien está interesado el módulo está a la venta.

Certificación TCMD

Hace unas semanas obtuve la certificación TCAD de Appcelerator con el fin de validar los conocimientos que tenía sobre el desarrollo de aplicaciones móviles con Titanium Mobile, el dia de ayer presenté y aprobé el examen para la certificación TCMD (Titanium Certified Mobile Developer) que es de segundo nivel.

Para esta certificación también hay material disponible en español pero el examen es en inglés y cubre los siguientes puntos:

  • Optimización de recursos
  • Desarrollo avanzado de la interfaz del usuario
  • API TableView a fondo
  • Manejo de movimientos y cambios de orientación
  • Recolección de datos ingresados por el usuario
  • API ScrollView a fondo
  • API Animation a fondo
  • Android API a fondo
  • iOS API a fondo
  • Instalación y uso de módulos
  • Extensiones de titanium

El examen de TCMD, al igual que el de TCAD que es requisito para esta certificación, consta de 60 preguntas que se deberán contestar en un máximo de 90 minutos y requiere un 75% de aciertos.

La certificación tiene la finalidad de validar que se tienen los conocimientos avanzados de la API de titanium mobile así como las mejores prácticas para el desarrollo de aplicaciones con este framework.

Al igual que TCAD no es un examen muy complicado pero para este caso si hay que tener un poco de experiencia y un conocimiento más profundo de las APIs de Titanium Mobile.

Aplicación móvil: Saca la fiesta

Hace unos meses hice una aplicación móvil para iOS que buscaba lugares cercanos a tu ubicación en diferentes categorías (bares, cajeros, farmacias, etc.), tenía muchas limitantes ya que fue de las primeras aplicaciones que desarrolle. Sólo desplegaba un máximo de 8 resultados por búsqueda y utilizaba una API obsoleta (Google Local Search).

En lugar de actualizar el código de la aplicación decidí reescribirla desde cero en Titanium Mobile (estaba originalmente desarrollada en Objective-C) agregando un par de nuevas funcionalidades como soporte para iPad, nuevas categorías y nueva API (Google Places).

Ayer terminé la aplicación y la envié para revisión a la App Store por lo que espero en unos 7 días este aprobada, a pesar de ser una aplicación sencilla estoy contento con los resultados.

Pueden descargar la aplicación desde aquí (esta versión aún no esta disponible) y dejo un par de capturas de pantalla.

The app was not found in the store. 🙁

Certificación TCAD

Titanium Certified App Developer

El día de ayer obtuve la certificación TCAD (Titanium Certified Application Developer) de Appcelerator Inc para el desarrollo de aplicaciones móviles utilizando el framework Titanium Mobile.

Para la certificación puedes estudiar los materiales en línea o asistir a algunas de las clases que dan diferentes instituciones, los temas incluidos en el examen son los siguientes:

  1. Javascript
  2. Appcelerator Cloud Services
  3. Desarrollo multiplataforma
  4. Contenido web
  5. Multimedia
  6. Sistema de archivos
  7. Geolocalización
  8. Mapas
  9. Bases de datos SQLite
  10. Propiedades de la aplicación
  11. Redes
  12. SDK Android
  13. SDK iOS
  14. Titanium
  15. Interfaz de usuario
  16. Despliegue y publicación de aplicaciones

Para aprobar la certificación necesitas un mínimo de 75% de respuestas correctas y tienes 90 minutos para contestar el examen. Esta certificación es prerequisito para obtener la TCMD (Titanium Certified Mobile Developer).

Personalmente me pareció facil el examen de la certificación ya que considero que cuento con algo de experiencia desarrollando aplicaciones con este framework.

Considero Titanium Mobile una excelente opción para desarrollar aplicaciones móviles por su facilidade de uso y soporte de la comunidad.

Filtrado de correos por IMAP

Desde hace tiempo necesitaba filtrar correos en una cuenta que no contaba con filtros de correo server-side y la mejor opción que encontre es imapfilter, una herramienta que realiza el filtrado de correos por medio de IMAP.

Imapfilter es muy fácil de configurar y es muy flexible, permite utilizar varias cuentas e incluso mover mensajes entre ellas.

Los requerimientos son muy básicos (Lua, PCRE y OpenSSL) y la instalación es sencilla.

La configuración se realiza por medio de un archivo similar a este:

---------------
--  Options  --
---------------

options.timeout = 120
options.subscribe = true

----------------
--  Accounts  --
----------------

-- Connects to "imap1.mail.server", as user "user1" with "secret1" as
-- password.
account1 = IMAP {
    server = 'imap1.mail.server',
    username = 'user1',
    password = 'secret1',
}

-- Another account which connects to the mail server using the SSLv3
-- protocol.
account2 = IMAP {
    server = 'imap2.mail.server',
    username = 'user2',
    password = 'secret2',
    ssl = 'ssl3',
}

-- Get a list of the available mailboxes and folders
mailboxes, folders = account1:list_all()

-- Get a list of the subscribed mailboxes and folders
mailboxes, folders = account1:list_subscribed()

-- Create a mailbox
account1:create_mailbox('Friends')

-- Subscribe a mailbox
account1:subscribe_mailbox('Friends')

-----------------
--  Mailboxes  --
-----------------

-- Get the status of a mailbox
account1.INBOX:check_status()

-- Get all the messages in the mailbox.
results = account1.INBOX:select_all()

-- Get newly arrived, unread messages
results = account1.INBOX:is_new()

-- Get unseen messages with the specified "From" header.
results = account1.INBOX:is_unseen() *
          account1.INBOX:contain_from('weekly-news@news.letter')

-- Copy messages between mailboxes at the same account.
results:copy_messages(account1.news)

-- Get messages with the specified "From" header but without the
-- specified "Subject" header.
results = account1.INBOX:contain_from('announce@my.unix.os') -
          account1.INBOX:contain_subject('security advisory')

-- Copy messages between mailboxes at a different account.
results:copy_messages(account2.security)

-- Get messages with any of the specified headers.
results = account1.INBOX:contain_from('marketing@company.junk') +
          account1.INBOX:contain_from('advertising@annoying.promotion') +
          account1.INBOX:contain_subject('new great products')

-- Delete messages.
results:delete_messages()

-- Get messages with the specified "Sender" header, which are older than
-- 30 days.
results = account1.INBOX:contain_field('sender', 'owner@announce-list') *
          account1.INBOX:is_older(30)

-- Move messages to the "announce" mailbox inside the "lists" folder.
results:move_messages(account1['lists/announce'])

-- Get messages, in the "devel" mailbox inside the "lists" folder, with the
-- specified "Subject" header and a size less than 50000 octets (bytes).
results = account1['lists/devel']:contain_subject('[patch]') *
          account1['lists/devel']:is_smaller(50000)

-- Move messages to the "patch" mailbox.
results:move_messages(account2.patch)

-- Get recent, unseen messages, that have either one of the specified
-- "From" headers, but do not have the specified pattern in the body of
-- the message.
results = ( account1.INBOX:is_recent() *
            account1.INBOX:is_unseen() *
            ( account1.INBOX:contain_from('tux@penguin.land') +
              account1.INBOX:contain_from('beastie@daemon.land') ) ) -
          account1.INBOX:match_body('.*all.work.and.no.play.*')

-- Mark messages as important.
results:mark_flagged()

-- Get all messages in two mailboxes residing in the same server.
results = account1.news:select_all() +
          account1.security:select_all()

-- Mark messages as seen.
results:mark_seen()

-- Get recent messages in two mailboxes residing in different servers.
results = account1.INBOX:is_recent() +
          account2.INBOX:is_recent()

-- Flag messages as seen and important.
results:add_flags({ '\\Seen', '\\Flagged' })

-- Get unseen messages.
results = account1.INBOX:is_unseen()

-- From the messages that were unseen, match only those with the specified
-- regular expression in the header.
newresults = results:match_header('^.+MailScanner.*Check: [Ss]pam$')

-- Delete those messages.
newresults:delete_messages()

Si el servidor IMAP permite mantener conexiones en reposo puedes dejar el script corriendo todo el tiempo y en el momento que entre un correo lo filtrará.

Por el momento lo instalé en mi servidor web y estoy filtrando dos cuentas de correo pero se me ocurren muchos usos para esta herramienta.

 

Módulo de Banorte Payworks para Magento

Desarrollando una tienda en línea para un proyecto propio decidí desarrollar el módulo para recibir pagos en Magento por medio de Banorte Payworks, desde mi experiencia, siempre ha sido difícil desarrollar algo para Magento por la poca documentación que existe.

Después de horas de pruebas e investigación pude desarrollar el módulo y adaptarlo para poder configurar el comportamiento en los diferentes escenarios.

Como comenté en posts anteriores mi interés es hacer cada vez más uso de esta plataforma de pagos que a mi consideración es una excelente alternativa a las típicas procesadoras de pagos (Paypal, DineroMail, etc.).

Si alguien está interesado el módulo está a la venta.

Actualización 21/12/12: Hay una nueva versión del módulo que soporta 3D Secure y mensualidades sin intereses.


Si quieres recibir más información sobre este módulo en tu correo, puedes utilizar el siguiente formulario:

[activecampaign form=3]

Mi experiencia en cetesdirecto.com

Nunca he sido bueno ahorrando dinero a pesar de haberlo intentado por diferentes medios y métodos pero a final de cuentas dejaba de depositar el dinero y al poco tiempo lo gastaba.

Conocí cetesdirecto.com hace más de un año y me gustó que para mi registro pudiera usar mi FIEL provista por hacienda que equivale a mi firma autógrafa por lo que no tuve que ir a firmar papeles a una sucursal ni nada parecido, cosa que se valora ya que en el caso de un banco se tiene que invertir tiempo para poder abrir una cuenta de inversiones pequeña y muchas veces los ejecutivos no tienen conocimiento de estos instrumentos.

Configuré una herramienta llamada ahorro recurrente que te hace un cargo a tu cuenta bancaria por el monto y en las fechas que indiques, esto es lo que me ha servido para ahorrar porque al igual que me cobran servicios a mi tarjeta (préstamo de auto, celular, etc) ahora me cobran dinero para invertir recurrentemente.

Los rendimientos no son muy altos (4.4% anual aproximadamente en Cetes a 28 días) pero en mi caso me funciona bastante bien, esta configurado para reinvertirse automáticamente después del periodo y si tengo una emergencia puedo vender los certificados para tener mi dinero antes o desactivar la reinversión automática y esperar a que termine el plazo para luego solicitar el retiro.

Hace unos días subí el monto de mi ahorro recurrente y me enteré de que tienen web móvil para consultar las inversiones, el principal atractivo que veo (además de obtener rendimientos de tu dinero) es la disponibilidad de fondos e información ya que en cualquier momento puedes saber cuanto tienes.

Espero seguir con este buen sabor de boca con el servicio e iré actualizando conforme use más el sitio.

Módulo de Banorte Payworks para WHMCS

Aprovechando que me decidí a integrar WHMCS e hice el módulo para registro de dominios con dynadot, decidí de una vez implementar el sistema de pagos Banorte Payworks para el procesamiento de tarjetas de crédito de forma transparente (el cliente no sale de mi sitio ni ve el logotipo de Banorte Payworks).

El módulo permite hacer la captura del dinero y reembolsos (pero solo por el monto total, Banorte Payworks no permite reembolsos parciales).

Espero que con esta implementación empiece a hacer uso de la plataforma ya que casi cumplo un año de haberla contratado y realizo menos de 5 transacciones al mes.

Voy a poner el módulo a la venta por si alguien está interesado en implementarlo.

NOTA: Este módulo es para Payworks 1.

Módulo de registro Dynadot para WHMCS

Hace unos días instalé WHMCS para automatizar la creación de cuentas de hosting y dominios, al comprar la licencia me ofrecieron una cuenta reseller de Enom la cual tiene muchos productos pero se tienen que hacer depósitos prepagados de 100 dólares mínimo, se me hace elevado para la cantidad de dominios que registro al mes.

Desde hace años vengo utilizando Dynadot para registrar los dominios que compro y me gusta bastante por la interfaz limpia además de que tengo acceso a precios de mayoreo.

Estuve buscando un módulo de registro Dynadot pr WHMCS pero no encontré por ningún lado, salvo uno en venta pero no estaba seguro de que funcionaría así que ayer en un tiempo libre me puse manos a la obra.

El módulo ya está probado y funciona perfectamente a pesar de las limitaciones de la API de Dynadot, puse el módulo a la venta en $130 MXN ($9.4 USD) para quien esté interesado, el módulo permite registro, renovación y cambio de DNS y me encargaré de hacer actualizaciones conforme liberen nuevas versiones de la API. Pueden comprarlo aquí.