velvetcms / core
Modular PHP content application framework with file-native page content, events, templates, and more. Foundation for the VelvetCMS platform.
Requires
- php: ^8.4
- composer/semver: ^3.4
- psr/log: ^3.0
- symfony/console: ^8.0
- symfony/yaml: ^8.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.93
- league/commonmark: ^2.8
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^12.0
Suggests
- erusev/parsedown: Required for the 'parsedown' content parser driver
- league/commonmark: Required for the 'commonmark' content parser driver
README
Why VelvetCMS Core?
Most PHP frameworks fall into two camps: heavyweight full-stack solutions with steep learning curves, or minimal routers that leave you rebuilding the same features for every project. VelvetCMS Core sits between those extremes.
It is built for developers and teams that want full-stack capabilities without framework opacity: explicit architecture, practical defaults, and a codebase you can reason about quickly.
That philosophy is what we call Pragmatic Zero Magic. You should be able to trace every part of your application's lifecycle without digging through layers of invisible behavior.
Core also deliberately tracks modern PHP aggressively. We target current stable releases early, remove legacy detours when they start warping the design, and prefer clear upgrade paths over dragging old compatibility baggage forward.
- Explicit over Implicit: Service bindings live in bootstrap code, routes and middleware are declared directly, and the request lifecycle stays readable end to end.
- Pragmatic Convenience: Autowiring helps with controllers and commands, but command registration, module loading, and core service wiring remain explicit where hidden resolution would cost clarity.
- No Facades: Dependencies arrive through constructors and method signatures, so tests and refactors work against real contracts instead of global static state.
- Content First: Page content is file-native, the parser understands frontmatter and block modes, and routing plus caching are tuned for publishing workloads rather than generic CRUD scaffolding.
- Lean by Design: The runtime stays small, the dependency graph stays short, and the codebase remains compact enough to inspect without framework archaeology.
Features
Core Architecture
- Service Container: Powerful dependency injection container. Explicit by default, with autowiring available as a pragmatic fallback.
- Modular System: Robust plugin architecture with PSR-4 autoloading, dependency resolution, and manifest-based loading for optimal performance.
- Event Dispatcher: Comprehensive event system allowing hooks into every part of the application lifecycle.
- CLI Suite: Extensive command-line tools for migrations, cache management, scaffolding, serving, diagnostics and more.
Content & Data
- File-Based Content: Pages live as
.vltor.mdfiles. They stay versionable, portable, and inspectable, with an on-disk index for fast lookups and no database requirement for page content. - Fluent Query Builder: Expressive database abstraction layer supporting complex queries, joins, raw expressions, and automatic caching.
- Schema Builder & Migrations:
- Database Agnostic: Write schemas once, run on SQLite, MySQL, or PostgreSQL.
- Fluent Interface: Define tables and columns with an expressive syntax (
$table->string('title')->nullable()). - Migration System: Version control for your database schema with
upanddownmethods.
- Pluggable Markdown Engine:
- Drivers: Support for
CommonMark(recommended),Parsedown, or simpleHTMLpass-through. - Extensible: Custom template tags (
{{ }},{!! !!}) preserved in all drivers. - CommonMark Features: Tables, Strikethrough, Autolink, Task Lists (via extensions).
- Drivers: Support for
- Velvet Content Blocks:
.vltfiles with YAML frontmatter and block switches (@markdown,@html,@text,@component). - Data Store: Simple key-value collections with
File,Database, orAutodrivers for module data. - Smart Caching: Multi-driver support (
Apcu,File,Redis) for caching queries, pages, routes, configuration, templates, and markdown compilation. - File Storage:
- Disk System: Abstraction layer for file operations (write, read, stream).
- Drivers:
Localdriver implemented (S3/Cloud ready interface). - Security: Built-in path normalization to prevent directory traversal.
Web & Security
- Robust Router: Expressive routing engine with support for:
- GET, POST, PUT, DELETE, PATCH methods
- Named routes and parameters
- Optional and wildcard parameters (
{param?},{param*}) - Middleware pipelines and global middleware
- Validation Service:
- Standalone Validator: reuse validation logic anywhere (CLI, API, Imports).
- Rich Rule Set:
required,email,url,min,max,regex,numeric,integer,boolean,alpha,alphanumeric,in,same,different,date,array. - Fluent API:
Validator::make($data, $rules)->validate(). - Custom Rules:
Validator::extend('slug', fn($value) => ...)for project-specific validation.
- View Engine: Lightweight yet powerful templating system featuring:
- Blade-like syntax (
{{ }},{!! !!}) - Blade-style comments (
{{-- ... --}}) - Control structures (
@if,@foreach) - Layout inheritance (
@extends,@section,@yield) - Partials and includes (
@include) - Namespace support for modular views
- Configurable runtime string evaluation guard for
compileString()/safe()
- Blade-like syntax (
- Asset Server: Built-in static asset serving for development and production, handling MIME types and module assets efficiently.
- Trusted Proxy Support: Optional forwarded host/scheme/IP handling for reverse-proxy deployments (
http.trusted_proxies). - Security Suite: Built-in protection against common vectors.
- ✅ XSS Protection - Auto-escaping template engine
- ✅ CSRF Protection - Token-based validation
- ✅ SQL Injection - Prepared statements by default, with explicit raw-expression escape hatches for advanced clauses
- ✅ Session Security - httponly, secure, samesite flags
- ✅ Path Traversal - Sanitization and realpath checks
- Rate Limiting:
- Named Limiters: Pre-configured (
standard,api,auth,strict) or custom. - Module Support: Modules register their own limiters via
RateLimiterservice. - Dynamic Limits: Callbacks for user-aware throttling (e.g., premium users).
- Flexible Keys: Limit by IP, user, route, or custom keys.
- Whitelist: Bypass for trusted IPs.
- Named Limiters: Pre-configured (
- Exception Handling:
- Custom Handler: Centralized error handling and reporting.
- HTTP Exceptions: Specialized exceptions for 404, 403, 500, etc.
- Renderable Exceptions: Exceptions that can render their own response.
- Logging:
- PSR-3 Compliant: Standard
LoggerInterfacewith all log levels. - Daily Rotation: Optional dated log files (
velvet-2026-01-28.log). - Auto Cleanup: Configurable
max_filesto prevent disk bloat.
- PSR-3 Compliant: Standard
System & Scheduling
- Task Scheduler: Cron-style task scheduling defined in PHP.
- Fluent Frequency: Define schedules naturally (
->daily(),->everyMinute()). - Command & Callback: Schedule console commands or PHP closures.
- Fluent Frequency: Define schedules naturally (
- Schedule Runner: CLI
schedule:runand optional WebCron endpoint (/system/cron). - Version Registry: Centralized version management for core and modules.
Multi-Tenancy
- Single switch: Enable/disable in user/config/tenancy.php with
tenancy.enabled(default off). - Resolvers:
- Host: Map hostnames or subdomains to tenants (
tenancy.host.map, optional wildcard subdomains). - Path: Use a path segment as tenant id (
tenancy.path.segment). - Callback: Provide a custom resolver that implements
TenantResolverInterface.
- Host: Map hostnames or subdomains to tenants (
- Works with:
- Content and views (tenant-scoped roots under
user/tenants/<tenant>/...) - Storage and modules (tenant-scoped roots/artifacts)
- Cache/session isolation per tenant
- Database-per-tenant setups when desired
- Content and views (tenant-scoped roots under
- Isolation: Cache prefixing and tenant-scoped storage prevent cross-tenant collisions.
- Sessions: Path-based tenancy scopes cookies to the tenant path automatically.
- CLI: Set tenant context via
$TENANCY_TENANTor--tenant=<id>; use--all-tenantsfor tenancy-aware orchestration commands.
Requirements
- PHP 8.4+ (+ extensions:
pdo,mbstring,json) - Linux/WSL2
- Composer
- SQLite, MySQL, or PostgreSQL (optional)
Quick Start
# Clone and install git clone https://github.com/VelvetCMS/core.git cd core composer install --no-dev # Bootstrap ./velvet install # Start dev server ./velvet serve
Visit http://localhost:8000
Documentation
Full documentation available at velvetcms.com/docs
Quick links:
License
VelvetCMS Core is licensed under the Apache License 2.0.
See LICENSE or Our licensing page for the full text.
Contributing
Contributions welcome! See CONTRIBUTING.md for guidelines.
Security Issues: Email security@anvyr.dev (do not open public issues!)
Credits
Built with ❤️ by Anvyr.
See composer.json for dependencies.