roolith / framework
Roolith PHP framework
Installs: 24
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 1
Open Issues: 0
Type:project
pkg:composer/roolith/framework
Requires
- php: >=8.0
- filp/whoops: ^2.18
- nesbot/carbon: 2.73.0
- roolith/cache: 1.0.2
- roolith/config: 1.0.1
- roolith/database: 1.3.0
- roolith/event: 1.0.1
- roolith/generator: 1.0.3
- roolith/router: 1.1.0
- roolith/template-engine: 1.0.4
README
Roolith PHP framework. Very minimalistic and less overhead.
Install
composer create-project roolith/framework your_app_name
Documentation
- Cache documentation
- Config documentation
- Database documentation
- Event documentation
- Generator documentation
- Router documentation
- Template-engine documentation
If you want to use this or need any help, you may reach to
me@habibhadi.comThis framework has been developed for educational purpose!
Generator
php roolith generate controller DemoController
php roolith generate model Product
php roolith generate middleware AuthMiddleware
Define route
Open app/Http/routes.php and define routes as per documentation
Error page
If there is no route defined then by default it will look for 404.php in viwes folder.
Config
All application configuration has been stored on config/config.php for more details read documentation
Constant
Application constants has been defined into /constant.php
Frontend workflow
npm install
Then
npm start
Before npm start open the gulpfile.js update browsersync options as per your need. Specially change vhost defined
local.roolith-framework.me
To add SCSS and JS use source/scss/app.scss and source/js/app.js
Use
npm run build
for production build. It will create min.css and min.js file.
Model
Model files located into app/Models
<?php namespace App\Models; class User extends Model { protected $table = 'users'; }
Controllers
Controller files located into app/Controllers
<?php namespace App\Controllers; use App\Models\User; class WelcomeController extends Controller { public function index() { $data = [ 'content' => 'Welcome to Roolith framework!', 'title' => 'Roolith Framework', ]; return $this->view('home', $data); } public function users() { return User::all(); } public function show($id) { return User::orm()->find($id); } }
Views
View files are into /views and view files are straight forward documentation
Let's keep it simple!
Print route URL inside template
<form action="<?= route('welcome.form') ?>" method="post">
Request
Request::input('page'); Request::has('page'); Request::all(); Request::only('page'); Request::only(['page', 'other_param']); Request::cookie('cookie_name'); Request::url(); Request::fullUrl(); Request::method(); Request::isMethod('POST'); Request::file('photo'); Request::file('photo')->isValid(); Request::file('photo')->upload($destination); Request::hasFile('photo');
Validator
$validator = new Validator(); $validator->check( [ 'name' => 'john', 'email' => 'me@habibhadi.com', 'company' => '', 'age' => 18, 'url' => 'something!', ], [ 'name' => Rules::set()->isRequired()->minLength(10)->isArray()->maxLength(20)->notExists(\App\Models\User::class), 'email' => Rules::set()->isEmail()->isRequired(), 'company' => Rules::set()->isRequiredIf('age:greater_than:10'), 'url' => Rules::set()->isUrl(), 'age' => Rules::set()->isNumeric(), ] ); if ($validator->success()) { // do something! }
Sanitize
Sanitize::param($_GET['param']); Sanitize::any('untrusted_string<script>alert("a")</script>'); Sanitize::email('something/@bad.com'); Sanitize::string('xss_protect');
Array methods
Example:
_::only(['name' => 'hadi', 'age' => 33], 'name'); _::only(['name' => 'hadi', 'age' => 33, 'something' => 'else'], ['name', 'something']); _::drop([1, 2, 3, 4, 5]);
List of methods -
- except
- chunk
- compact
- concat
- difference
- drop
- dropRight
- dropWhile
- filter
- remove
- findIndex
- indexOf
- join
- last
- first
- reverse
- take
- takeRight
- uniq
- find
- each
- contains
- map
- isMultidimensional
- resetKeys
- order
- orderBy
- orderByString
- random
- add
- flat
- dot
- exists
- get
- has
- pluck
- prepend
- query
- set
Localization
Get message
__('errors.required'); // This field is required
Set local
Settings::setLang('es'); Settings::getLang();
Once es lang is set it will look lang/es/message.php. So when es has been set then below code will output -
__('errors.required'); // este campo es requerido
Cookie
Set cookie
Storage::setCookie('name', 'value', Carbon::now()->addMonths());
Get cookie
Request::cookie('name');
Delete cookie
Storage::deleteCookie('name');
Session
Storage::setSession('name', 'value'); Storage::deleteSession('name');