Laravel trabaja con clases que generalmente se guardan en repositorios desde el cual son llamadas. Esta estructura requiere que ademas de conocer la organización del framework, comprendamos su enfoque para crear y almacenar las clases.
Puede parecer para muchos complicado, pero es una estructura que desde mi punto de vista esta enfocada a componentes como parte de un todo, de ahi la necesidad de entenderla adecuadamente
Crear una clase
Las clases en Laravel se crean dentro de la carpeta App, usando psr-4. Basta con crear un archivo en una dirección dentro de App y comenzaremos a tener una clase reconocida, por la aplicación:
Creamos el archivo Conexión dentro de una carpeta nueva llamada Personalizado
App/Personalizado/Conexión.php
Y luego colocamos la clase con sus métodos y/o atributos. En nuestro caso estamos creando una clase que sustituirá los valores de conexión a la bd en el archivo env.
class Conexion { public function conectar() { return 'conecto'; } }
Una vez creado, la clase principal que se encuentra ubicada en “App\Personalizado\Conexion\conexion.php”, tendrá como namespace y que es el que podrá ser usado desde cualquier lugar de la aplicación, o sea hacer bind, este:
App\Personalizado\conexion
Para que el bind funcione, son necesarios unos pasos más. Lo siguiente que haremos será crear el Service Provider de la clase.
Lo haremos con Artisan desde la consola:
php artisan make:provider ConexionServiceProvider
Lo que sigue es registrar la clase en el método register() del ConexionServiceProvider, haciendo el adecuado bind.
public function register() { //registramos la clase \App::bind('Conexion'); }
Y finalmente registramos ConexionServiceProvider en el fichero de configuración, que se encuentra en la ruta config/app.php, agregando la clase, dentro del array de providers:
/* * Application Service Providers... */ App\Providers\AppServiceProvider::class, App\Providers\AuthServiceProvider::class, ………… /* * Clases Propias añadidas... */ App\Providers\ConexionServiceProvider::class,
Nos faltaría comprobar que nuestra clase es accesible, podemos hacer diferentes pruebas, como llamar la clase desde una ruta o correr una prueba con Tinker.
Comencemos con Tinker, llamándolo desde la consola:
>>>php artisan tinker
Una vez abierto, llamamos la clase, y la corremos :
Psy Shell v0.9.12 (PHP 7.2.3 — cli) by Justin Hileman >>> use App\Personalizado\Conexion;
La instanciamos :
>>> $h =new Conexion(); => App\Personalizado\Conexion {#3106}
Y llamamos la funcion:
>>> $h->conectar(); => "conecto" >>>
Salimos de Tinker, con control +C.
Tambien podemos probarlo en el sistema de rutas de Laravel.
Route::get('conectando', function(){ if(class_exists('App\Personalizado\Conexion')) dd('hallada'); else dd(' no hallada'); } );
Si accedemos ahora a la ruta conectando deberíamos ver escrita la palabra hallada.
Ahora, nuestra clase esta lista y disponible para ser usada.
Y listo, esto es todo.
Espero modestamente que este artículo, sirva de ayuda a alguien.
Gracias.
…., si avanzo sígueme, si me detengo empújame, si retrocedo mátame…….