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|^13.0
- livewire/livewire: ^4.0
- maatwebsite/excel: ^3.1
- symfony/expression-language: ^6.4|^7.0
Requires (Dev)
- larastan/larastan: ^2.9|^3.0
- laravel/pint: ^1.13
- orchestra/testbench: ^9.0|^10.0
- phpunit/phpunit: ^11.0
- prism-php/prism: ^0.100
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
- prism-php/prism: Required for the AI Agent module (conversational AI widget) — ai_agent module
This package is auto-updated.
Last update: 2026-06-12 17:43:28 UTC
README
Enterprise Structure. Startup Speed.
Generate your system's entire structure in minutes — you focus only on the business logic.
Built for AI agents: the architecture comes ready, so the agent spends a fraction of the 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 |
In a hurry? Follow the Quick Start → — one entity, SQLite, working CRUD in 5 minutes.
⚡ The full structure in minutes — far fewer tokens with AI
What Ptah generates in minutes: the complete, layered structure of every entity (model, migration, DTO, repository, service, controller, requests, resource, Livewire screen and routes), plus auth, RBAC and a dynamic menu. What stays with you: the specific business logic and a short post-scaffold review (see Known Limitations).
Why this saves tokens: with ptah + AI (GitHub Copilot, Claude, Cursor) the agent doesn't waste tokens generating dozens of boilerplate files and re-deciding the architecture on every entity — that's already delivered, consistently. The agent spends its budget only on your differentiator. Fewer tokens, fewer files to review, and an architecture that doesn't drift between entities.
Example: IT Helpdesk — full CRUD structure 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 — Configure your database
Edit .env to point to your database of choice before running migrations.
SQLite (quick start):
DB_CONNECTION=sqlite
touch database/database.sqlite
MySQL:
DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=ptah_app DB_USERNAME=root DB_PASSWORD=your_password
PostgreSQL:
DB_CONNECTION=pgsql DB_HOST=127.0.0.1 DB_PORT=5432 DB_DATABASE=ptah_app DB_USERNAME=postgres DB_PASSWORD=your_password
See the full database guide → for more options.
Step 4 — Enable the required modules
php artisan ptah:module auth php artisan ptah:module permissions php artisan ptah:module menu
Step 5 — 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 6 — Run migrations, sync menu and serve
php artisan migrate php artisan ptah:menu-sync --fresh php artisan serve
What you get at the end (the structure):
- ✅ 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
What's still yours to do (the actual application): wire up relationships left as TODOs, review the generated validation rules, and add the business logic — ticket escalation, priority notifications, integrations. Then the usual road to production: tests, security review and deploy. See the post-scaffold checklist.
Why AI loves this: instead of generating hundreds of files — thousands of tokens, with architectural drift between entities — the agent runs the commands above and spends its token budget only on your differentiator. Ptah handles the structure; AI handles the business logic.
🚀 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 |
| ai_agent | php artisan ptah:module ai_agent |
Floating AI chat widget (JivoChat-style) + provider config admin — powered by prism-php/prism |
# 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="...", the structure is ready, and it spends its tokens only on the business logic — 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 |
🎨 Theming & customizing views
Brand colors — set once, everything follows. Define your palette in
config/ptah.php (or via .env) and the whole UI — BaseCrud, Forge components,
modules — picks it up. No view publishing, survives composer update:
// config/ptah.php 'theme' => [ 'colors' => [ 'primary' => env('PTAH_COLOR_PRIMARY', '#5b21b6'), 'success' => env('PTAH_COLOR_SUCCESS', '#10b981'), 'danger' => env('PTAH_COLOR_DANGER', '#ef4444'), 'warn' => env('PTAH_COLOR_WARN', '#f59e0b'), 'dark' => env('PTAH_COLOR_DARK', '#1e293b'), ], ],
# .env — rebrand without touching code PTAH_COLOR_PRIMARY=#0d9488
Ptah injects these as CSS variables (--color-primary, --ptah-primary, …) in the
layout <head>; every tint, focus ring and hover is derived from them via
color-mix(). Accepts any CSS color (hex, rgb, hsl, oklch).
Customizing views — publish only what you edit. Most customization is done
through the CrudConfig modal (database-driven), so you rarely need to touch a Blade
file. If you do, ⚠️ publishing a view means you own it — Laravel will prefer your
copy and composer update will never refresh it again. Publish the smallest slice:
php artisan vendor:publish --tag=ptah-views-components # just the <x-forge-*> php artisan vendor:publish --tag=ptah-views-base-crud # just the BaseCrud screen php artisan vendor:publish --tag=ptah-views-auth # just the auth pages php artisan vendor:publish --tag=ptah-views-ai # just the AI widget # (ptah-views still publishes ALL 60+ views — avoid it unless you really mean to)
To keep the UI always up to date, keep resources/views/vendor/ptah/ empty.
📚 Documentation
| Document | Contents |
|---|---|
| Quick Start | Your first CRUD in 5 minutes — one entity, SQLite, zero decisions |
| 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 |
| Known Limitations | Developer checklist — decimal precision, FK constraints, composite indexes, post-forge responsibilities |
📋 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.