codesaur/router

Хөнгөн, хурдан, объект-суурьтай маршрутчиллын (routing) компонент

Maintainers

Package info

github.com/codesaur-php/Router

Homepage

pkg:composer/codesaur/router

Statistics

Installs: 735

Dependents: 1

Suggesters: 0

Stars: 1

Open Issues: 0

v6.0.0 2026-05-24 03:05 UTC

README

CI PHP Version License

Агуулга / Table of Contents

  1. Монгол | 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-д ашиглагдана.

Дэлгэрэнгүй мэдээлэл

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 in codesaur/http-application.
  • Route - immutable value object returned by Router::__call(). Provides fluent API such as ->name(...), ->middleware([...]).

Documentation

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

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