rudra/framework 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

rudra/framework

Composer 安装命令:

composer require rudra/framework

包简介

Rudra framework

README 文档

README

Maintainability CodeFactor PHP Version License

Rudra Framework

A lightweight, transparent PHP framework built on the principles of simplicity and clarity.

~15 MB · Lightweight Query Builder · No hidden dependencies · No magic · PHP 8.3 Attributes · Porto Architecture

Philosophy

Rudra follows the KISS principle — every tool is visible, every dependency is explicit, and every layer does exactly one thing. No "magic" happens behind the scenes: if you see it in the code, that's all there is.

  • Transparency — no hidden behavior, no implicit side effects
  • Simplicity — minimal surface area, easy to learn and extend
  • Explicit over implicit — dependencies are declared, not guessed
  • Modern PHP — built from the ground up on PHP 8.3+ features (attributes, typed constants, fibers)

Who is this for?

Rudra is built for developers who:

  • Prefer explicit code over framework magic — you want to see exactly what SQL is executed, what routes are registered, and what dependencies are injected
  • Value cognitive clarity — you need a framework that stays out of your way and doesn't require memorizing hidden conventions
  • Work on small-to-medium projects — you want structure and best practices without the overhead of enterprise-grade frameworks
  • Want full control — you believe that understanding your tools is more important than having hundreds of features out of the box

If you're looking for a batteries-included framework with built-in ORM, pre-configured queue workers, and ready-made broadcast drivers — Rudra is not for you.
If you want a lightweight, transparent foundation with simple primitives that you can extend exactly as needed — you're in the right place.

Installation

Via Composer (stable)

composer create-project --prefer-dist rudra/framework newapp
cd newapp

Via Composer (dev)

composer create-project --prefer-dist --stability=dev rudra/framework newapp
cd newapp

Via Git + DDEV (full environment)

The fastest way to get a fully working local environment — containers, dependencies, SSL, and database included:

git clone git@github.com:Jagepard/Rudra-Framework.git
cd Rudra-Framework
ddev start   # Start containers, install deps, set up SSL & DB
ddev launch  # Open the site in your browser

Quick Start

Run the built-in development server:

php rudra serve

Then open http://127.0.0.1:8000 in your browser.

📦 Ecosystem Components

Rudra is built on a modular component architecture. Each component is a standalone Composer package — use only what you need, or install everything via rudra/framework.

Component Description Package
📦 Container DI container with 5 binding patterns (string, object, factory string, factory object, closure) rudra/container
🧭 Router HTTP router with PHP 8 attributes, middleware pipeline, REST resources, method spoofing rudra/router
🎯 Controller MVC controller abstraction with lifecycle hooks (init, before, after) rudra/controller
💾 Model Lightweight Query Builder + Repository pattern (not a heavy ORM) rudra/model
🔐 Auth Authentication, session management, RBAC, "Remember Me" rudra/auth
🔗 OAuthClient OAuth 2.0 client (Yandex, VK, custom providers) rudra/oauth-client
🎧 EventDispatcher Events system with Listeners (pub/sub) and Observers (stateless notifications) rudra/event-dispatcher
Validation Fluent validation with CSRF, sanitization, custom rules, field aliases rudra/validation
🖼️ View Template engine (PHP + Twig support) with file-based caching rudra/view
🛡️ Exception HTTP error handling with custom error pages and DebugBar integration rudra/exception
🔀 Redirect HTTP redirection with status codes (1xx-5xx) rudra/redirect
📄 Pagination SQL OFFSET/LIMIT calculator with page links generator rudra/pagination
📜 Annotation Metadata reader for PHP 8 attributes + legacy docblock annotations rudra/annotation
🖥️ Cli CLI component with command routing rudra/cli
📝 Docs Auto-generates Markdown API documentation from source code rudra/docs

🔑 Key Features in Action

🔐 Authentication & RBAC

use Rudra\Auth\AuthFacade as Auth;

// Registration
$user = [
    "email"    => "user@email.com",
    "password" => Auth::bcrypt("password")
];

// Authentication (plain password vs hash from DB)
Auth::authentication($user, "password", ["admin/dashboard", "login"]);

// Authorization check (redirects to 'login' if not authenticated)
if (!Auth::authorization(null, "login")) {
    exit;
}

// Role-Based Access Control
if (!Auth::roleBasedAccess($currentRole, "editor", "error/403")) {
    exit;
}

🎧 Event Dispatcher (Listeners + Observers)

use Rudra\EventDispatcher\EventDispatcherFacade as Dispatcher;

// Listeners — pub/sub with payload
Dispatcher::addListener('user.registered', [UserListener::class, 'onRegister']);
Dispatcher::dispatch('user.registered', ['id' => 1, 'email' => '...']);

// Observers — stateless notifications (no payload)
Dispatcher::attachObserver('before', [AuditObserver::class, 'onEvent']);
Dispatcher::notify('before');

✅ Fluent Validation

use Rudra\Container\Facades\Request;
use Rudra\Container\Facades\Session;
use Rudra\Validation\ValidationFacade as V;

$fields    = Request::post()->all();
$processed = [
    'name'        => V::sanitize($fields ['name'])->required()->min(3)->max(50)->run(),
    'email'       => V::email($fields ['email'])->run(),
    'age'         => V::sanitize($fields ['age'])->integer()->between(18, 100)->run(),
    'description' => V::set($fields['description'])->run(), // without validation
    'csrf'        => V::sanitize($fields['csrf'])->csrf(Session::get('csrf_token'))->run(),
];

if (V::approve($processed)) {
    $data = V::getValidated($processed, ["csrf", "_method"]);
} else {
    $errors = V::getErrors($processed);
}

🧭 RESTful Resources

Registers standard CRUD routes with explicit plural and singular URL patterns. No magic pluralization — you define exactly what the URLs look like.

$router->resource('api/users', 'api/user', UserController::class);

This creates the following routes:

Method URL Controller Method Description
GET api/users index List all users
GET api/user/:id read Get single user
POST api/users create Create new user
PUT api/user/:id update Full update user
PATCH api/user/:id update Partial update user
DELETE api/user/:id delete Delete user

The default action names are [index, read, create, update, delete].

Custom Method Names

You can override the default action names by passing a custom array of 5 methods:

$router->resource('api/posts', 'api/post', PostController::class, [
    'actionIndex',   // GET    api/posts       — list all posts
    'actionView',    // GET    api/post/:id    — get single post
    'actionAdd',     // POST   api/posts       — create new post
    'actionUpdate',  // PUT/PATCH api/post/:id — update post
    'actionDrop'     // DELETE api/post/:id    — delete post
]);

The array order is fixed: [index, read, create, update, delete].

🖼️ View with Caching

use Rudra\View\ViewFacade as View;

// Cache-first strategy with fallback
echo View::cache(['mainpage', "+1 day"]) ?? View::render(["layout", "mainpage"], [
    'content' => View::cache(["page_{$slug}", "+1 day"]) 
        ?? View::view(["page", "page_{$slug}"], ['foo' => 'bar']),
]);

// Or with helpers
data(['content' => cache(['mainpage']) ?? view(['index', 'mainpage'])]);
render('layout', data());

💾 Data Access Layer (Rudra-Model)

Rudra includes a lightweight, transparent data access layer — not a heavy ORM, but a simple Query Builder with Repository pattern.

Architecture: Entity → Model → Repository

A predictable delegation chain with automatic fallback:

  • Entity — entry point, defines the table name
  • Model — business logic layer (optional)
  • Repository — data access layer (optional, falls back to base CRUD)

If you don't create a Model or Repository, the base Repository handles standard CRUD automatically.

Zero Boilerplate

namespace App\Containers\User\Entity;

use Rudra\Model\Entity;

class User extends Entity
{
    public static ?string $table = 'users';
}

// Usage — no Model or Repository needed:
$users = User::getAll();
$user  = User::find(1);
User::create(['name' => 'John', 'email' => 'john@example.com']);

Custom Repository Logic

namespace App\Containers\User\Repository;

use Rudra\Model\Repository;

class UserRepository extends Repository
{
    public function findActiveUsers(): array
    {
        return $this->qBuilder("SELECT * FROM {$this->table} WHERE active = 1");
    }
}

// Automatically routed:
$activeUsers = User::findActiveUsers();

Fluent Query Builder

use Rudra\Model\QBFacade as QB;

$query = QB::select('id, name, email')
    ->from('users')
    ->where('status = :status')
    ->and('role = :role')
    ->orderBy('created_at DESC')
    ->limit(10)
    ->get();

// Execute via Repository:
$results = User::qBuilder($query, ['status' => 'active', 'role' => 'admin']);

Schema Builder

use Rudra\Model\Schema;

Schema::create('users', function ($table) {
    $table->integer('id', '', true) // auto-increment
          ->string('name')
          ->string('email')
          ->text('bio', 'NULL')
          ->created_at()
          ->updated_at()
          ->pk('id');
})->execute();

File-Based Caching

Simple, reliable JSON file caching — no Redis/Memcached required:

// Cache query results
$users = User::cache(['getAll']);

// Cache with TTL
$posts = Post::cache(['findBy', ['category', 'news']], '+1 hour');

// Auto-clears on create/update/delete

Why Not a Heavy ORM?

  • No magic — no hidden queries, no lazy loading surprises
  • No hidden dependencies — direct PDO access when needed
  • Predictable — you see exactly what SQL is executed
  • Fast — no reflection overhead, no entity hydration complexity
  • Simple — if you know SQL, you know Rudra-Model

🛠️ CLI Tools

Rudra ships with a rich set of CLI utilities following the Porto architecture. Run php rudra help to see the full list.

🚀 Launch & Help

Command Description
php rudra serve Start the built-in dev server (alias: run)
php rudra help List all available commands

🛠️ Generators (make:*)

Command Description
php rudra make:container 📦 Scaffold a new Porto container
php rudra make:controller 🧭 Generate a controller class
php rudra make:contract 📜 Generate an interface (contract)
php rudra make:factory 🏭 Generate a factory class
php rudra make:listener 👂 Generate an event listener
php rudra make:middleware 🛡️ Generate a middleware class
php rudra make:migration 🗄️ Generate a database migration
php rudra make:model 🧱 Generate Entity + Repository pair
php rudra make:observer 👁️ Generate an event observer
php rudra make:seed 🌱 Generate a database seeder
php rudra make:docs 📝 Generate documentation from source

🗄️ Database

Command Description
php rudra migrate 🛤️ Run pending migrations (with duplicate protection)
php rudra seed 🌾 Execute seeders (with duplicate protection)

🔍 Debug

Command Description
php rudra debug:router 🗺️ List all registered routes
php rudra debug:router:container 🔍 List routes for a specific container
php rudra debug:listeners 🎧 List registered event listeners
php rudra debug:observers 🔭 List registered event observers

🔐 Security

Command Description
php rudra bcrypt 🔐 Hash a password with bcrypt
php rudra secret 🔑 Generate a cryptographic secret (APP_KEY)

🧹 Maintenance & Utils

Command Description
php rudra cache:clear 🧹 Clear application cache
php rudra convert:array-to-yml 🔄 Convert a PHP array config to YAML (alias: to:yml)

Features

  • PHP 8.3 Attributes for routing and middleware — clean, declarative syntax
  • Automatic Dependency Injection with autowiring
  • 5 container binding patterns: string, object, factory string, factory object, closure
  • Event Dispatcher with both Listeners and Observers
  • File-based caching — simple, reliable, no external dependencies
  • Porto Architecture — clear separation between Ship (shared) and Containers (modules)
  • DebugBar integration with custom collectors (Security, PDO, Config)
  • Whoops for beautiful error pages in development
  • Twig support — optional, via factory binding
  • RESTful resources — one line registers all CRUD routes
  • Method spoofing — PUT/PATCH/DELETE from POST forms via _method
  • CSRF protection built into validation and controllers

License

This project is licensed under the Mozilla Public License 2.0 (MPL-2.0) — a free, open-source license that:

  • ✅ Requires preservation of copyright and license notices
  • ✅ Allows commercial and non-commercial use
  • ✅ Requires that modifications to original files remain open under MPL-2.0
  • ✅ Permits combining with proprietary code in larger works

📄 Full license text: LICENSE
🌐 Official MPL-2.0 page: https://mozilla.org/MPL/2.0/

统计信息

  • 总下载量: 133
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 2
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MPL-2.0
  • 更新时间: 2016-07-26

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固