baremetalphp / framework
A lightweight, educational PHP framework with service container, routing, ORM, and more
Installs: 4
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/baremetalphp/framework
Requires
- php: >=8.2
Requires (Dev)
- phpunit/phpunit: ^12.5
This package is auto-updated.
Last update: 2025-12-06 21:21:26 UTC
README
A lightweight, educational PHP framework with service container, routing, ORM, migrations, and more.
Features
- ๐ฏ Service Container - Dependency injection and service management
- ๐ฃ๏ธ Routing - Clean, simple routing with middleware support
- ๐๏ธ ORM - Active Record style ORM with relationships (hasOne, hasMany, belongsTo, belongsToMany)
- ๐ Migrations - Database version control and schema management
- ๐จ Views - Simple templating engine with blade-like syntax
- ๐ Authentication - Built-in authentication helpers
- ๐งช Testing - PHPUnit test suite included
- โก CLI Tools - Built-in console commands for common tasks
Requirements
- PHP 8.0+
- PDO extension
- SQLite, MySQL, or PostgreSQL support
Installation
Install via Composer:
composer require elliotanderson/phpframework
Quick Start
Creating a New Project
The easiest way to get started is to use the project skeleton:
composer create-project elliotanderson/baremetal my-app
Manual Setup
- Require the framework:
composer require elliotanderson/phpframework
- Set up your application structure:
my-app/
โโโ app/
โ โโโ Http/
โ โ โโโ Controllers/
โ โโโ Models/
โโโ bootstrap/
โ โโโ app.php
โโโ config/
โ โโโ database.php
โโโ public/
โ โโโ index.php
โโโ routes/
โ โโโ web.php
โโโ composer.json
- Create a route (
routes/web.php):
use BareMetalPHP\Routing\Router; use BareMetalPHP\Http\Response; return function (Router $router): void { $router->get('/', function () { return new Response('Hello, World!'); }); };
- Bootstrap your application (
bootstrap/app.php):
<?php require __DIR__ . '/../vendor/autoload.php'; use BareMetalPHP\Application; $app = new Application(__DIR__ . '/..'); $app->registerProviders([ BareMetalPHP\Providers\ConfigServiceProvider::class, BareMetalPHP\Providers\DatabaseServiceProvider::class, BareMetalPHP\Providers\RoutingServiceProvider::class, BareMetalPHP\Providers\ViewServiceProvider::class, ]); return $app;
- Create your entry point (
public/index.php):
<?php $app = require __DIR__ . '/../bootstrap/app.php'; $app->run();
Usage Examples
Routing
$router->get('/users', [UserController::class, 'index']); $router->post('/users', [UserController::class, 'store']); $router->get('/users/{id}', [UserController::class, 'show']);
Models
use BareMetalPHP\Database\Model; class User extends Model { protected $table = 'users'; // Relationships public function posts() { return $this->hasMany(Post::class); } } // Usage $user = User::find(1); $posts = $user->posts;
Database Migrations
use BareMetalPHP\Database\Migration; class CreateUsersTable extends Migration { public function up($connection) { $this->createTable($connection, 'users', function ($table) { $table->id(); $table->string('name'); $table->string('email')->unique(); $table->timestamps(); }); } public function down($connection) { $this->dropTable($connection, 'users'); } }
Views
use BareMetalPHP\View\View; return View::make('welcome', [ 'name' => 'World' ]);
CLI Commands
The framework includes a CLI tool (mini) with several commands:
php mini serve- Start the development serverphp mini migrate- Run pending migrationsphp mini migrate:rollback- Rollback the last migrationphp mini make:controller Name- Create a new controllerphp mini make:migration name- Create a new migration
Testing
composer test # or vendor/bin/phpunit
Documentation
For detailed documentation, visit the framework documentation.
License
MIT License - see LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.