codesaur / router
Хөнгөн, хурдан, объект-суурьтай маршрутчиллын (routing) компонент
Requires
- php: ^8.2.1
Requires (Dev)
- phpunit/phpunit: ^10.0
This package is auto-updated.
Last update: 2026-05-24 03:13:48 UTC
README
Агуулга / Table of Contents
- Монгол | 2. English | 3. Getting Started
1. Монгол тайлбар
Хөнгөн, хурдан, объект-суурьтай маршрутчиллын (routing) компонент. Динамик параметрүүд, нэртэй маршрутууд, reverse routing зэрэг бүх шаардлагатай боломжуудыг дэмждэг.
codesaur/router нь codesaur ecosystem-ийн нэг хэсэг бөгөөд хөнгөн жинтэй,
фрэймворкоос үл хамааран standalone байдлаар ашиглаж болох PHP routing компонент юм.
Багц нь дараах 3 үндсэн class-аас бүрдэнэ:
- Router - маршрут бүртгэх, тааруулах, URL үүсгэх үндсэн класс
- RouterInterface - router-ийн бүрэн contract (
match,generate,pattern,getRoutes). 3rd-party router-уудыг adapter-аар ороож ашиглах боломж олгоно. - Route - immutable value object -
Router::__call()-ийн буцаах утга.->name(...),->middleware([...])гэх мэт fluent API-д ашиглагдана.
Дэлгэрэнгүй мэдээлэл
- Бүрэн танилцуулга - Суурилуулалт, хэрэглээ, жишээнүүд
- API тайлбар - Бүх метод, exception-үүдийн тайлбар
- Шалгалтын тайлан - Код шалгалтын тайлан
2. English description
A lightweight, fast, object-oriented routing component. Supports dynamic parameters, named routes, reverse routing, and all essential routing features.
codesaur/router is part of the codesaur ecosystem and is a lightweight PHP routing component that can be used standalone, independent of any framework.
The package consists of the following 3 core classes:
- Router - main class for registering routes, matching requests, and generating URLs
- RouterInterface - full router contract (
match,generate,pattern,getRoutes). Allows third-party routers to be adapted and used incodesaur/http-application. - Route - immutable value object returned by
Router::__call(). Provides fluent API such as->name(...),->middleware([...]).
Documentation
- Full Documentation - Installation, usage, examples
- API Reference - Complete API documentation
- Review - Code review report
3. Getting Started
Requirements
- PHP 8.2.1+
- Composer
Installation
Composer ашиглан суулгана / Install via Composer:
composer require codesaur/router
Quick Example
use codesaur\Router\Router; $router = new Router(); // Энгийн GET маршрут / Simple GET route $router->GET('/hello', function() { echo 'Hello, World!'; }); // Динамик параметртэй маршрут / Route with dynamic parameters $router->GET('/news/{int:id}', function(int $id) { echo "News ID: $id"; })->name('news-view'); // UTF-8 параметр / UTF-8 parameter (Cyrillic, CJK, etc.) $router->GET('/search/{utf8:query}', function(string $query) { echo "Search: $query"; })->name('search'); // Per-route middleware - (pattern, method) scope-той / scoped to the (pattern, method) pair $router->POST('/api/users', [UserController::class, 'create']) ->middleware([CsrfMiddleware::class, AuthMiddleware::class]) ->name('users.create'); // Append semantics - олон ->middleware() chain цуглуулагдана / chained calls accumulate $router->GET('/admin', [AdminController::class, 'dashboard']) ->middleware([AuthMiddleware::class]) ->middleware([AdminOnlyMiddleware::class]); // Маршрут тааруулах / Match route // match() буцаах: [callable, params, middleware] тогтмол 3-tuple эсвэл null $result = $router->match('/news/10', 'GET'); if ($result !== null) { [$callable, $params, $middleware] = $result; \call_user_func_array($callable, $params); } // URL үүсгэх / Generate URL $url = $router->generate('news-view', ['id' => 10]); // -> /news/10 // Client-side substitution-д бэлэн pattern / Pattern for client-side substitution $pattern = $router->pattern('news-view'); // -> /news/{id}
Running Tests
Тест ажиллуулах / Run tests:
# Бүх тестүүдийг ажиллуулах / Run all tests composer test # Coverage-тэй тест ажиллуулах / Run tests with coverage composer test:coverage
Changelog
- CHANGELOG.md - Full version history
Contributing & Security
License
This project is licensed under the MIT License.
Author
Narankhuu
codesaur@gmail.com
https://github.com/codesaur
codesaur ecosystem: https://codesaur.net