Siler is a set of general purpose high-level abstractions aiming an API for declarative programming in PHP.
- 💧 Files and functions as first-class citizens
- 🔋 Zero dependency, everything is on top of PHP built-in functions
- ⚡ Blazing fast, no additional overhead - benchmark
$ composer require leocavalcante/siler dev-master
That is it. Actually, Siler is a library, not a framework (maybe a micro-framework), the overall program flow of control is dictated by you. So, no hidden configs or predefined directory structures.
$ composer create-project siler/project hello-siler
It's a minimal project template, just with Siler and a convenient serve
script:
$ cd hello-siler/
$ composer serve
use Siler\Functional as λ;
use Siler\Route;
Route\get('/', λ\puts('Hello World'));
Nothing more, nothing less. You don't need even tell Siler to run
or something like that.
As said before, Siler aims to use PHP files and functions as first-class citizens, so no Controllers here. If you want to call something more self-container instead of a Closure, you can simply give a PHP filename then Siler will require it for you.
index.php
use Siler\Route;
Route\get('/', 'pages/home.php');
pages/home.php
echo 'Hello World';
Siler doesn't try to be a fully-featured framework - don't even aim to be a framework - instead it embraces component based architectures and offers helper functions to work with this components under PHP namespaces.
Is one of the libraries that has helpers functions making work with templates quite simple.
$ composer require twig/twig
use Siler\Functional as F;
use Siler\Route;
use Siler\Twig;
Twig\init('path/to/templates');
Route\get('/', F\puts(Twig\render('template.twig')));
Siler also brings helper functions for vlucas/phpdotenv, so you can easily acomplish twelve-factor apps.
$ composer require vlucas/phpdotenv
.env
TWIG_DEBUG=true
index.php
use Siler\Dotenv;
use Siler\Route;
use Siler\Twig;
Dotenv\init('path/to/.env');
Twig\init('path/to/templates', 'path/to/templates/cache', Dotenv\env('TWIG_DEBUG'));
Route\get('/', 'pages/home.php');
Real-time web apps using WebSockets.
$ composer require cboden/ratchet
use Siler\Ratchet;
Ratchet\connected(function ($conn) {
print("New connection\n");
});
Ratchet\inbox(function ($from, $message) {
printf("New message: %s\n", $message);
});
print("Listen on 3333\n");
Ratchet\init(3333);
A query language for your API. Thanks to webonyx/graphql-php you can build you Schema from a type definitions string and thanks to Siler you can tie them to resolvers:
$ composer require webonyx/graphql-php
schema.graphql
type Query {
message: String
}
type Mutation {
sum(a: Int, b: Int): Int
}
index.php
use Siler\Graphql;
use Siler\Http\Response;
// Enable CORS for GraphiQL
Response\header('Access-Control-Allow-Origin', '*');
Response\header('Access-Control-Allow-Headers', 'content-type');
$typeDefs = file_get_contents('path/to/schema.graphql');
$resolvers = [
'Query' => [
'message' => 'foo',
],
'Mutation' => [
'sum' => function ($root, $args) {
return $args['a'] + $args['b'];
},
],
];
Graphql\init(Graphql\schema($typeDefs, $resolvers));
But if you give a try, I'd love the get some feedback
MIT 2018