Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/netherphp/avenue

A Request Router
https://github.com/netherphp/avenue

Last synced: 2 months ago
JSON representation

A Request Router

Awesome Lists containing this project

README

        

# Nether Avenue

[![Packagist](https://img.shields.io/packagist/v/netherphp/avenue.svg?style=for-the-badge)](https://packagist.org/packages/netherphp/avenue)
[![Build Status](https://img.shields.io/github/actions/workflow/status/netherphp/avenue/phpunit.yml?style=for-the-badge)](https://github.com/netherphp/avenue/actions)
[![codecov](https://img.shields.io/codecov/c/gh/netherphp/avenue?style=for-the-badge&token=VQC48XNBS2)](https://codecov.io/gh/netherphp/avenue)

A PHP 8+ annotation based request router. It is able to scan through a directory of routes/controllers and determine which ones should get executed to satisfy incoming request.

Routes are able to define via the `RouteHandler` attribute, the path, domain, and HTTP verb they are willing to answer. They can also extract information from the URI and pass them to the method. It will make sure the data is of the types declared on the method signature.

Routes are *checked if they can* handle a request based on the request parameters (Verb, Domain, and Path). Then routes are *asked if they will* handle a request. A method just for checking the willingness of a route handler can be defined with the `ConfirmWillAnswerRequest` attribute.

The Router is able to both scan a directory on the fly to generate the route map (nice for development), as well as there is a vendor bin script, `netherave`, which is able to generate a static route map file that the Router will load to speed things up.

# Quickstart

How-To on getting the library up and running on a fresh project.

* https://github.com/netherphp/avenue/wiki/Quickstart

# Documentation

All documentation that exists is currently on the GitHub wiki.

* https://github.com/netherphp/avenue/wiki

---

*Example Router (www\index.php)*
```php
require('vendor/autoload.php');

$Config = Nether\Avenue\Library::PrepareDefaultConfig();
$Router = new Nether\Avenue\Router($Config);
$Router->Run();
```

*Example Route (routes\Home.php)*
```php
namespace Routes;

use Nether\Avenue;

class Home
extends Avenue\Route {

#[Avenue\Meta\RouteHandler('/index')]
public function
Index():
void {

echo 'Home Page.';
return;
}

#[Avenue\Meta\RouteHandler('/dashboard')]
#[Avenue\Meta\ConfirmWillAnswerRequest]
public function
Dashboard():
void {

echo 'User Dashboard.';
return;
}

public function
DashboardWillAnswerRequest():
int {

$User = YourAppSessionLib::GetCurrentUser();

if($User && $User->CanHasDashboard())
return Avenue\Response::CodeOK;

return Avenue\Response::CodeForbidden;
}

#[Avenue\Meta\ErrorHandler(403)]
public function
HandleForbidden():
void {

echo "Dude No.";
return;
}

#[Avenue\Meta\ErrorHandler(404)]
public function
HandleNotFound():
void {

echo "Bruh Wut?";
return;
}

}

```

*Example Static Map Generation (CLI)*
```cli
$ netherave gen routes --show
Route Directory: routes
Route File: ./routes.phson

Summary:
* GET (2)
Routes\Home::Index
Routes\Home::Dashboard

* Error Handlers (2)
Routes\Home::HandleForbidden
Routes\Home::HandleNotFound
```

# Notes

This is not a PSR compliant anything. It do as it be.