jonytonet / ptah
Ptah — Laravel scaffolding generator. CRUD, DTOs, Repositories, Services, Livewire 4, Tailwind v4.
Requires
- php: ^8.2
- barryvdh/laravel-dompdf: ^3.0
- laravel/framework: ^11.0|^12.0
- livewire/livewire: ^4.0
- maatwebsite/excel: ^3.1
Requires (Dev)
- orchestra/testbench: ^9.0|^10.0
- phpunit/phpunit: ^11.0
Suggests
- bacon/bacon-qr-code: Required for generating QR codes in TOTP setup — auth module
- pragmarx/google2fa-laravel: Required for 2FA via authenticator app (TOTP) — auth module
This package is auto-updated.
Last update: 2026-03-09 17:19:38 UTC
README
Enterprise Structure. Startup Speed.
Build a small or medium system from zero to production in minutes.
With AI, even faster — and spending far fewer tokens.
What is Ptah?
Ptah is a Laravel package that combines SOLID scaffolding, ready-made visual components and a dynamic CRUD system in a single installation. With one command you generate the entire structure of an entity — model, migration, DTO, repository, service, controller, requests, resource, Livewire view and routes — ready to use from the very first php artisan serve.
| Pillar | What it delivers |
|---|---|
| Ptah Forge | 26 Blade components (<x-forge-*>) with Tailwind v4 + Alpine.js — layout, sidebar, navbar, modal, table, forms and much more |
| ptah:forge | SOLID scaffolding generator: an entire entity in seconds, with layered architecture and customisable stubs |
| BaseCrud | Fully generated Livewire screen — filters, create/edit modal, soft delete, export and per-user preferences, all configurable via the database |
⚡ From zero to production in minutes
With ptah + AI (GitHub Copilot, Claude, Cursor) you spend a fraction of the tokens needed to build the same system from scratch — because the package already delivers the structure, and AI only needs to fill in the specific business logic.
Example: IT Helpdesk — complete system in ~3 minutes
Step 0 — Check system requirements
Before you start, confirm your environment meets the minimum versions:
php -v # Required: PHP 8.2+ composer -V # Required: Composer 2+ node -v # Required: Node.js 18+ npm -v # Required: npm 9+
Expected output (example):
PHP 8.2.x ...
Composer version 2.x.x ...
v20.x.x
10.x.x
If any version is below the minimum, update it before proceeding. See the full requirements → for database and extension requirements.
Step 1 — Create the Laravel project
composer create-project laravel/laravel ptah-app
cd ptah-app
Step 2 — Install Ptah
Choose one of the two options below:
Option A — From Packagist (stable — recommended):
composer require jonytonet/ptah
Option B — From GitHub (latest dev version):
Add the VCS repository to your composer.json before requiring the package:
{
"repositories": [
{
"type": "vcs",
"url": "https://github.com/jonytonet/ptah"
}
],
"minimum-stability": "dev",
"prefer-stable": true
}
Then run:
composer require jonytonet/ptah:dev-main
Both options — finish the installation:
php artisan ptah:install
Step 3 — Enable the required modules
php artisan ptah:module auth php artisan ptah:module permissions php artisan ptah:module menu
Step 4 — Generate the 3 system entities
Category:
php artisan ptah:forge Category --fields="name:string,color:string:nullable,description:text:nullable"
Agent:
php artisan ptah:forge Agent --fields="name:string,email:string,department_id:unsignedBigInteger:nullable"
Ticket:
php artisan ptah:forge Ticket --fields="title:string,description:text,status:string,priority:string,category_id:unsignedBigInteger,agent_id:unsignedBigInteger:nullable,resolved_at:datetime:nullable"
Step 5 — Run migrations, sync menu and serve
php artisan migrate php artisan ptah:menu-sync --fresh php artisan serve
What you get at the end:
- ✅ Login with session protection and 2FA
- ✅ Full CRUD for Categories, Agents and Tickets — table, filters, modal, soft delete, export
- ✅ Role-based access control (MASTER + custom roles)
- ✅ Dynamic sidebar menu
- ✅ SOLID architecture: Controller → Service → Repository → DTO
- ✅ Generated validations, Resources and RESTful routes
- ✅ 14 artefacts created per entity, zero manual boilerplate
With AI: instead of generating hundreds of files — consuming thousands of tokens with a high risk of architectural inconsistency —, it runs the commands above and fills in only the specific business logic: ticket escalation, priority notifications, external integrations. Ptah handles the structure; AI handles the differentiator.
🚀 Installation
From Packagist (stable — recommended)
# 1. Install the package composer require jonytonet/ptah # 2. Run the installer php artisan ptah:install # 3. (Optional) Install Laravel Boost for AI agent integration php artisan ptah:install --boost
From GitHub (latest dev version)
Add to your composer.json before requiring:
{
"repositories": [
{
"type": "vcs",
"url": "https://github.com/jonytonet/ptah"
}
],
"minimum-stability": "dev",
"prefer-stable": true
}
Then:
composer require jonytonet/ptah:dev-main php artisan ptah:install
See the full installation guide → for database setup, optional modules and troubleshooting.
🧩 Optional modules
Enable only what you need. Each module updates .env and runs its own migrations.
| Module | Command | What it enables |
|---|---|---|
| auth | php artisan ptah:module auth |
Login, logout, password recovery, 2FA (TOTP + email), profile, active sessions |
| menu | php artisan ptah:module menu |
Dynamic sidebar menu via database with cache, accordion groups |
| company | php artisan ptah:module company |
Company and department management, company switcher, multi-tenant support |
| permissions | php artisan ptah:module permissions |
Full RBAC — roles, pages, objects, middleware, Blade directives, audit log |
| api | php artisan ptah:module api |
REST API with Swagger/OpenAPI via darkaonline/l5-swagger, standardised BaseResponse |
# Check current state of all modules
php artisan ptah:module --list
🤖 Ptah + AI
Ptah is designed to work with AI agents. When installed with --boost, the package automatically registers its guidelines in the configured agents (GitHub Copilot, Claude, Cursor, Gemini, etc.), giving the agent deep knowledge of Ptah conventions, commands and architecture.
Why this matters:
- Without Ptah: AI needs to generate model + migration + repository + service + controller + requests + resource + view + routes for each entity — dozens of files, thousands of tokens, high risk of inconsistency
- With Ptah: AI runs
ptah:forge MyEntity --fields="..."and the system is ready — fewer tokens, architecture guaranteed by the package
For prompts, templates and AI workflow, see the AI Guide →
📟 Commands
| Command | Description |
|---|---|
php artisan ptah:install |
Installs the package (config, stubs, migrations, default data). Flags: --demo, --boost, --force, --skip-npm |
php artisan ptah:forge {Entity} |
Generates the complete structure for an entity ⭐ |
php artisan ptah:module {module} |
Enables an optional module |
php artisan ptah:module --list |
Lists modules and their states |
php artisan ptah:docs {Entity} |
Generates Swagger/OpenAPI annotations |
📚 Documentation
| Document | Contents |
|---|---|
| Installation Guide | Step-by-step guide with real terminal output — Laravel 11/12, all modules and Boost |
| BaseCrud | Complete reference — column schema, types, filters, renderers, export, preferences and UI configuration |
| Modules | Detailed documentation for Auth, Menu, Company, Permissions and API modules |
| Company | Company module — companies, departments, company switcher and multi-company |
| Permissions | Permissions module — RBAC, roles, middleware, helpers, Blade directives and audit log |
| Base Layer | BaseDTO, BaseRepository, BaseService — all methods, signatures, examples and REST API query parameters |
| AI Guide | AI agent integration — prompts, templates and workflow with Copilot, Claude and Cursor |
📋 Requirements
| Requirement | Minimum version |
|---|---|
| PHP | 8.2 |
| Laravel | 11 or 12 |
| Node.js + npm | 18+ |
| Livewire | v4 (included as dependency) |
📄 License
Open source under the MIT License.
Made by jonytonet
Ptah — Enterprise Structure. Startup Speed.