CoderFunda
  • Home
  • About us
    • Contact Us
    • Disclaimer
    • Privacy Policy
    • About us
  • Home
  • Php
  • HTML
  • CSS
  • JavaScript
    • JavaScript
    • Jquery
    • JqueryUI
    • Stock
  • SQL
  • Vue.Js
  • Python
  • Wordpress
  • C++
    • C++
    • C
  • Laravel
    • Laravel
      • Overview
      • Namespaces
      • Middleware
      • Routing
      • Configuration
      • Application Structure
      • Installation
    • Overview
  • DBMS
    • DBMS
      • PL/SQL
      • SQLite
      • MongoDB
      • Cassandra
      • MySQL
      • Oracle
      • CouchDB
      • Neo4j
      • DB2
      • Quiz
    • Overview
  • Entertainment
    • TV Series Update
    • Movie Review
    • Movie Review
  • More
    • Vue. Js
    • Php Question
    • Php Interview Question
    • Laravel Interview Question
    • SQL Interview Question
    • IAS Interview Question
    • PCS Interview Question
    • Technology
    • Other

25 August, 2022

Using Route Registrars in your Laravel application

 Programing Coderfunda     August 25, 2022     Laravel, Laravel Tutorials     No comments   

 Recently I came across a unique approach to loading routes into Laravel applications, and I wanted to share this with you. It allows you to create Route Registrars classes you register your routes within. I saw this in a package currently being developed by Ollie Read, and it caught my attention as a clean and exciting way to register routes.

The changes required to your standard Laravel application are relatively simple. We make a few changes to the Route Service Provider - and remove the web and API route files. The first thing we do is create a new trait/concern that we can add to our app/Providers/RouteServiceProvider called MapRouteRegistrars. Add the following code to this new trait/concern.

1declare(strict_types=1);
2 
3namespace App\Routing\Concerns;
4 
5use App\Routing\Contracts\RouteRegistrar;
6use Illuminate\Contracts\Routing\Registrar;
7use RuntimeException;
8 
9trait MapRouteRegistrars
10{
11 protected function mapRoutes(Registrar $router, array $registrars): void
12 {
13 foreach ($registrars as $registrar) {
14 if (! class_exists($registrar) || ! is_subclass_of($registrar, RouteRegistrar::class)) {
15 throw new RuntimeException(sprintf(
16 'Cannot map routes \'%s\', it is not a valid routes class',
17 $registrar
18 ));
19 }
20 
21 (new $registrar)->map($router);
22 }
23 }
24}

As you can see, we also need to create an interface/contract to use and ensure all of our Registrars implement it. Create this under app/Routing/Contracts/RouteRegistrar and add the following code.

1declare(strict_types=1);
2 
3namespace App\Routing\Contracts;
4 
5use Illuminate\Contracts\Routing\Registrar;
6 
7interface RouteRegistrar
8{
9 public function map(Registrar $registrar): void;
10}

Now that we have the trait and interface in place, we can look at the changes we need to make to the default Route Service Provider.

1declare(strict_types=1);
2 
3namespace App\Providers;
4 
5use App\Routing\Concerns\MapsRouteRegistrars;
6use Illuminate\Contracts\Routing\Registrar;
7use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
8 
9class RouteServiceProvider extends ServiceProvider
10{
11 use MapsRouteRegistrars;
12 
13 protected array $registrars = [];
14 
15 public function boot(): void
16 {
17 $this->routes(function (Registrar $router) {
18 $this->mapRoutes($router, $this->registrars);
19 });
20 }
21}

From the above code, you can see that we have added a new property to our route service provider. This property is where the application's route registrars are registered and loaded inside the boot method.

Now that we have got our application ready to use route registrars instead of route files, let's create a default one for our application. This approach would work exceptionally well in a domain-driven design or modular system - allowing each domain or module to register its routes. For this example, we will keep this simple so that you can understand the approach. Create a new route registrar in app/Routing/Registrars/DefaultRegistrar.php and add the following code.

1declare(strict_types=1);
2 
3namespace App\Routing\Registrars;
4 
5use App\Routing\Contracts\RouteRegistrar;
6 
7class DefaultRegistrar implements RouteRegistrar
8{
9 public function map(Registrar $registrar): void
10 {
11 $registrar->view('/', 'welcome');
12 }
13}

Now that our default registrar is created, we can register this inside our Route Service Provider, ensuring it is loaded.

1declare(strict_types=1);
2 
3namespace App\Providers;
4 
5use App\Routing\Concerns\MapsRouteRegistrars;
6use App\Routing\Registrars\DefaultRegistrar;
7use Illuminate\Contracts\Routing\Registrar;
8use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
9 
10class RouteServiceProvider extends ServiceProvider
11{
12 use MapsRouteRegistrars;
13 
14 protected array $registrars = [
15 DefaultRegistrar::class,
16 ];
17 
18 public function boot(): void
19 {
20 $this->routes(function (Registrar $router) {
21 $this->mapRoutes($router, $this->registrars);
22 });
23 }
24}

Now, if you visit /, you will be loaded with the welcome view, which means that everything is all hooked up correctly. I can imagine a great way that I might utilize this in an application of mine, where I have static marketing routes, blog routes, admin routes, and more. As an example, I would imagine the route service provider looking like the following:

1declare(strict_types=1);
2 
3namespace App\Providers;
4 
5use App\Routing\Concerns\MapsRouteRegistrars;
6use App\Routing\Registrars\AdminRegistrar;
7use App\Routing\Registrars\BlogRegistrar;
8use App\Routing\Registrars\MarketingRegistrar;
9use Illuminate\Contracts\Routing\Registrar;
10use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
11 
12class RouteServiceProvider extends ServiceProvider
13{
14 use MapsRouteRegistrars;
15 
16 protected array $registrars = [
17 MarketingRegistrar::class, // Marketing Routes
18 BlogRegistrar::class, // Blog Routes
19 AdminRegistrar::class, // Admin Routes
20 ];
21 
22 public function boot(): void
23 {
24 $this->routes(function (Registrar $router) {
25 $this->mapRoutes($router, $this->registrars);
26 });
27 }
28}

Splitting our routes like this is a great way to move from a standard PHP routes file to a class-based routing system allowing for better encapsulation with your application or domain.

What other ways have you found to help you manage a growing application? Especially from a routing perspective, they can get a little unruly after a while. Let us know on Twitter.

  • Share This:  
  •  Facebook
  •  Twitter
  •  Google+
  •  Stumble
  •  Digg
Email ThisBlogThis!Share to XShare to Facebook

Related Posts:

  • How to get a Websites Favicons in Laravel There may be times in your Laravel applications where you want to display a favicon from another website. For example, you could have a link to … Read More
  • Laravel Jetstream: Add CRUD with Spatie Permission Laravel Jetstream is a starter kit that helps you not only with Auth scaffolding but with extra functionality like Teams or Two-Factor Authentic… Read More
  • Restructuring a Laravel Controller using Services, Events, Jobs, Actions, and more One of the top Laravel questions I hear is "How to structure the project". If we narrow it down, the largest part of it sounds like "If the logi… Read More
Newer Post Older Post Home

0 comments:

Post a Comment

Thanks

Meta

Popular Posts

  • Write API Integrations in Laravel and PHP Projects with Saloon
    Write API Integrations in Laravel and PHP Projects with Saloon Saloon  is a Laravel/PHP package that allows you to write your API integratio...
  • Features CodeIgniter
    Features CodeIgniter There is a great demand for the CodeIgniter framework in PHP developers because of its features and multiple advan...
  • Laravel Breeze with PrimeVue v4
    This is an follow up to my previous post about a "starter kit" I created with Laravel and PrimeVue components. The project has b...
  • Credit card validation in laravel
      Validation rules for credit card using laravel-validation-rules/credit-card package in laravel Install package laravel-validation-rules/cr...
  • Fast Excel Package for Laravel
      Fast Excel is a Laravel package for importing and exporting spreadsheets. It provides an elegant wrapper around Spout —a PHP package to ...

Categories

  • Ajax (26)
  • Bootstrap (30)
  • DBMS (42)
  • HTML (12)
  • HTML5 (45)
  • JavaScript (10)
  • Jquery (34)
  • Jquery UI (2)
  • JqueryUI (32)
  • Laravel (1017)
  • Laravel Tutorials (23)
  • Laravel-Question (6)
  • Magento (9)
  • Magento 2 (95)
  • MariaDB (1)
  • MySql Tutorial (2)
  • PHP-Interview-Questions (3)
  • Php Question (13)
  • Python (36)
  • RDBMS (13)
  • SQL Tutorial (79)
  • Vue.js Tutorial (68)
  • Wordpress (150)
  • Wordpress Theme (3)
  • codeigniter (108)
  • oops (4)
  • php (853)

Social Media Links

  • Follow on Twitter
  • Like on Facebook
  • Subscribe on Youtube
  • Follow on Instagram

Pages

  • Home
  • Contact Us
  • Privacy Policy
  • About us

Blog Archive

  • September (100)
  • August (50)
  • July (56)
  • June (46)
  • May (59)
  • April (50)
  • March (60)
  • February (42)
  • January (53)
  • December (58)
  • November (61)
  • October (39)
  • September (36)
  • August (36)
  • July (34)
  • June (34)
  • May (36)
  • April (29)
  • March (82)
  • February (1)
  • January (8)
  • December (14)
  • November (41)
  • October (13)
  • September (5)
  • August (48)
  • July (9)
  • June (6)
  • May (119)
  • April (259)
  • March (122)
  • February (368)
  • January (33)
  • October (2)
  • July (11)
  • June (29)
  • May (25)
  • April (168)
  • March (93)
  • February (60)
  • January (28)
  • December (195)
  • November (24)
  • October (40)
  • September (55)
  • August (6)
  • July (48)
  • May (2)
  • January (2)
  • July (6)
  • June (6)
  • February (17)
  • January (69)
  • December (122)
  • November (56)
  • October (92)
  • September (76)
  • August (6)

  • Failed to install 'cordova-plugin-firebase': CordovaError: Uh oh - 9/21/2024
  • pyspark XPath Query Returns Lists Omitting Missing Values Instead of Including None - 9/20/2024
  • SQL REPL from within Python/Sqlalchemy/Psychopg2 - 9/20/2024
  • MySql Explain with Tobias Petry - 9/20/2024
  • How to combine information from different devices into one common abstract virtual disk? [closed] - 9/20/2024

Laravel News

  • Lightning Fast Schedule Management for Laravel - 6/20/2025
  • Reset Rate Limits Dynamically with Laravel's clear Method - 6/18/2025
  • Manipulate Image URLs in Laravel with the Image Transform Package - 6/19/2025
  • Handle Nested Arrays Elegantly with Laravel's fluent() Helper - 6/18/2025
  • Laravel 12.19 Adds a useEloquentBuilder Attribute, a FailOnException Queue Middleware, and More - 6/18/2025

Copyright © 2025 CoderFunda | Powered by Blogger
Design by Coderfunda | Blogger Theme by Coderfunda | Distributed By Coderfunda