domingo, 2 de octubre de 2016

Nuevas caracterizticas en Codeigniter 3

La última versión estable 3.0.3 fue liberado el 31 de de octubre de 2015 (hace ya algún tiempo), pero no había hablado de ella. Así que quiero dejar mis comentarios. Una de las cuestiones mas importantes es el cambio de la licencia de MIT. Las nuevas versiones de CodeIgniter 3.0 se licenciaban bajo una licencia de BSD Apache . Esto significa que ahora se puede utilizar, combinar, copiar, modificar, publicar, distribuir y sub licenciar. Pero no se puede cambiar algunos de los archivos (* MY_).

Cambio de la versión PHP

Ahora requiere minimo PHP 5.2.4, aunque es recomendado usar PHP 5.4 o más nuevo.

Default driver para la base de datos

Ahora Codeigniter 3 cambio el drives para conectarse a la base de datos por 'mysqli' el antiguo driver quedo deprecado.

Actualizado y mejorado el soporte MIME

La lista es bastante larga de los tipos de archivos que se le a añadido soportate por codeigniter:


  • Añadido soporte para pem, p10, p12, p7a, p7c, p7m, p7r, p7s, crt, crl,rsa, der, kdb,sst, cer, csr Certs en mimes.php.
  • Añadido soporte para pgp, gpg, zsh and cdr archivos en mimes.php.
  • Añadido soporte para 3gp, 3g2, f4v, vlc , mp4, wmv Video archivos en mimes.php
  • Añadido soporte para m4a, xspf, au, aac, m4u, ac3, flac, ogg, wma archivos de audio en mimes.php.
  • Añadido soporte para kmz and kml (Google Earth) files, ics Calendar files, and rar, jar y 7zip archivos en mimes.php.
  • Codeigniter 3 a añadido soporte tambien a xml, xsl, doc, docx, php, zip y csv archivos en mimes.php

Output Minification

Nueva librería Output library tiene la función de minificar Javascript, CSS ae inclusive el HTML. Esta echa para compactar el codigo HTML,incluyendo cualquier linea JavaScript y CSS contenida dentro del archivo ayudando a ahorrar muchos bytes de data y mejorando la velocidad de descargar y analisis del navegador.

Minifying HTML Output

Para remover los espacios inútiles del código HTML, solo debemos modificar la configuración en config.php editamos minify_output, lo colocamos como true y listo.


$config['minify_output'] = TRUE;

Minifying JS/CSS

Para minificar CSS o JAVASCRIPT, solo necesitaras incluir dentro del controlador de Assets, o otra manera de hacerlos es manejar tus assets y mostrarlos no como archivos estáticos. Esto lo puedes hacer por que la clase Output tiene un método minify.

$css = $this->output->minify($style_content, 'text/css')
$scripts = $this->output->minify($script_content, 'text/javascript');

Si la configuración minify_output es TRUE, entonces cualquier contenido mostrado con la clase OUTPUT con alguno de los siguientes MIME sera minificado antes de ser enviado al navegador.
  • text/html
  • text/css
  • text/javascript
  • application/javascript
  • application/x-javascript

Nuevas opciones de routeo.

Hay dos opciones nuevas añadidas al area de routeo.

Callbacks

Si estas usando PHP 5.3 o mayor, tu puedes usar funciones anonimas para manejar las rutas similar a:

$route['pagina/(:any)'] = function ($page_slug) {     get_instance()->load->model     $data = array(         'page'  => get_instance()->page_model->find_by_slug($page_slug)     );     $this->load->view('page_wrapper', $data); };

Metodos HTTP  (GET, PUT, POST, etc)

Ahora puedes usar especificos HTTP-verb en especificas rutas en tu archivos routes.php, sin ningun tipo de caminos verdes. Esto es particularmente util cuando estas ahciendo un API Rest. Tu puedes usar metodos HTTP, propios o estandares, añadiendo el verbo al final de la ruta como un array hacia tu ruta. por ejemplo:

$route['products']['put'] = 'product/insert';

Codeigniter a echo multiples de pequeños cambios para volverse más eficiente y para mejorar la funcionalidad. 


Muchos mejoras en las conexiones a la base de datos a través de los drivers. 
Muchos cambios en las librerías ya existentes, como añadir la nueva librería de encriptación que reemplace todas las funciones inseguras que tenia la vieja. 
hay muchos cambios y actualizaciones en codeigniter si quieren ver la lista completa pueden verla aquí.

Si crees que me falto algo. Escribe lo en los comentarios. Saludos...

viernes, 3 de junio de 2016

Bases de Datos en Android, aumentando la velocidad de las inserciones.

La pantalla de inicio de una una aplicación Android estaba demasiado lenta en el arranque, porque descargaba unos 900 sitios en la base de datos SQLite al comenzar la activad. Yo estaba haciendo una gran cantidad de inserciones SQL, con el propósito de llenar una tabla para poder tener la información disponible de manera offline. Buscando una solución encontré por internet el uso de transacciones explícitas en SQLite para aumentar la velocidad de la inserción en la tabla.

La lista que estaba insertando en la tabla contenía 900 sitios, que debían ser insertados en la base de datos, para después ser ubicados en el mapa. y el tiempo que tomaba era de 16 segundos. Este era mi código inicial:


public void createSites(List<Site> objs) {
    for (Site obj : objs) {
        ContentValues values = obj.getContentValues();
        long insertId = db.insertWithOnConflict(database.TABLE_TYPEPENDING,null,values,SQLiteDatabase.CONFLICT_REPLACE);
    }
}

Después de añadir transacciones explícitas en SQLite, el tiempo paso a menos de un segundo, y la información estaba disponible mucho más rápido.

public void createSites(List objs) {
    try {
        //Inicio la transacción
        db.beginTransaction();
        for (Site obj : objs) {
            ContentValues values = obj.getContentValues();
            db.insertWithOnConflict(database.TABLE_TYPEPENDING, null, values, SQLiteDatabase.CONFLICT_REPLACE);
        }
        //Marca la transacción actual como exitosa
        db.setTransactionSuccessful();
    }catch (SQLException e) {
        Log.e(toString(),"Sql error");
    } finally {
        //Termina la transacción
        db.endTransaction();
    }
}

sábado, 5 de marzo de 2016

Como conectar a Android con ADB sobre TCP?

Desde una computadora, si tienes el USB conectado

La forma más sencilla de conectarse mediante WIFI al teléfono, es si ya tienes el teléfono conectado a la pc con USB. Desde una linea de comandos en la computadora, tienes que escribir los siguientes comandos:

adb tcpip 5555
adb connect <IP Telefono>:5555

Asegurate de reemplazar correctamente la ip del telefono que actualmente tiene tu dispositivo.

Descubrir la ip manualmente:

Ve a la configuracion wifi de android, click en el boton de menu en la barra de aciones, as click en avanzado y mira la ip al final de la pantalla.




Usar adb, para descubrir la IP:

Ejecuta los siguientes comandos por adb

adb shell ip -f inet addr show wlan0
To tell the ADB daemon return to listening over USB
adb usb

Proceso manual, desde el telefono (SI el telefono esta rooteado)

Tu puedes habilitar la conexión ADB sobre WIFI desde el dispositivo si tu telefono esta rooteado.

su
setprop service.adb.tcp.port 5555
stop adbd
start adbd


Lo puedes desabilitar con los siguientes comandos:

setprop service.adb.tcp.port -1
stop adbd
start adbd

viernes, 18 de diciembre de 2015

Packt Publishing todos los libros a 5$

A partir del 17 de diciembre 2015 en el Año Nuevo, Packt Publishing está invitando a todo el mundo de la tecnología para explorar su extensa biblioteca de libros electrónicos y vídeo cursos por un precio increíble. Cada eBook y Vídeo que Packtpub ha creado alguna vez estará disponible por sólo $ 5!

miércoles, 30 de septiembre de 2015

Packt's PacktLib subscription Campaign

http://bit.ly/1YLFu4z


This week, Packt Publishing has reduced the price of its PacktLib subscription service. For just $100 a year you have access to every single book in Packt’s huge library of over 3,000 strong eBooks and videos, especially the latest releases that are available as soon as they’re published.

All you have to do is set up a subscription here to get access to the whole service for a full year. Customers are also encouraged to check out the reader for free, which lets them see every book they already own laid out for easy viewing

domingo, 26 de julio de 2015

Packtpub Skill Up Survey Results!



Last month, Packt asked you to take the Skill Up survey to get a greater understanding of the tech world. Over 20,000 of tech professionals responded, leading to the biggest developer salary and skills survey of 2015!

Check out the results of this survey and discover what everyone thinks will be the next big thing in tech and what skills the biggest earners in your sector have under their belt.

At Packt we’re committed to helping the world put software to work in new ways and have launched a whole range of exclusive offers to help you to Skill Up:
  1. Every eBook and Video is now available for $10! Check out our Top 20 here.
  2. Grab some great course bundles - 5 for $25 on every Video and eBook based on your most essential skills.
  3. PacktLib with over 3000 titles in our library at a reduced rate of $80 for a limited time.

Discover what you need to know to be the best. It’s time to Skill Up!

martes, 23 de junio de 2015

Joomla cargar un modulo dentro de un componente

Dejo una función para cargar un modulo dentro de un componente en joomla, despues nada más tienes que invocarla con el nombre de la posición y listo.

function load_module_position( $position, $style = 'xhtml')
{
   switch($style)
   {
      case 'table':
         $style = 1;
         break;
      case 'horz':
         $style = 1;
         break;
      case 'none':
         $style = -1;
         break;
      case 'xhtml':
         $style = -2;
         break;
      case 'rounded':
         $style = -3;
         break;
      default:
         $style = -2;
         break;
   }

   $document   = &JFactory::getDocument();
   $renderer   = $document->loadRenderer('module');
   $params      = array('style'=>$style);

   $contents = '';
   foreach (JModuleHelper::getModules($position) as $mod)  {
      $contents .= $renderer->render($mod, $params);
   }
   return $contents;
}