Simplificando al máximo las características de todo framework para PHP, este permite ser un punto de entrada para quienes aún no están utilizando alguno, o desean entender cada elemento que componen uno.
Haciendo uso de patrones singleton, carga de clases tipo Zend, y una implementación sencilla y propia de manejo de vistas, Sfphp, te puede ayudar a desarrollar una aplicación en un menor tiempo y organizando tus códigos de mejor manera.
Clona este repositorio, y ejecuta el script:
dominio.com/iniciar.php
Esto dejará una nueva estructura de directorios dónde comenzarás a alojar tu aplicación
App
|-Core
|-Controladores
|-|-Inicio.php
|-Modelos
|-Vistas
Etc
|-Cache
|-Config
|-|-config.xml
|-Logs
|-Sesiones
Libs
Clona el branch skeleton, con una app sencilla de ejemplo
<app>
<key>la clave generada por el script iniciar.php o que puedes obtener desde el script llave.php</key>
<name>nombre de la app</name>
<company>sincco</company>
<cache>segundos</cache>
<eemailapi>API de ElasticMail</eemailapi>
</app>
<front>
<url>http://tudominio.com/</url>
</front>
Sólo puedes tener una por default (a la que se conectan todos los modelos por defecto), pero tantas como necesites con un identificador distinto
<bases>
<default>
<host></host>
<user></user>
<password>encriptado con la llave de la app, puedes usar en script encriptar.php?s=password</password>
<dbname></dbname>
<type>firebird|mysql|sqlsrv|otro</type>
</default>
</bases>
<dev>
<log>1|0 activa el log del framework (en Etc/Logs)</log>
<showerrors>1|0 muestra los errores propios del framework en pantalla</showerrors>
<showphperrors>1|0 muestra los errores de php</showphperrors>
<querylog>1|0 activa un log de querys ejecutados</querylog>
<contact>correo de contacto para soporte</contact>
</dev>
Si la configuración lo especifica, se activa por default el cache para querys, que evita la petición excesiva a la BD. Estos archivos son vigentes durante los segundos indicados en la configuración y se depuran sobre las peticiones al sistema. Su depuración manual es eliminando los registros data_* del directorio Cache. Se incluye el script clear_cache, para eliminar toda la caché del sistema.
Dentro del directorio de Logs, se deja un archivo .sql con los querys que se ejecutan en los controladores de datos.
Cada petición se procesa seccionando la URL del siguiente modo:
dominio.com/[modulo]/controlador/accion/[(parametro1/valor1)...(parametron/valorn]
El controlador y accion por defecto son 'inicio', por lo que, al no recibirse dentro de la URL, estos son los que se ejecutarán de forma inmediata, así que deben existir dentro de tu estructura de archivos.
Los parametros se procesan de forma lineal, por lo que, si no llevan el orden correcto, no podrás encontrar el valor que necesitas.
.../fruta/manzana/color/rojo
Se traduce en el siguiente arreglo:
(['fruta'] => ['manzana']) ,
(['color'] => ['rojo'])
Mientras que, si se rompe el patrón:
.../fruta/color/rojo
se obtiene:
(['fruta'] => ['color']) ,
(['rojo'] => NULL)
Ejecutando el script error_notification.php se envia un correo a la direccion configurada con el log actual de errores.
Configuración básica para un vhost en Nginx
server {
listen 80;
listen [::]:80;
server_name sitio;
index index.php;
client_max_body_size 2M;
root /var/www/html/sitio;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
# Don't serve hidden files.
location ~ /\. {
deny all;
}
location = /favicon.ico {
log_not_found off;
}
location / {
try_files $uri /index.php?$args;
}
location ~ \.php$ {
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
#Activar CACHE PHP
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_intercept_errors on;
fastcgi_ignore_client_abort off;
fastcgi_connect_timeout 60;
fastcgi_send_timeout 90;
fastcgi_read_timeout 90;
fastcgi_buffer_size 128k;
fastcgi_buffers 4 256k;
fastcgi_busy_buffers_size 256k;
fastcgi_cache CZONE;
fastcgi_cache_valid 200 302 1h;
fastcgi_cache_valid 301 1h;
fastcgi_cache_min_uses 2;
}
#Para Framewok de PHP
if (!-e $request_filename){
rewrite ^(.+)$ /index.php?url=$1 break;
}
error_log /var/www/__logs/error error;
}
This source file is subject to the Open Software License (OSL 3.0) that is available through the world-wide-web at this URL: http://opensource.org/licenses/osl-3.0.php
Happy coding!