[] (https://scrutinizer-ci.com/g/xsanisty/SilexStarter/build-status/develop) [] (https://scrutinizer-ci.com/g/xsanisty/SilexStarter/?branch=develop) [ ] (https://scrutinizer-ci.com/g/xsanisty/SilexStarter/?branch=develop) [] (https://insight.sensiolabs.com/projects/a30a66f9-8110-40c5-8a35-f3c1697dde55)
SilexStarter é um aplicativo inicial construído no topo da estrutura Silex, Eloquent do Laravel, Cartalyst Sentry e alguns outros componentes integrados de terceiros. SilexStarter tem como objetivo ajudar a construir aplicativos simples com mais rapidez, é construído com MVC e abordagem modular em mente e vem com alguns módulos de administração básicos, incluindo gerenciador de usuários e gerenciador de módulos.
Por enquanto, o branch instalável é apenas o branch de desenvolvimento, você pode instalá-lo facilmente usando o compositor usando o seguinte comando
composer create-project xsanisty/silexstarter target_dir dev-develop -s dev
assim que a instalação do compositor for concluída, você pode inicializar o aplicativo usando o seguinte comando
$cd target_dir
$./xpress app:init
O módulo pode ser desenvolvido diretamente dentro do diretório app/modules
e criar o módulo em seu próprio namespace ou construí-lo como um pacote compositor separado, o módulo pode ser ativado ou desativado registrando-o em app/config/modules.php
file : app/routes.php
A configuração da rota pode ser criada como a rota normal do Silex ou usando o construtor de rotas usando sintaxe semelhante à rota do Laravel.
Estilo de roteamento Silex
/* the application instance is available as $app in context of route.php */
$ app -> get ( ' /page ' , function (){
return ' I am in a page ' ;
});
$ app -> post ( ' /save ' , function (){
return ' Ok, all data is saved! ' ;
});
/* grouping */
$ app -> group ( ' prefix ' , function () use ( $ app ) {
$ app -> group ( ' page ' , function () use ( $ app ) {
$ app -> get ( ' index ' , function (){
return ' I am in prefix/page/index ' ;
});
});
});
/* resourceful controller */
$ app -> resource ( ' prefix ' , ' SomeController ' );
/* route controller */
$ app -> controller ( ' prefix ' , ' SomeController ' );
Estilo de roteamento Laravel
/* route can be built using the Route static proxy */
Route:: get ( ' /page ' , function (){
return ' I am in a page ' ;
});
Route:: post ( ' /save ' , function (){
return ' Ok, all data is saved! ' ;
});
/* grouping */
Route:: group ( ' prefix ' , function () {
Route:: group ( ' page ' , function () {
Route:: get ( ' index ' , function (){
return ' I am in prefix/page/index ' ;
});
});
});
/* resourceful controller */
Route:: resource ( ' prefix ' , ' SomeController ' );
/* route controller */
Route:: controller ( ' prefix ' , ' SomeController ' );
file: app/controllers/*
Controlador basicamente pode ser qualquer classe que resida na pasta controladores, será registrado como serviço quando habilitado e será instanciado adequadamente quando necessário, com todas as dependências injetadas.
Suponha que tenhamos PostRepository
e CommentRepository
, devemos registrá-lo primeiro antes que possa ser injetado corretamente no controlador.
file: app/services/RepositoryServiceProvider.php
<?php
use Silex Application ;
use Silex ServiceProviderInterface ;
class RepositoryServiceProvider implements ServiceProviderInterface
{
public function register( Application $ app )
{
$ app [ ' PostRepository ' ] = $ app ->share( function ( Application $ app ) {
return new PostRepository
});
$ app [ ' CommentRepository ' ] = $ app ->share( function ( Application $ app ) {
return new PostRepository
});
}
public function boot ( Application $ app )
{
}
}
file: app/config/services.php
<?php
return [
' common ' => [
' RepositoryServiceProvider ' ,
]
]
file: app/controllers/PostController.php
<?php
class PostController{
protected $ postRepo ;
protected $ commentRepo ;
public function __construct ( PostRepository $ postRepo , CommentRepository $ commentRepo )
{
$ this -> postRepo = $ postRepo ;
$ this -> commentRepo = $ commentRepo ;
}
public function index (){
return Response:: view ( ' post/index ' , $ this -> postRepo -> all ());
}
}
e agora, devemos ser capazes de criar um mapa de rotas para este controlador
Route:: get ( ' /post ' , ' PostController:index ' );
file: app/models/*
SilexStarter usa Eloquent ORM como camada de abstração de banco de dados, para que você possa estendê-lo para criar o modelo classJeyac. A configuração do banco de dados pode ser encontrada em app/config/database.php
<?php
class Post extends Model{
protected $ table = ' posts ' ;
public function comments (){
return $ this -> hasMany ( ' Comment ' );
}
}
file: app/views/*
file: app/middlewares.php
file: src/Providers/*
file: app/modules/*
file: app/config/modules.php
file: app/modules/**/ModuleProvider.php