martes, 18 de octubre de 2011

Algunos trucos con el httpd.conf y php.init

Php en su archivo de configuración tiene una serie de atributos interesantes. Muchos de los cuales en mi vida he visto y otros que no les presto mucha importancia. Curiosamente hace un par de semanas atrás, mi jefe directo me asigno una misión bastante peculiar. Tenia que hacer funcionar local un aplicación. No voy a rondar en detalles. Si los quieren leer pueden verlos aquí.

En mi búsqueda de hacer funcionar dicha aplicación me tope con algunas variables en los archivos de configuración en el php y en el apache que quiero compartir por aca:
 
Primer truco

Uno muy interesante es poder anular los warning en php.
Usando la variable siguente en el php.init:

error_reporting = E_ALL & ~E_NOTICE

Esto le dice al Php que muestre los errores, pero no los warning o Notice como se les conoce. Entonces imaginemos que en el php creamos un array o tratamos de acceder alguna variable global y después simplemente tratamos de acceder sus datos con un índice que no existe.

Ejemplo:

echo $_REQUEST["email"]; 

Si esta variable no se encuentra configurada en el php.init, el warning es mostrado.

Sin embargo puede presentar problemas intensos de hackeo. Yo no recomendara utilizarlos.

Segundo Truco

Otro truco que si me parece mas util de usar es el: auto_prepend_fileauto_append_file. Estos son archivos que se cargan al inicio de cualquier script y despues de cualquier otros script en su orden respectivamente.

Un ejemplo seria algo asi como:
auto_prepend_file = /home/sites/koza/phpdefines.php

Esta variable auto carga o auto ejecuta este script antes de cualquier ejecusion. Es equivalente a:

inlcude('/home/sites/koza/phpdefines.php');

En el incio de cualquier script.

Tercer Truco

Ejecutar los script en php en archivos con extensión html. Al inicio pensé que esto seria de lo mas trivial del mundo. Honestamente confieso que me tomo más tiempo del que pensé. Realmente es trivial, pero encontrar el lugar para poner la configuración fue lo que me tomo mucho tiempo. Nota: Se puede hacer esto un archivo .httpaccess. Sin embargo no logre hacerlo funcionar por eso prefiero dejarlo como un nota (De que en teoría es posible).


En el archivo de configuración de apache (httpd.conf)

Buscamos la línea:

AddType application/x-httpd-php

Y le agregamos al final .htm y .html

Quedando algo asi como:

AddType application/x-httpd-php .htm .html

Esto es muy útil por razones de seguridad. Escondiendo en que esta programado la aplicación porque en el browser se vera simplemente .html en los scripts que en realidad son php. Pienso que es una excelente practica de configuración del los servidores.

Cuarto Truco.

Los virtual host, las configuración https y el /etc/hosts. Estos chicos pueden hacer una verdadera epifanía si no se sabe configurar bien. Hagamos algo básico y general. Los archivos hosts son archivos especializados dentro de los sistemas operativos (/etc/hosts para linux, unix y derivados) -> notese el s al final. Este archivo "simula" la llamada de un dominio remplazando por un ip previamente configurado.

Ejemplo:
127.0.0.1 koza.com

Si en el browser abro la dirección www.koza.com en realidad el archivo hosts se encarga de cargar mi servidor local.

Quinto Truco.

Los virtual Host son una noble invención, junto con el archivo host pueden hacer grandes hazanas.
Daremos por un hecho que existe en el archivo host la configuración anteriormente dada.

Entonces podemos construir de koza.com un mundo de reglas virtuales de nuestro sitio como:


        ServerName cruiser.koza.com
        UseCanonicalName Off
        DocumentRoot /home/sites/koza/htdocs/

    SetEnv SITE_LINK_URL http://www.google.com


En la configuracón arriba establecida le estamos diciendo al apache (Con ayuda del host file) que la proxima vez que alguien acceda a cruiser.koza.com su configuración personalizada va a usar Document Root en la carpeta /home/sites/koza/htdocs y que va a tener una variable de entorno personalizada llamada SITE_LINK_URL. Podemos hacer uso de esta en Php asi:

define("SITE_LINK_URL", $_SERVER["SITE_LINK_URL"]);

domingo, 9 de octubre de 2011

A que te Hackeo!!!

Esa fue mi reacción, cuando con mirada frenética y sin menor contemplación una base de datos requería para realizar un encargo inusual de mi jefe inmediato. Este me había solicito echar ha andar local un proyecto web, de la forma que fuera sin importar lo medios. Solo contaba con un FTP.  

Notas: Para evitar cualquier problema evitare nombres, definiciones o cualquier cosa que me pueda llevar a la orca.

En este mundo hay personas que uno simplemente no les puede decir No o darse el lujo de quedarles mal. Para mi una de esas personas es mi Jefe. Lo curioso no es porque sea mi jefe, no es porque sea mi mejor amigo o alguien al que le deba mucho. Es porque simplemente es alguien que me supo ganar como aliado, es alguien que antepone la persona antes que un puesto, un titulo o nombramiento. Alguien que yo respeto, que sabe me apoya en mi ideas locas, que toma en cuenta mi opinión no importa lo ocupado que este. Alguien de admirar.

Y hay empieza mi viaje oscuro, llevándome por el sendero de la devastación informática, a invocar las poderosas magias negras y arcanas del Hackeo Ético. Mi enigmática hazaña empieza con lo mas básico. Un Ftp "abierto de patas", como la puta piedrerita de la linea del tren. Casi desnuda y sin menor seguridad. Completamente irresistible (Sarcasmo negro). La misión que Vega me encomendó es que de una carpeta en un FTP X, lograra descargar un sitio Web (HTML, JS, CSS, PHP) y tratara de correr dicho proyecto en local.

Resulta que dicho proyecto tenia, SSL, Base de datos y unas configuraciones en Php que solo Dios sabe. Ya me conocen, cuando algo es realmente "pichudo", es donde mas me motivo. El reto, las cosas difíciles es algo que me apasiona.
Me di a la tarea de descargar los script y analizarlos en mi computadora local. Después de luchar un rato y simplemente convencido de que la única manera que lograría cumplir con mi misión era entrando por SSH al FTP. Buscar la base de datos, los Certificados SSL en Apache, ademas de la configuraciones de los directorios virtuales.


Tenía la primera regla de oro del hackeo a mi favor. Muchas veces el hackeo es algo que funciona por pura y real oportunidad. No es como en las películas, que tienen equipos de codificación o cosas asi. Aveces hackear es algo tan sencillo como robar el password o asumirlo (abs123, cumpleaños, cédula). También son cosas mas avanzadas como debilidades en el software. Por lo general cuando se descubre una debilidad en un software son un par de días (al menos en software libre) para encontrar el parche de seguridad. Pero el hacker que logra encontrar dicho fallo, se vuelve muy famoso o simplemente tiene un par de días para hacker todo lo que pueda. 

NOTA:
No se crean lo de las películas. No todos los software se pueden hackear. Hay algunos que son super seguros y al menos que encuentren un fallo de seguridad o logren robar un password no lo alcanzaran. Se imagina que existiera un hacker que pudiera romper cualquier seguridad. Podría acceder al banco que quisiera, comprar con tarjetas de crédito robadas. Digamos que seria la persona mas poderosa en el mundo.

Resulta que este FTP que les hablo, estaba tan mal configurado que me permitía llegar a Raíz de un directorio UNIX. YAHOOO, tenia la oportunidad que cualquiera hacker desearía. Una mala configuración en un software. Solo necesitaba ver como lograr entrar a servidor por SSH. No dure mucho en pensar que la solucion estaba en:

ssh-keygen -t rsa

El RSA generado lo subí al directorio del home del FTP. Después cuando ejecute el SSH, BINGO. Estaba dentro del servidor para hacer lo que me viniera en gana. Lo primero, la base de datos. Necesitaba buscarla. Con tan mala suerte que la base no estaba instalada en el Mysql del server. Después de hacer algo de magia con un par de comando, encontre un respaldo en SQL (Otra caseria oportunista exitosa). Simplemente lo importe en mi computadora con el siguiente comando:


mysql -u koza basededatosx << backup.sql

Y descargue todos los archivos que necesitaba buscando los comandos por ssh y despues pasarlos a mi servidor local.

Las próxima entrada será; Lo que aprendí en php.init y el httpd.conf en mis días de hacker... No se las pierdan.

martes, 27 de septiembre de 2011

Upload de QPixmap a Php

Hoy tuve que enfrentarme a la tarea de subir una imagen desde un Programita en C++ a un Script en web de PHP.
Al inicio pensé que no seria complicado pero después de un rato me di cuenta que era la tarea era "infernal".
Mi primera opción fue usar CURL, pero despúes de varios intento fallidos me decline por QT.
Qt tiene una serie de clases para manejo de Network. Sin embargo la mayoría a quedado obsoleta dejando muy pocas en juego.
Al final me decidí por hacerlo con QNetworkAccessManager. Veamos código primero y despúes la explicación.

Prueba Conceptual:

Form en HTML

Enviar un nuevo archivo:

Codigo PHP para subir imagenes

$target_path = "uploads/";

$target_path = $target_path . basename( $_FILES['userfile']['name']); 

if(move_uploaded_file($_FILES['userfile']['tmp_name'], $target_path)) {
    echo "The file ".  basename( $_FILES['userfile']['name']). " has been uploaded";
} else{
    echo "There was an error uploading the file, please try again!";
}

Nota:
No mucho que explicar aca, un form que sube cualquier cosa. Esto se lo manda al PHP y lo salva en una carpeta de upload.

Ahora lo que intenso hacer es simular el request del browser con C++ con QT.

void UploadManager::upload(QString url, QPixmap img){
    QNetworkAccessManager *manager = new QNetworkAccessManager(this);
    connect(manager, SIGNAL(finished(QNetworkReply*)),
    this, SLOT(downloadFinished(QNetworkReply*)));
    QByteArray bytes;
    QBuffer buffer(&bytes);
    buffer.open(QIODevice::WriteOnly);
    img.save(&buffer, "PNG");
    QByteArray multipartform;
    QString crlf("\r\n");
    QString boundaryStr("---------------------------109074266748897678777839994");
    QString boundary="--"+boundaryStr+crlf;
    QString filename = "test.png";
    multipartform.append(boundary.toAscii());
    multipartform.append(QString("Content-Disposition: form-data; name=\"userfile\"; filename=\"" + filename + "\"" + crlf).toAscii());
    multipartform.append(QString("Content-Type: text/plain" + crlf + crlf).toAscii());
    multipartform.append(bytes);
    multipartform.append(QString(crlf + "--" + boundaryStr + "--" + crlf).toAscii());
    QNetworkRequest request;
    request.setUrl(QUrl(QString("http://127.0.0.1/PruebasConceptuales/upload/subearchivo.php")));
    request.setHeader(QNetworkRequest::ContentTypeHeader, "multipart/form-data; boundary=" + boundaryStr);
    manager->post(request, multipartform);
}

Explicación:

Básicamente, lo que hacemos es construir el Request que usa Firefox. Se sabe que cuando se va a subir una imagen el Archivo pasa por un proceso de Base64. Curiosamente el QPixmap simplemente lo convierto en un flujo de Bits (lineas 5 - 8). Y con eso basta para subir. Despúes seguidamente hacemos otro Array de Bits con el cual empezamos a meter todos los datos para simular el post (Lineas 8 -18). Creamos un QNetworkRequest y le decimos al QNetworkAccessManager que use el request y que le pase todos los datos con manager->post(request, multipartform);

Cualquier consulta no duden en comentar :P

lunes, 26 de septiembre de 2011

Kde - Dolphin - Symbolik Link Gui

Hoy saque el rato para hacer un par de Desktop entries que me permitirán hacer los symbolic linnk.

Ya saben el clasico:

ln -s <Origen> <destino>

La cuestión es que por razones meramente laborales, últimamente he tenido que ejecutar ese condenado comando ya varias veces. No es difícil simplemente es medio cansado escribir esas enormes direcciones.

Buscando en el repo y "googleando" tope con tan mala suerte que no encontré ningún GUI. Curiosamente hay un proyecto de symbolic link para "Guindos". Aqui le pueden echar una mirada.

Bueno entonces, me decidí a hacer mi propia versión del asunto. En vista de que un programita en C++ cumpliría mis expectativas, pensé que no seria adecuado ya que estar buscando dos path con un FileChooser es bastante irritante. Sin embargo era mejor que escribir los path a mano. (Vean kompare como ejemplo)

Entonces la inspiración me llego con Dolphin, si pudiera usar el menu contextual para generar orígenes y destinos. Hasta el momento no se como hacer plugin para Dolphin (No se si se puede) pero si había usado los desktop entries para expandir las opciones del menú contextual.

Bueno, entonces manos a la obra.

Como funciona?

Desktop entrie es un archivo especial en los escritorios X definido por FreeDesktop. Es un simple archivo de texto que define reglas y la ejecución de comandos.

Para que funcionen en KDE se puede poner en dos lugares:

/usr/share/kde4/services/ServiceMenus/

/home/<User>/.kde/share/kde4/services/

Y con solo ponerlos ahí basta. Cuando Dolphin refresque estos entries agregara el comportamiento definido en los menus contextuales.

Yo necesitaba habilitar la opción de origen a cualquier cosa, archivos, carpetas.
Entonces la definición fue asi:


[Desktop Entry]
Type=Service
X-KDE-ServiceTypes=KonqPopupMenu/Plugin,inode/directory,all/all,all/allfiles
X-KDE-Submenu=Symbolic Links
X-KDE-AuthorizeAction=shell_access
Actions=lnorigin;

[Desktop Action lnorigin]
Name=Origin
Icon=/opt/resources/SymboliclinkOrigin.png
Exec=bash /opt/scripts/services/lnorigin.sh %f

El script simplemente salva %f  en un archvio temporal en home:

#!/bin/bash
echo $1 > /home/koza/.lnorigin.txt

El asunto con el Destino fue diferente. El menú contextual de Dolphin solo debía mostrar la opción cuando se estuviera apuntando a una carpeta. Esto se debe a que en la carpeta me va a pedir el nombre (Utilice el comando KDialog). Mi definición y el script que hace el truco por abajo fue así:

[Desktop Entry]
Type=Service
X-KDE-ServiceTypes=KonqPopupMenu/Plugin,inode/directory
X-KDE-Submenu=Symbolic Links
X-KDE-AuthorizeAction=shell_access
Actions=lndesteny;

[Desktop Action lndesteny]
Name=Destiny
Icon=/opt/resources/SymboliclinkDesteny.png
Exec=bash /opt/scripts/services/lndesteny.sh %f


#!/bin/bash
path=$1
if [ -f /home/koza/.lnorigin.txt ]
then
    name=$(kdialog --title "Destiny Name" --inputbox "What name do you want?")
    ln -s `cat /home/koza/.lnorigin.txt` $1/$name
else
    kdialog --error "Destiny is not setted"
fi

Notas:
Queda de mas decir que la ubicación de la imagen, la ubicación donde se va a correr el script y otras cosas deben ser ajustados.

PD: Los archivos desktop entries pueden tener cualquier nombre pero con extensión .desktop.

Si tienen problemas comenten abajo y si esto es como muy solicitado puedo hacerme un script de instalación.

Actualización:

Descubri que la manera mas rapida para refrescar los desktop entries (inclusive imagenes) es atravez del comando siguente:

#!/bin/bash
kbuildsycoca4

domingo, 25 de septiembre de 2011

Qt + manipulación de imágenes

Como muchos de mis "seguidores" saben. Yo adoro C++ y QT cuando a programación en linux respecta. La cancha esta bastante clara para mi.

1. Qt tiene mejor documentación ( assistant - Programa de ayuda)
2. Es nativo en c++
3. El 90% de todo tiene ejemplos en codigo
4. El IDE QDevelop es una maravilla.

En fin muchas cosas que algún día escribiré una entrada sobre por que QT es "chiva".Sin embargo no opaca GTK aunque a titulo personal no me gusta.

Hoy he estado haciendo pruebas conceptuales (Pequeños programas) para desarrollar un programa para mi mama.

En mi viaje me encontré con la manipulación de imagen.
Ya había usado manipulación de imágenes anteriormente en QT, algo bastante sencillo pero me daba la idea de por donde buscar. Además en lo de manipulación de imágenes se respecta yo tengo mucha experiencia en Java.

Qt tiene varios clases de manipulación de imágenes para distintos niveles.

QImage:
Esta provee de un set de métodos para manipulación a nivel de Pixel.

QImage ImageDialog::verticalrotation(QImage source_image){
    QImage new_image(source_image.width(), source_image.height(), source_image.format());
    int height_subtraction = source_image.height() - 1;
    for(int x = 0; x < source_image.width(); ++x)
        for(int y = 0; y < source_image.height(); ++y)
            new_image.setPixel(x, height_subtraction - y, source_image.pixel(x, y));
    return new_image;
}
QPixmap:
Esta provee una serie de métodos para realizar transformación de nivel mas alto. Puede ser rotaciones, dimensionar, cortar partes de images, entre otras.
//Corta una sección de una imagen más grande 
QPixmap test = QPixmap(QString::fromUtf8("/home/koza/47411-bigthumbnail.jpg"));
QPixmap chunk = test.copy(10,10,100,100);
label->setPixmap(chunk);
QPainter:
Esta clase provee manipulación de utilitarios. Metodos como dibujar texto, eclipces, rectangulos. Es muy semejante a Ghaphics2D de java.
QPixmap pic(QPixmap::fromMimeSource( "camera.png" ));
QPainter paint;
paint.begin(&pic);
paint.setPen( Qt::blue );
paint.drawText( rect(), AlignCenter, string);
paint.end(); 
mPixLbl->setPixmap(pic);

Convertir de un tipo a otro es relativamente sencillo.  No voy a poner los detalles acá. Sin embargo es bueno comentar que existe una serie de clases para manipulación de imágenes.

Solo resta decir que escoger la clase adecuada depende de lo que se quiera programar.

domingo, 18 de septiembre de 2011

Eyeos -> Unable to search all data matching $transferObject from database

Todo empezó hablando con un compañero del trabajo que es tan entusiasta en programación y de tema en tema empezamos a "fachentiar" sobre las famosas cloud. Fue donde le comente un poco sobre este sistema (EyeOs). Es muy impresionante y open source. De hecho me encanta el Api. Es un engine muy curioso el que desarrollaron.

En la oficina yo uso KDE 4. El problema es que KDE viene por defecto con Mysql, dando problemas cuando tienes que usarlo para otra aplicación como WordPress o EyeOS. Para mayores detalles se puede acceder aca. En la instalación es sencillo, simplemente le establecemos el socket Unix de la siguiente forma:

:home/koza/.local/share/akonadi/socket-sabrina/mysql

Pero cuando tratas de crear una cuenta veras el siguiente problema:

Unable to search all data matching $transferObject from database

Esto se debe a un problema con la conexión a la base de datos de mysql.

Pero si yo veo el esquema de la base de datos con el GUI de mysql?
Si es verdad. La instalación se lleva a cabo de forma exitosa. Pero la instalación usa un código muy diferente al de la aplicación para su funcionamiento productivo. Los scripts de instalación son basicamente desechados una vez la aplicación esta configurada.

Entonces me puse a travesear el código. Muy claro, muy limpio, soy un fan de los desarrolladores de esta aplicación. En mi investigación el script GenericDao.php en el método getConnection esta la magia.
Se implemento usando la clase PDO. (Esto es algo generico de PHP para ecapsular las conexiones a las bases de datos). Entonces el truco es más sencillo de lo que creen. Basta simplemente con abrir settings.php. En la definición de la variable SQL_CONNECTIONSTRING hay que agregar la declaración del unix_socket al string de conexión.


define('SQL_CONNECTIONSTRING', 'mysql:host=localhost;dbname=eyeos;unix_socket=<Ubicación de socket>');

Este seria para mi caso:

define('SQL_CONNECTIONSTRING', 'mysql:host=localhost;dbname=eyeos;unix_socket=/home/koza/.local/share/akonadi/socket-sabrina/mysql.socket'); 

Espero les sirva. Cualquier consulta comenten :P

sábado, 17 de septiembre de 2011

Un extraño en tierras ajenas. Freedom software day sarapiqui

En estas fechas se celebra el Freedom Software Day. Como buen Geek, simpatizo con la causa y me di a la tarea de incorporarme a las actividades en las que la Universidad Nacional pensaba desenvolverse. La experiencia de hoy a sido enriquecedora pero algo extraña. Todo empezó cuando la Red costarricense de software libre. Grupo al que formo "parte" estaban solicitando ayuda para hacer estantes y charlas para la cede de Sarapiqui. Me ofrecí para ambas actividades. Mi Stands estaría basada en juegos libres y mi charla en entornos de programación en Linux. Quiero abrir un paréntesis para mencionar que el el año pasado colabore con la frase "voy a ayudar" en lo que me pusieran a hacer. Me lleve una amarga experiencia a la cual no quiero tomar remembranza en este momento. Este año dije "Colaborare pero sera en algo que realmente me motive".

En vista que llevaría todo el equipo de juegos eso consistía en; el teclado gammer, el joysitick, los parlantes, la compu. Lo único que solicite era el "RAY". Jennifer Vargaz se ofreció en llevarme. (Mil gracias de paso). Dos chicas más serian mis compañeras de viaje. Andrea Torres y Diana Rodríguez. Yo sabía que Andrea Torres si tiene trascendencia en esto del software libre. Anteriormente la había "conocido" en una charla sobre SSH. Algo básica pero interesante.
Desgraciadamente de las otras dos muchachas no tenía ni idea.

En un principio ir tan largo con completas desconocidas me aterraba completamente. Incluso la noche anterior, necesite tomarme un te de tilo bien cargado para poder conciliar el sueño. Era algo completamente loco, no sabía que esperar, no tenía amistad con ninguna de ellas. Lo único que tenía era un conjunto de referencias, un par de fotos y actividades en las que habían participado donde la la documentación seguía siendo disponible por medio del Internet.

El día de la actividad me desperté alrededor de las 5:15am. No quería llegar tarde. Me levante inspirado en preparar todo lo que necesitaba llegar. Cuando mi equipo estaba listo para el viaje, solicite un taxi. Me permitió llegar a la Universidad nacional alrededor de las 6:40am. Tenia suficiente tiempo para esperar con las chicas que viajaría. Ya me pito Jennifer a la distancia. Donde ya pude reconocer a Andrea Torres (Una cara no la olvido nunca). Me dirigí donde ellas, salude, acomode mi equipo y me senté un poco nervioso en el asiento de atrás. Empezamos a hablar un poco, realmente no hable mucho. Me dio la impresión que ellas se conocían de muchos año. Hablaban de actividades, recuentros de la U, actividades de la red, que hacer en sus oficinas. No se tornaron muy interesadas en mi la verdad. Sin embargo el estar callado escuchando con interesantes me sienta muy bien. Desṕues de un viaje relativamente corto. Llegamos al campus de la UNA de sarapiqui.

Llegando a la UNA fue la primera vez que vi a Gabriela Mejias. La que fue mi contacto directo para llevar acabo la actividad en la Cede. La Universidad de Sarapiqui es muy chiva, tiene paisajes boscosos en sus alrededores. El lugar es como ver Bijagua de Alajuela. Un lugar "Rural" muy agradable, pero nada como mi caliente Guanacaste. (:P). Ya fui a desayunar con las chicas.
Poco tiempo después era hora de montar el stand de juegos. Me asignaron a Diego. Un estudiante de informática que seria mi mano derecha. Tengo que admitir que el Stand fue todo un éxito. Los asistentes se tornaron muy interesados. Entre los juegos que logre que jugaran estuvo; Openarena, Gltron, Super Tux, Super Tux Car y World. Los involucrados llegaban, reían, se divertían, hablaban un poco conmigo, copiaban los juegos y comentaban. Para mi lo mas sobresaliente fue una chiquita de alredor de unos 7 - 8 años que se acerco. Adrea Torres le cedió el control (Joystick). La niña gozaba con Super Tux. Realmente fue muy chistoso verlo. De repente el padre se acerco y me pregunto sobre que tan difícil era configurar un joystick y hablamos un poco al respecto.

Después de todo el "despelote" que fue el estante de juegos libres. Me toco la charla de programación. La charla era muy pesada, pero se llevo acabo en el tiempo proviso (1 hora). A todos les dije que los ejemplos que viéramos se los podía copiar una vez finalizada la charla. Los temas que logre abarcar fueron; Librerías, Binarios, g++, Gui, java y php. Fue algo muy relámpago, pero dejaba la idea de como empezar a programar. Lo que mas me dolió fue que pase semanas preparando los ejemplos con comentarios, notas y todo lo necesario. Al final solo uno de todos los 17 asistentes me pidió el correo. OJALA que me solicite el material. (:s)

Aquí les dejo el material por si quieren ver mi trabajo.

Por ultimo, después de las fotos, los besos y los abrazos. Me despedí de la cede de Sarapiqui y su gente. Muy agradecido por que todos fueron tan amables. Con una sensación de satisfacción. Diciendo UNA "Gracias por todo lo que me diste". Espero haberte retribuido un poquito el día de hoy.

Nos emprendimos en nuestro viaje de vuelta. Un poco incomodo por reparaciones en la carretera y la neblina. Cuando al fin llegamos a Heredia. Pasamos a comer a un restaurante, donde tuve la oportunidad de compartir una ultima vez con las chicas. Mis ultimas palabras de esta entraba se las quiero dedicar a ellas. Infinitamente agradecido; por acogerme en el viaje, su amabilidad mostrada, su tiempo y sus buenas intenciones. Considerado como un desconocido lograron hacerme sentir muy cómodo. Se que es esta vida nada sucede como deseábamos, como suponíamos, ni como teníamos previsto. Pero me siento muy afortunado en haberlas conocido hoy. Todas ustedes tienen mis respetos, besos y abrazos. Espero volver a vernos pronto...

viernes, 16 de septiembre de 2011

Teclados mecanicos y yo!!!

Hoy ha llegado el ultimo de mis teclados mecánicos. Que emoción :P.  Elegí uno que realmente fuera silencioso para la oficina. Pues ya había comprado uno para la casa. Estos teclados tiene la fama de que son para toda la vida. Para ser honesto eso espero. He invertido alrededor de unos $100 por teclado. Para la casa, en vista de que estoy a la espera de diablo 3 y jugando Starctraft elegí el Black Widow de Razor. Este teclado viene equipado con los Cherry Mx Blue. Son bastante ruidosos. Pero son excelentes para teclear. Vienen con 5 MacroKeys además de iluminación por tecla. Pesa 3 Kilos con todo y caja. Hasta el momento estoy sin quejas, para jugar son excelentes y en mi caso para escribir código son estupendos.
En la oficina si presento un reto interesante. El 70% de mi tiempo estoy en el trabajo, sin embargo necesitaba algo que fuera silencio y que a la vez tuviera la delicadeza de un teclado mecánico. Quiero dejar por sentado el hecho que a mi me preocupa la ergonomia. Yo escribo mucho. Después de cierto tiempo escribiendo me empiezan a dolor las manos. Por eso la idea de comprar teclado mecánicos fue la solución a mis problemas. Al final me decide (supervisado con un amigo) por un Filco Majestouch 2. Estos vienen con Cherry Mx Brown. Se siente un poco extraño al teclado que tengo en casa. Pero es muy cómodo, además adquirí un gel de goma para descansar la mano. Hasta el momento no tengo quejas tampoco. No hace mucho ruido y podría pasar como un teclado común y corriente. No tiene iluminación, no tiene macros. Pero su valor esta a la hora de escribir. QUE MARAVILLA...

Ya había tenido la experiencia de un teclado mecánico anteriormente. El amigo que me ayudo a elegir el teclado es tan adicto como yo a Star Craft II. El fue el primero en comprar el teclado mecánico ya que son súper famosos entre los jugadores profesionales de Star Craft II. Hace cierto tiempo atrás lo llevo a una reunión de amigos y me permitió usarlo para un mach. Enamorado a primer touch... (Cuantas veces han escuchado decir eso???)

Tal vez sea cierto que los teclado mecánicos con muy caros, también dicen que no valen su precio. Pero hasta el momento no tengo ningún problema con ellos. Yo programo mucho y me encanta escribir en el blog. Para mis fines son excelentes. Los teclados de goma convencionales tienden a gastarse, a cansar los dedos y después de un tiempo pueden producir graves problemas en la salud. No puedo hablar mucho porque llevo un par de días con estos teclado, pero a mi criterio me llevare bien con ellos hasta que expiren su vida útil y parece que moriría escribiendo antes que eso pase.

domingo, 11 de septiembre de 2011

Kubuntu, Php y Mysql

Me imagino que a muchos les ha pasado el siguente error:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld

Y de verdad que da mucha colera :P. Y si usamos sudo la cosa se pone peor. Lo que da mas chicha es que este error es muy típico para KDE.
Para ponerlos en contexto resulta que mysql ya viene por defecto en KDE. Lo usa el programita Akonadi. La verdad no voy a hablar mucho sobre el. Simplemente queria aclararlo. Entonces el peor error en KDE si quieres mysql para programar es teclear:

sudo apt-get install mysql

Porque entonces la cosa se enreda mas y el resultado sera dos mysql instalados y ninguno operacional. Entonces por favor NO LO HAGAS.

Lo que puedes hacer es usar la instancia que ya existe de Mysql que Akonadi necesita. Resulta que ya existe un socket por defecto. Es este amigo de aca.

/home/<USER>/.local/share/akonadi/socket-sabrina/mysql.socket


Entonces vamos a levantar el servicio de mysql con el siguente comando.

mysql --socket=/home/koza/.local/share/akonadi/socket-sabrina/mysql.socket

Nota: Recuerden dejar la terminal abierta, si la cierran despues de unos minutos el servicio bajara.

Ahora bien. Podemos hacer un script pequeñito para realizar la prueba.

//No se necesita poner la extencion .socket is se pone los (:) al inicio del path
$link = mysql_connect(':home/koza/.local/share/akonadi/socket-sabrina/mysql', 'koza', '');
if (!$link) {
    die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($link);


Con eso debería bastar. 

Pero por si los fallos, acá esta un par de tips que se pueden usar:

Asegúrese de que Akonadi este funcionando. Puede usar el el programa "Configuracion de Akonadi". Y en la pestana de "Configuracion del servidor" bajar el servicio y volverlo a subir.

Si es un caso en el que da problemas de permitos. Lo que se puede hacer ir al archivo Httpd.conf del Apache y modificar la linea:

User nobody por User <USER>

miércoles, 15 de junio de 2011

Entrevista a Linux Torvald

Para mi Linus Torvalds ( El creador de kernel de Linux) es una persona de admirar, todo un Héroe para muchos y Némesis para otros. A mi me gusta mucho la forma de expresión de este tipo, porque en ocasiones es todo un filosofo y en otras es un verdadero animal. :P

Hoy estaba leyendo una entrevista que realizaron con el. Pueden verla aquí.

En esta entrada me gustaría comentar un poco sobre dicha entrevista, sobre todo las cosas que más me han llamado la atención.

Si Linus empezó Linux como un Hobbie, no me puedo imaginar que clase de tipo puede ser. Pero es curioso como el destino mueve los hilos. El nunca pensó que Linux llegara tan largo, ahora es increíble pero hay cientos de usos para Linux.  El mas común y menos conocido... El famoso Android. Pocos saben que Android es Linux pero es súper utilizado por Tabletas y Teléfonos.


Tampoco logro imaginarme la sensación de Torvalds de saber que Linux ha sido tan difundido, deber ser algo totalmente impresionante. Parece como si fuera el dios del Linux (Vivo). El saber que hay miles de miles de personas alrededor del mundo que aportan horas de trabajo en sus días para mejorar el Kernel, y que eres parte de este hecho histórico, sería para mi suficiente motivación para seguir. Linuz es una leyenda que nunca morirá, ha hecho historia, si Linux dejara de existir y otro nuevo sistema naciera, no debería de hacerlo desde cero. Podría usar a Linux como base.

No se que tan cierto será, pero me da la impresión de que Linuz cree cada palabra que dice y predica o al menos eso parece. Hace un buen tiempo atrás lo vi en una entrevista donde el entrevistador le preguntaba sobre cuando dinero hubiera ganada si hubiera decido comercializar Linux. El se hecho una sonrisa y dijo "A cada quien que se ha involucrado con Linux le ha tocado su parte". Esto es muy cierto, los programadores y personas que usan Linux de forma empresarial han hecho millones. Los propietarios de los servidores han ahorrado dinero con Linux en actualizaciones, rendimiento y licencias. Los usuarios convencionales como usted y yo, tenemos un sistema operativo completamente funcional gratis, sin muchos problemas. La idea es que cualquier que use Linux simplemente "Le toca su parte". No se si Linus miente, al menos cree su propia mentira. (Pienso yo)

Quiero abrir un paréntesis para aclarar un par de cosas a personar que no tiene nada que ver con programación. Creo que hay una opinión común entre los profesionales en informática sobre cual es el problema más grande al que se pueden enfrentar. Irónicamente no es nada técnico, el principal reto es la comunicación con el cliente o persona involucrada directamente con el proyecto. Se le suele llamar Placeholder. Curiosamente este mismo problema lo tiene Linus mejorando el Kernel de Linux. Las comunidades de Linux se han vuelto enormes y el gran desafío es tener un norte común. Ese procesos de organización, comunicación y coordinación es lo que el dice "es lo mas complicado grande reto al que Linux se enfrenta".


Linus habla de Linux como un todo. La gente es muy purista en Llamarlo GNU/Linux pero a Torvalds poco le importa siempre que lo uses. Como el dice, Linux no fue un proyecto de la Free Software Fundation (FSF). Aunque Linux hacen mucha sinergia con los proyectos que de han nacido de este ultimo. Linux como tal es un Núcleo, que poco hace sin los programas de la FSF. Como Linus dice "La mayoría de las distribuciones le dan al sistema su propio nombre: Fedora, SuSE, Ubuntu, Android, Mandriva, la lista sigue. Así que si la FSF quiere llamarlo GNU/Linux, ¿por qué debería preocuparme? No".

Yo admiro a Free Software Fundation pero tiene un mentalidad he ideologiza muy complicada. La verdad no la entiendo bien y prefiero no tocar el tema. Si quieres un sistema completamente libre, ese es tu problema. A mi me encantan las cosas funcionales  a las que no tengo que gastarles mucho rato. Por ese Ubuntu es un amor, máxime que tiene millones de blog dedicados a hacer turoriales y postiar problemas. Ubuntu usa código no libre para algunas tareas. Ese es el principal pleito de Free Software Fundation. TODO DEBE SER LIBRE. La idea es buena lo curioso que hay gente que no libera el código de su proyectos ni a palos. Este es el caso de Nvidia y sus controladores gráficos. Hace ya rato que Nvidia le da soporte a Linux, pero de forma cerrada. Dice Torvalds que no entiende este tipo de actitudes. No sabe si lo hacen porque les da vergüenza liberar el código que este lleno de errores o simplemente es una estrategia comercial.

Deje de ultimo el tema de las ideologías. Porque realmente es algo muy interesante. Linus cree que Linux no tiene una única ideología. Esto quiere decir que Linux puede ser adaptado a cualquier filosofía y la gente la adopta a sus razones he intereses. Mi filosofía es "Estoy feliz con Linux (Ubuntu) porque no tengo virus, la compu no se me traba, la mayoría es gratis y hago todo lo que quiero hacer sin problemas". Para otros la ideología es "Es bueno para mi negocio". Para otros es "Soy un rebelde sin causa y me cae mal Windows". Irrelevante de la filosofía que se use del porque usar Linux, La única ideología que a Linus lo enferma es la que excluye a otras. "Mi ideología es la definitiva y correcta". Creo que por ahí Linus y Richard Stallman el hombre grande del movimiento open source, tienen tantas asperezas. Muchos lo critican. Yo simplemente lo admiro, muere con sus ideas y se hunde con ellas si es necesario. Si me gustaría que entre Torvalds y Stallman hubiera una hermandad. Que dejaran de cortarse las cabezas y que dejaran de hacer el teatro de política. Dejaran de usar palabras eléctricas cuando se refieren el uno al otro.

sábado, 4 de junio de 2011

Domingo en la oficina :s

Después de que todas las siete plagas de Egipto fueron depositadas en mi haber. El viernes anterior ha este domingo estaba en uno de "Esos" días. Esperando la hora de salida, mi mirada no se apartaba de la parte inferior derecha de la pantalla de mi monitor donde el reloj avanzaba muy lentamente. Mi único anhelo y esperanza de aquel día era irme a mi casa a realizar los planes que deseaba, jugar Star Craft, dormir, Ps3, no sé cualquier cosa que me alejara de esta profunda tristeza que la oficina influía sobre mi y me mostraba sus deseos de mortificarme con forme las horas transcurrían. Iluso de mi... Había realizado equivocadamente muchas tareas este viernes, Se puede decir que todo me salio bastante mal. Y ahí estaba dos horas después de la hora de salida, con todos mi compañeros observándome con cara de odio, nefastos, destrucción, delirio. Pensando en lo inútil que era este "Mae". Que por su culpa estaban ahí "Clavados". Todo ellos ajenos a lo que me pasaba, ajenos a lo que sentía, ajenos a mis agobio. Creo que absolutamente nadie le interesaba.
Que podía pensar, como mantener una cabeza fría en tal situación. Como estar tranquilo cuando una docena de miradas apuntaban a mi cabeza, quemantes, indignados. Difícil es cuando donde lo que se cree bien, estaba MAL y más que mal pésimo, Lo que se cree como realidad era completamente incierto para mí, Lo que deseaba se me era completamente arrebatado por culpa de aquella laboral amarga la cual deseaba dejar.
Porque tanto? (Trabajo ) me preguntaba mi madre a través de una llamada telefónica. Después de contarle, como es costumbre palabras sabias nacían una vez más de su boca. "De humanos es equivocarse, si se puede arreglarlo, terminalo y ya esta". Eso era lo que necesitaba, unas palabras indiferentes de cualquier pensamiento; de quien había sido la culpa, de como se podía arreglar, de que se podría hacer. Cuantas veces hacemos ver un problema lejano, imposible, enredado, adverso y es algo tan sencillo de resolver. Todo tiene que ver con el momento justo. "It's all about timingLinux odisey Comercial. (Palabras sabías que me encantan escuchar).
Y allí estaba en la oficina ese domingo, con miles de cosas por hacer, con un un bloc de notas, con dos litros de jugo de naranja, dos paquetes de chicharritos verdes y una paz impresionante resultado de haber visto a mi madre el sábado y la calma de estar solo en la oficina. Empecé mi labor temprano en la tarde y motivado por alguna fuerza extraña que no lograba comprender. Tomaba notas en mi bloc, tachaba las tareas terminadas, comentando las que eran producto de malos entendidos y comiendo chucherías. Paso el tiempo sin distracciones ignorando mis pensamientos de odio, pereza, cansancio, suicidas cuando advertí que era hora de irme pues ya había terminado absolutamente todo. Aquellas tareas ya estaban listas para pasar control de calidad el lunes en la mañana apenas el personal entraran al departamento a trabajar. Después de casi ocho horas de trabajo que sinceramente no note, entendí que "si no haces algo con voluntad y corazón, Nada puede salir bien". Todas las personas conocen este pensamiento, pero si no tienen un contexto apropiado donde aplicarlo son simples palabras. 
Buda dice "Como flores hermosas, con color, pero sin aroma, son las dulces palabras para el que no obra de acuerdo con ellas." pero como cuesta darle aroma a las flores.
Que importante es que alguien nos recuerde estas palabras, alguien que no entendía absolutamente nada de informática me había recordado y dado la respuesta más acertada para resolver mi problema "termínalo y ya esta".

viernes, 6 de mayo de 2011

Que Idioma hablamos los profesionales en informatica?


"Comitie" dijo sin la menor vergüenza ni vacilación. Mi compañero analizo la situación y sin mas reseño dijo "A que dicha". Aquel que estaba en frente observando tal escena era yo. Quien en mis adentro con sigilo y sin menor contemplación dijo "Comitie???", Que era los que esas palabras manifestaban en su sentido profundo. Cualquiera no tan técnico estaría ajeno a cualquier significado.
Que increíble que los ingenieros (Y no tan ingenieros) hablan una jerga "Techi-engli-Fluctuante".Porque?

1. "Commitie" viene de la palabra Commit (Proceso del SVN para referir a subir archivos procesados anteriormente modificados)
2. "English" viene de commit -> "Confirmar" en ingles que es lo mismo que el caso de arriba
3. Fluctuante-> Eso tiene que ver mucho en el grupo de compañeros de trabajo. No toda jerga entre grupos de informáticos es "genérica". Por ejemplo si pasa alguna cosa tonta en el trabajo, Se me ocurrió decir la palabra "Tortua" en una reunión que como se darán cuenta no era precisamente lo que quería decir. Entonces de ahí en adelante solo así me dice un grupo de compañeros.

"Backaquie" -> La real academia estaría orgullosa NO???. De la combinación de Hacer un respaldo en ingles y ponerle un gerundio. Quien necesita el francés ni el latín para expresar los sentimientos si tenemos el "Computin"

"Submitie" -> Otra palabra por la cual Pablo Neruda estará revolcándose en su tumba NO? Del ingles Submit, vendría siendo algo como envió. Proceso por los cuales los formularios HTML puro trabajan.

 Mae, "atachele" el PDF. Que no se le olvide... Nunca voy a olvidar ese día. Estaba a punto de matar a alguien... Una persona bastante desgraciada, detestable y ajena a mi fatiga menciono alrededor de la media noche. En esas famosas palmadas en la oficina.

(P)edaso (D)e (F)raude era lo que en mi cabeza retumbaba. Historia aparte para otra entrada. Pero ilustra un muy buen ejemplo de esta jerga informática.

"Atachele" -> Del ingles Attach (Adjuntar), del Técnico ( Adjuntar un archivo digital ), Fluctuante (No todos los dicen así).

Curioso NO?
Bueno la segunda parte de esta entrada, se la voy a dedicar a aquellas jerga "Asumida".
Piense en un minuto es la siguiente frase:

"Ayer me toco raspar la maquina". Que cansado suena eso no. La lija, el cincel y el aguarrás para dejarla bien "cachete". Lejos esta de raspar, que frase mas mal hecha. Es voltear un disco duro a 0 en todos los registros osea "Formatear". Nota: Si es un Formato Completo.

"Porque no me chaparrea este disco". Una forma vulgar y pueblerina de pedirle a alguien una copia de un disco X. Recuerden: Piratear es un delito :P.

Creo que ignorantes somos todos, hablamos mal el español y lo poquito que nos hace ser personajes serios he importantes en la sociedad lo hemos convertido en chistes en potencia. No digo que no se use la jerga popular. Para nada, yo creo que soy el primero que merece la piedra en la frente si dijéramos "el que este libre de pecado que tire la primera piedra". Solo digo que por lo menos deberíamos saber el nombre correcto de las cosas, para que en un momento de importancia no decir, la "Llegueda" frente a gente importante. Jefes, Clientes, Evaluadores, Entrevistadores y por que no alumnos.

martes, 3 de mayo de 2011

Mas Azul y menos Naranja

Quien no ha usado Ubuntu Linux. Con el poderoso Escritorio Gnome. Como odio esos botones tamaño elefante y su naranja horrendo. Puta, me llevo mal con Gnome hace ya unos años. Y como es Software libre, lo que no te sirve o no te gusta que no estorbe. Entonces pase a KDE. Dios mio al principio fue duro como todo cambio. Pero me he acostumbrado tanto a usarlo que no podría abandonarlo.
Mi viaje por los escritorios fue amplio. Al inicio use Gnome (Hermosa hasta que conoces KDE), probé XFCE que es el que tiene el segundo lugar en mi corazón, probé E17 y no tengo quejas, probé fluxbox, entre otros escritorios.
Pero solo hay un problema en el mundo del GTK (librería de Gnome) . Que si corres un programa GTK en KDE notaras que se ve todavía mas horrendo que en el propio GNOME. Y por mas que le hagas que le reduzcan fuentes, cambies estilo de todo. Sera siempre una Cochinada.
Gracias a dios y después de mucho tiempo. (Créame que lo he intentado durante buen tiempo). Ya hay una forma de ver Gtk como Qt(La librería base de KDE).
Como:
Primero vayan aquí:
http://code.google.com/p/gtk-qt-engine/downloads/list
Y descarguen el archivo gtk-qt-engine-1.1.tar.bz2
Antes que se rompan el calabazo viendo como lo compilan le doy los requerimientos.
Necesitamos:

CMake 2.4
Qt 4.3 developement package
GTK developement package
GCC
Bonobo



Claro si buscan con el synactic encontraran que cada una de las librerías de arriba necesita un montón de cosas. Pero la vida es fácil con synactic. Todo es automático.
Descomprimen el archivo en cualquier ubicación.
Acceden a ellas con terminal (Konsole)
y dan los siguientes comandos.

cmake .   
 make  
 sudo make install   

Ahora si en Preferencias → Gtk Style → Encontraran una opción de usar style QT. Y magia magia.
Reinician la Pc y por fin las aplicaciones en GTK corriendo en KDE se verán hermosas (Como si hubieran sido escritas en QT).
NOTA:
Esto solo aplica para usuarios de KDE. No me puedo imaginar las consecuencias desastrosas que puede traerle al escritorio GNOME.

Actualización 
Con las nuevas versiones de Kubuntu (11.04) ya trae este paquete por defecto. Entonces no es necesario hacer mayor cosa.

AEM hablemos del arquetipo 11

Cuando creamos un proyecto con AEM. Siempre es importante saber que arquetipo estamos usando. Pues esto me determinara que source, herramien...