Skip to content

sincco/sfphp2

Repository files navigation

Sfphp

Simple Framework (for) PHP

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.

Uso

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
O

Clona el branch skeleton, con una app sencilla de ejemplo

Configuracion

General de la APP

<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 end

<front>
	<url>http://tudominio.com/</url>
</front>

Bases de datos

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>

Opciones de desarrollo

<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>

Cache

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.

Query log

Dentro del directorio de Logs, se deja un archivo .sql con los querys que se ejecutan en los controladores de datos.

Peticiones

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.

Parametros get

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) 

Log de errores

Ejecutando el script error_notification.php se envia un correo a la direccion configurada con el log actual de errores.

Nginx

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;
}

NOTICE OF LICENSE

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!

About

Framework de desarrollo en PHP

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published