PHPackages                             sopheos/pebble\_burn - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. sopheos/pebble\_burn

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

sopheos/pebble\_burn
====================

PHP burn library

1.0.6(6mo ago)1354MITPHPPHP &gt;=8.1.0

Since Aug 3Pushed 6mo ago1 watchersCompare

[ Source](https://github.com/sopheos/pebble_burn)[ Packagist](https://packagist.org/packages/sopheos/pebble_burn)[ RSS](/packages/sopheos-pebble-burn/feed)WikiDiscussions main Synced 3w ago

READMEChangelogDependencies (1)Versions (12)Used By (0)

Pebble/Burn
===========

[](#pebbleburn)

Services
--------

[](#services)

Gestion des dépendances entre les services d'une application

Router
------

[](#router)

Le système de route permet d'associer un traitement à une requête (HTTP / CLI).

Le routeur `\Pebble\Burn\Router` est un singleton.

Ajouter une route
-----------------

[](#ajouter-une-route)

La méthode `add($http_method, $uri, $controller, $method = null) : Router` permet d'ajouter une nouvelle route. Cette méthode est chainable.

- *`$http_method`* Méthode de la requête HTTP (GET, POST, ...) ou CLI.
- *`$uri`* URI correspondant à la route.
- *`$controller`* Nom du contrôleur OU un élément `callable`.
- *`$method`* Nom de la méthode du contrôleur si celui-ci n'est pas de type `callable`.

Raccourcis :

- `get($uri, $controller, $method = null) : Router`
- `post($uri, $controller, $method = null) : Router`
- `put($uri, $controller, $method = null) : Router`
- `patch($uri, $controller, $method = null) : Router`
- `delete($uri, $controller, $method = null) : Router`
- `options($uri, $controller, $method = null) : Router`
- `cli($uri, $controller, $method = null) : Router`

Les URIs
--------

[](#les-uris)

Les URIs peuvent être des expressions régulières. Les segments capturés par des parenthèses sont passés comme paramètres à la fonction de rappel. Pour les routes dynamiques, les `expressions régulières` et `wildcards` doivent être entourées pas des parenthèses.

Exemples :

```
Router::getInstance()->get('/user/{any}', function($num) {
    echo 'User n°' . $num;
});
```

Wildcards
---------

[](#wildcards)

Les `wildcards` sont des snippets pour écrire les expressions régulières plus simplement.

- `{all}` Entre 0 et n caractères non obliques (`/`)
- `{any}` Entre 1 et n caractères non obliques (`/`)
- `{num}` Entre 1 et n caractères numériques
- `{hex}` Entre 1 et n caractères hexadécimaux
- `{uuid}` Un UUID tel que définit dans la RFC 4122

Ajouter un wildcard :

```
Router::getInstance()->wildcard('date', '[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}');
```

Execution d'une route
---------------------

[](#execution-dune-route)

```
$http_method = $_SERVER['REQUEST_METHOD'];
$uri = parse_url('http://dummy' . $_SERVER['REQUEST_URI'], PHP_URL_PATH);
Router::getInstance()->run($http_method, $uri)->execute();
```

Exception
=========

[](#exception)

Si une route n'est pas trouvée, ou que sa fonction de rappel n'est pas appelable, une erreur de type `\Pebble\Burn\RouteException` est déclenchée.

###  Health Score

41

—

FairBetter than 87% of packages

Maintenance68

Regular maintenance activity

Popularity17

Limited adoption so far

Community9

Small or concentrated contributor base

Maturity59

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 66.7% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~86 days

Recently: every ~106 days

Total

11

Last Release

190d ago

Major Versions

0.0.4 → 1.0.02024-10-17

### Community

Maintainers

![](https://www.gravatar.com/avatar/e5a5482c3c1b25e5c39c23177570691f1e625aa5c094dc5dce45284b90409910?d=identicon)[sopheos](/maintainers/sopheos)

---

Top Contributors

[![sugatasei](https://avatars.githubusercontent.com/u/6987162?v=4)](https://github.com/sugatasei "sugatasei (4 commits)")[![Lucas-Sopheos](https://avatars.githubusercontent.com/u/141317430?v=4)](https://github.com/Lucas-Sopheos "Lucas-Sopheos (2 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/sopheos-pebble-burn/health.svg)

```
[![Health](https://phpackages.com/badges/sopheos-pebble-burn/health.svg)](https://phpackages.com/packages/sopheos-pebble-burn)
```

###  Alternatives

[forxer/laravel-gravatar

A library providing easy gravatar integration in a Laravel project.

4238.0k1](/packages/forxer-laravel-gravatar)[webignition/internet-media-type

PHP model of an http://en.wikipedia.org/wiki/Internet\_media\_type

10149.1k13](/packages/webignition-internet-media-type)[practically/preloader

PHP preloading for PHP &gt;=7.4

1035.6k](/packages/practically-preloader)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
