g4t/easyroute

Modern Laravel 13 routing using PHP 8 attributes with auto-generation, nested controller support, and native route caching.

Maintainers

Package info

github.com/hussein4alaa/laravel-g4t-easy-route

pkg:composer/g4t/easyroute

Statistics

Installs: 3

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

0.0.2 2026-03-23 22:45 UTC

This package is auto-updated.

Last update: 2026-04-09 19:24:33 UTC


README

EasyRoute Logo

🌟 Laravel 13 G4T easyRoute Attributes

A Laravel 13 package that lets you define routes using PHP 8 attributes with full support for Controller-level routes, Method-level routes, middleware, subfolders, and caching via Laravel’s routes-v7.php.

EasyRoute Features Banner

πŸš€ Features

  • Controller-level route attributes (#[Route(uri: 'users')])
  • Method-level route attributes (#[Get], #[Post], #[Put], #[Patch], #[Delete], #[Any])
  • Auto route generation using method names or onController option
  • Middleware support (controller-level + method-level)
  • Nested folder support for controllers
  • Route caching using Laravel compiled routes (bootstrap/cache/routes-v7.php)
  • Configurable Controllers paths

βš™οΈ Installation

Install via Composer:

composer require g4t/easyroute

Publish config:

php artisan vendor:publish --provider "G4T\EaseRoute\EaseRouteServiceProvider"

This creates config/route-attribute.php:

return [
    'controllers_path' => [app_path('Http/Controllers')],
    'cache' => true,
];

πŸ“ Usage Controller-level Route

<?php

namespace App\Http\Controllers;

use G4T\EaseRoute\Attributes\Route;
use G4T\EaseRoute\Attributes\Get;
use G4T\EaseRoute\Attributes\Post;

#[Route(uri: 'users', middleware: ['auth'])]
class UserController extends Controller
{
    #[Get]
    public function index()
    {
        return "List of users";
    }

    #[Get(onController: true)]
    public function show($id)
    {
        return "User: $id";
    }

    #[Post('create')]
    public function store()
    {
        return "Create user";
    }
}

Supported HTTP Methods

Attribute HTTP Method
#[Get] GET
#[Post] POST
#[Put] PUT
#[Patch] PATCH
#[Delete] DELETE
#[Any] Any method

⚑ Route Caching

To improve performance, EasyRoute can use Laravel compiled routes instead of scanning controllers for every request.

Workflow Diagram

Steps:

  1. Ensure cache is enabled in config/route-attribute.php:
'cache' => true
  1. Run the caching command:
php artisan route:cache

βš™οΈ Configuration

return [
    'controllers_path' => [app_path('Http/Controllers')],
    'cache' => true,
];
  • controllers_path β†’ Array of paths where your controllers reside
  • cache β†’ Use cached routes from routes-v7.php

πŸ“ Notes Supports nested folders in controllers_path.

Use onController: true to auto-generate URI based on Controller and Method names.

Middleware is merged: controller-level + method-level.

Fully compatible with Laravel 13 attributes syntax.

GET      users                          UserController@index
GET      user/show/{id}                 UserController@show
POST     users/create                    UserController@store
app/
β”œβ”€ Http/
β”‚  β”œβ”€ Controllers/
β”‚  β”‚  β”œβ”€ UserController.php
β”‚  β”‚  └─ Admin/
β”‚  β”‚     └─ AdminController.php
bootstrap/
└─ cache/
   └─ routes-v7.php
config/
└─ route-attribute.php

βœ… Notes for Developers

  • Place your controllers inside controllers_path
  • Add #[Route(...)] at the class level
  • Add #[Get], #[Post], etc. at method level
  • Use onController: true for automatic route naming Run php artisan route:cache to generate cached routes

EasyRoute makes your Laravel 13 routing modern, clean, and high-performance.