📦 Bow Package
Introduction
Ce système permet d'étendre votre application, de gréffer des packages externe dans votre application Bow Framework.
Création de plugin
Si vous avez une application Bow, il vous suffit de faire la création via php bow
et lancer la commande add:configuration
ensuite, vous donnez le nom de votre configuration:
php bow add:configuration PluginConfiguration
Le fichier PluginConfiguration.php
sera créé dans le dossier app/Configuration
qui contient deux méthode create
et run
.
create
permet d'initialiser le packagerun
permet de lancer d'initialisation le package.
Dans l'initialisation des packages c'est la methode create qui ce lancera avant pour tous le autre packages qui seront defini au dessus dans votre configuration ensuite la methode run sera sera dans le meme orde.
N'Essayez pas de contacter un package ici si vous attendez qu'il soit d'abord configurer.
Dans le fichier de configuration, Bow va injecter le DIC et sera accéssible via la propriété $this->container
. Plus d'information sur le DIC de Bow.
Exemple de création
Nous allons faire un plugin aui va vérifier un email, alors on crée la configuration avec le nom EmailCheckerConfiguration
:
Notez que c'est un exemple pour vous montrer comment vous y prendre, cet exemple dans un vrai projet aurait pu être traité autrement.
php bow add:configuration EmailCheckerConfiguration
Dans le dossier app
nous allons ajouter un dossier Packages
dans ce dossier, nous allons encore ajouter le fichier EmailCheckController.php
:
namespace App\Packages;
use Bow\Http\Request;
use Bow\Support\Str;
class EmailCheckController
{
/**
* Check the email
*
* @param Request $request
* @return mixed
*/
public function __invoke(Request $request)
{
$email = $request->get('email');
if (Str::isMail($email)) {
$response = [
'message' => 'Ok',
'error' => false
];
} else {
$response = [
'message' => 'C\'est un mauvais email !',
'error' => true
];
}
return $response;
}
}
Nous allons maintenant créer note configuration :
namespace App\Configurations;
use Bow\Configuration\Loader;
use Bow\Configuration\Configuration;
class EmailCheckController extends Configuration
{
/**
* Permet de lancement de configuration
*
* @return void
*/
public function run()
{
$this->container->make('app')->post(
'/email/checker', \App\Packages\EmailCheckController::class
);
}
}
Allons tester notre application Bow Framework avec la commande php bow run:server
pour lancer le serveur de développement.
Testons notre package
Pour cet exemple, nous allons tester votre code avec curl
:
curl -X POST -d "email=exemple@exemple.com" http://localhost:5000/email/checker
# {"message": "Ok", "error": false}
Il manque quelque chose ?
Si vous rencontrez des problèmes avec la documentation ou si vous avez des suggestions pour améliorer la documentation ou le projet en général, veuillez déposer une issue pour nous, ou envoyer un tweet mentionnant le compte Twitter @bowframework ou sur directement sur le github.