Skip to content

A simple framework to make URL Routing in PHP easier

License

Notifications You must be signed in to change notification settings

Jonah987654321/OmniRoute

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OmniRoute

OmniRoute is a lightweight, flexible PHP routing library designed to simplify the management of routes in your PHP applications. It allows you to define routes, handle URL parameters with regular expressions, and manage error callbacks for common HTTP response codes.

Features

  • Route Registration: Easily register routes with specific HTTP methods and callbacks.
  • Prefix Support: Apply a prefix to a group of routes to organize and manage them efficiently.
  • Error Handling: Register custom callbacks for handling 404 Not Found and 405 Method Not Allowed errors.
  • Regular Expression Arguments: Support for dynamic URL parameters using regular expressions.
  • Sub-Router Integration: Include and register routes from external files for better modularization.

Installation

composer require jonahh/omniroute

Usage

Basic Route Registration

You can register a simple route by calling the add method:

use OmniRoute\Router;
require __DIR__.'/vendor/autoload.php';

Router::add('/home', function() {
    echo "Welcome to the homepage!";
});

Route with Parameters

To create a route with dynamic parameters, use placeholders wrapped in <: :>:

Router::add('/user/<:id:>', function($id) {
    echo "User ID: " . $id;
});

Prefixing Routes

You can group routes under a common prefix:

Router::registerPrefix('/api/v1');

Router::add('/users', function() {
    echo "Users endpoint";
});

All routes added after setting a prefix will automatically include it.

Registering Sub-Routers

For better modularization, you can load routes from external files:

Router::registerSubRouter('path/to/routes.php');

Setting allowed methods

You can set what methods are allowed for routes to be called:

Router::add('/api/post-only', function() {
    echo json_encode(["data"=>$data]);
}, ["POST"]);

Handling Errors

You can register custom error callbacks for 404 and 405 errors:

Router::registerErrorCallback(OMNI_404, function($path) {
    echo "Error 404: The path $path was not found.";
});

Router::registerErrorCallback(OMNI_405, function($path, $method) {
    echo "Error 405: The method $method is not allowed for $path.";
});

Running the Router

Finally, to execute the router and handle incoming requests, call the run method:

Router::run();

License

This package is open-source and available under the MIT License.

Author

This package is developed by Jonah

About

A simple framework to make URL Routing in PHP easier

Resources

License

Stars

Watchers

Forks