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:

  • cannot upload mp4 file manager in laravel 8 error 'invalid JSON response from server' 0enter image description hereit's already working max size 5M. i want to mp4 upload file manager in laravel 8. file size max 350M. i cannot uplo… Read More
  • Laravel Custom Facade New Instance  AnswersSorted by:                           &nbs… Read More
  • Create a function that can be used by other functions AnswerSorted by:                             … Read More
  • File encryption in Laravel and sudo users 0I understand I can encrypt and store the contents of files (csv mainly) using the techniques explained here and here.However, I … Read More
  • vlaue of checkbox to database in vue laravel 0i have this input:<div class="d-flex justify-content-between align-items-center"> <label for="patymentTerms">Payment Terms</labe… Read More
Newer Post Older Post Home

0 comments:

Post a Comment

Thanks

Meta

Popular Posts

  • Spring boot app (error: method getFirst()) failed to run at local machine, but can run on server
    The Spring boot app can run on the online server. Now, we want to replicate the same app at the local machine but the Spring boot jar file f...
  • Log activity in a Laravel app with Spatie/Laravel-Activitylog
      Requirements This package needs PHP 8.1+ and Laravel 9.0 or higher. The latest version of this package needs PHP 8.2+ and Laravel 8 or hig...
  • Failed to install 'cordova-plugin-firebase': CordovaError: Uh oh
    I had follow these steps to install an configure firebase to my cordova project for cloud messaging. https://medium.com/@felipepucinelli/how...
  • Laravel auth login with phone or email
          <?php     Laravel auth login with phone or email     <? php     namespace App \ Http \ Controllers \ Auth ;         use ...
  • Cashier package and Blade files
    I'm a little confused about this Cashier package. I installed it using the Laravel website (with composer), but noticed there's no...

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

  • Improved Installation and Frontend Hooks in Laravel Echo 2.1 - 5/15/2025
  • Filter Model Attributes with Laravel's New except() Method - 5/13/2025
  • Arr::from() Method in Laravel 12.14 - 5/14/2025
  • Streamline API Resources with Laravel's Fluent Methods - 5/13/2025
  • Customize URL Handling with Laravel's Macroable URI Class - 5/13/2025

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