PHPackages                             mapathe/core - 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. [Framework](/categories/framework)
4. /
5. mapathe/core

ActiveLibrary[Framework](/categories/framework)

mapathe/core
============

Dépendance Core contenant le cœur de l'application PHP (routes, base, services, etc.)

v1.0.0(11mo ago)01PHP

Since Jul 25Pushed 11mo agoCompare

[ Source](https://github.com/SNcodeur2001/dependence_core_php)[ Packagist](https://packagist.org/packages/mapathe/core)[ RSS](/packages/mapathe-core/feed)WikiDiscussions main Synced today

READMEChangelogDependenciesVersions (2)Used By (0)

Mapathe Core PHP - Documentation
================================

[](#mapathe-core-php---documentation)

Vue d'ensemble
--------------

[](#vue-densemble)

**Mapathe Core** est une bibliothèque PHP moderne qui fournit les composants fondamentaux pour développer des applications web avec injection de dépendances, routage et gestion de sessions.

Installation
------------

[](#installation)

```
composer require mapathe/core
```

Architecture
------------

[](#architecture)

### Container d'Injection de Dépendances

[](#container-dinjection-de-dépendances)

Le `Container` gère automatiquement les dépendances avec support des singletons.

```
$container = Container::getInstance();

// Lier une classe
$container->bind(Interface::class, Implementation::class);

// Singleton
$container->singleton(Service::class);

// Résoudre
$service = $container->resolve(Service::class);
```

### Application Principale

[](#application-principale)

La classe `App` centralise l'accès aux services.

```
// Initialiser l'application
App::initialize();

// Récupérer un service
$controller = App::get('CitoyenController');
$service = App::get(\App\Service\CitoyenService::class);
```

### Routage

[](#routage)

Le `Router` gère les routes avec support des paramètres et middlewares.

```
// Dans routes/route.web.php
return [
    [
        'method' => 'GET',
        'path' => '/users/{id}',
        'controller' => 'CitoyenController',
        'action' => 'show',
        'middlewares' => ['auth']
    ],
    [
        'method' => 'POST',
        'path' => '/login',
        'action' => function() {
            echo "Connexion";
        }
    ]
];

// Résoudre la route courante
Router::resolve();
```

### Configuration des Services

[](#configuration-des-services)

Les services sont configurés via `config/services.yml` :

```
services:
  repositories:
    CitoyenRepository:
      class: \App\Repository\CitoyenRepository
      singleton: true

  services:
    CitoyenService:
      class: \App\Service\CitoyenService
      singleton: true
      dependencies: ['CitoyenRepository']

  controllers:
    CitoyenController:
      class: \App\Controller\CitoyenController
      dependencies: ['CitoyenService']
```

Classes Abstraites
------------------

[](#classes-abstraites)

### AbstractController

[](#abstractcontroller)

Base pour tous les contrôleurs avec méthodes CRUD et réponses JSON.

```
class CitoyenController extends AbstractController
{
    public function index() {
        $data = ['users' => []];
        $this->renderJson($data, "success", 200, "Liste récupérée");
    }
}
```

### AbstractEntity

[](#abstractentity)

Base pour les entités avec sérialisation.

```
class User extends AbstractEntity
{
    public static function toObject(array $data): static {
        // Conversion array vers objet
    }

    public function toArray(): array {
        // Conversion objet vers array
    }
}
```

### AbstractRepository

[](#abstractrepository)

Base pour les repositories avec connexion PDO.

```
class UserRepository extends AbstractRepository
{
    public function findAll() {
        $stmt = $this->pdo->query("SELECT * FROM users");
        return $stmt->fetchAll();
    }
}
```

Gestion des Sessions
--------------------

[](#gestion-des-sessions)

```
$session = Session::getInstance();

$session->set('user', $userData);
$user = Session::get('user');
Session::requireAuth(); // Middleware auth
```

Base de Données
---------------

[](#base-de-données)

Configuration automatique via variables d'environnement :

```
DB_DRIVER=pgsql
DB_HOST=localhost
DB_PORT=5433
DB_NAME=pgdbDaf
DB_USER=pguserDaf
DB_PASSWORD=pgpassword
```

Middlewares Intégrés
--------------------

[](#middlewares-intégrés)

- **auth** : Vérifie l'authentification utilisateur
- **guest** : Redirige les utilisateurs connectés

Exemple Complet
---------------

[](#exemple-complet)

```
// Structure du projet
/src
  /core           # Classes du framework
  /config
    services.yml  # Configuration des services
/routes
  route.web.php   # Définition des routes

// Bootstrap
require 'vendor/autoload.php';
App::initialize();
Router::resolve();
```

Fonctionnalités Clés
--------------------

[](#fonctionnalités-clés)

✅ **Injection de dépendances** automatique
✅ **Routage** avec paramètres dynamiques
✅ **Middlewares** d'authentification
✅ **Sessions** sécurisées
✅ **ORM** simple avec PDO
✅ **Configuration** YAML
✅ **Réponses JSON** standardisées

Cette bibliothèque offre une base solide pour développer rapidement des applications PHP modernes avec une architecture propre et maintenable.

###  Health Score

25

—

LowBetter than 35% of packages

Maintenance51

Moderate activity, may be stable

Popularity1

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity36

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% 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

Unknown

Total

1

Last Release

343d ago

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/116581490?v=4)[Mapathé Ndiaye](/maintainers/SNcodeur2001)[@SNcodeur2001](https://github.com/SNcodeur2001)

---

Top Contributors

[![SNcodeur2001](https://avatars.githubusercontent.com/u/116581490?v=4)](https://github.com/SNcodeur2001 "SNcodeur2001 (4 commits)")

### Embed Badge

![Health badge](/badges/mapathe-core/health.svg)

```
[![Health](https://phpackages.com/badges/mapathe-core/health.svg)](https://phpackages.com/packages/mapathe-core)
```

###  Alternatives

[laravel/dusk

Laravel Dusk provides simple end-to-end testing and browser automation.

1.9k39.6M299](/packages/laravel-dusk)[nineinchnick/edatatables

Grid widget for the Yii Framework, wrapper for the DataTables jQuery plugin

173.2k](/packages/nineinchnick-edatatables)[link-cloud/fast-hyperf

LinkCloud Fast Hyperf

241.2k1](/packages/link-cloud-fast-hyperf)

PHPackages © 2026

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