laravel-named-route-binding maintained by umutcangungormus
Laravel Named Route Binding
Laravel'de route parametrelerini controller metodlarına isimlerine göre bağlayan bir paket. Artık parametre sırası önemli değil!
Problem
Laravel'de varsayılan olarak route parametreleri controller metodlarına sırasına göre geçirilir:
// routes/web.php
Route::get('/users/{user}/posts/{post}', [PostController::class, 'show']);
// PostController.php - Parametreler SIRAYLA gelmeli!
public function show($user, $post)
{
// $user = {user} route parametresi
// $post = {post} route parametresi
}
// ❌ Bu ÇALIŞMAZ! Sıra yanlış olduğu için $post'a user değeri gelir
public function show($post, $user)
{
// $post = {user} route parametresi (YANLIŞ!)
// $user = {post} route parametresi (YANLIŞ!)
}
Çözüm
Bu paket ile parametreler isimlerine göre eşleştirilir:
// routes/web.php
Route::get('/users/{user}/posts/{post}', [PostController::class, 'show']);
// PostController.php - Artık sıra önemli DEĞİL!
public function show($post, $user)
{
// ✅ $post = {post} route parametresi (İSİMLE EŞLEŞTİ!)
// ✅ $user = {user} route parametresi (İSİMLE EŞLEŞTİ!)
}
// İstediğiniz sırada yazabilirsiniz
public function show($user, $post) // ✅ Çalışır
public function show($post, $user) // ✅ Çalışır
Kurulum
Composer ile paketi yükleyin:
composer require umutcangungormus/laravel-named-route-binding
Paket otomatik olarak keşfedilir (Laravel 5.5+). Manuel kayıt gerekiyorsa:
// config/app.php
'providers' => [
// ...
UmutcanGungormus\NamedRouteBinding\NamedRouteBindingServiceProvider::class,
],
Yapılandırma (Opsiyonel)
Yapılandırma dosyasını yayınlayın:
php artisan vendor:publish --provider="UmutcanGungormus\NamedRouteBinding\NamedRouteBindingServiceProvider"
config/named-route-binding.php:
return [
// Özelliği etkinleştir/devre dışı bırak
'enabled' => env('NAMED_ROUTE_BINDING_ENABLED', true),
];
Özellikler
1. İsimle Eşleştirme
Route::get('/categories/{category}/products/{product}', [ProductController::class, 'show']);
// Her iki yazım da çalışır
public function show($category, $product) { }
public function show($product, $category) { }
2. Snake_case / CamelCase Desteği
Route parametresi user_id ise, metod parametresi userId veya user_id olabilir:
Route::get('/users/{user_id}', [UserController::class, 'show']);
// Her ikisi de çalışır
public function show($user_id) { }
public function show($userId) { }
3. Dependency Injection Desteği
Request ve diğer bağımlılıklar otomatik enjekte edilir:
Route::get('/users/{user}', [UserController::class, 'show']);
public function show(Request $request, $user)
{
// $request otomatik enjekte edilir
// $user route parametresinden gelir
}
// Sıra değiştirilebilir
public function show($user, Request $request) { }
4. Varsayılan Değerler
Route::get('/posts/{post}', [PostController::class, 'show']);
public function show($post, $format = 'json')
{
// $format varsayılan değeri kullanır
}
5. Nullable Parametreler
public function show($post, ?string $optional)
{
// $optional null olur eğer route'da yoksa
}
Route Model Binding ile Kullanım
Laravel'in Route Model Binding özelliği ile tam uyumludur:
Route::get('/users/{user}/posts/{post}', [PostController::class, 'show']);
// Type-hinted modeller otomatik çözümlenir
public function show(Post $post, User $user)
{
// $post ve $user model instance'ları olarak gelir
}
Gerçek Dünya Örnekleri
Örnek 1: E-ticaret
// routes/web.php
Route::get('/shops/{shop}/categories/{category}/products/{product}', [ProductController::class, 'show']);
// ProductController.php - İstediğiniz sırada
public function show(
Request $request,
Product $product, // 3. route parametresi
Category $category, // 2. route parametresi
Shop $shop // 1. route parametresi
) {
// Hepsi doğru şekilde eşleşir!
}
Örnek 2: API Resource
// routes/api.php
Route::get('/teams/{team}/members/{member}/tasks/{task}', [TaskController::class, 'show']);
// TaskController.php
public function show(Task $task, Member $member, Team $team)
{
$this->authorize('view', [$task, $team]);
return new TaskResource($task);
}
Test
composer test
Katkıda Bulunma
Pull request'ler memnuniyetle karşılanır!
Lisans
MIT Lisansı. Detaylar için LICENSE dosyasına bakın.
🇬🇧 English Version
A Laravel package that binds route parameters to controller method arguments by name instead of by order. Parameter order no longer matters!
The Problem
By default in Laravel, route parameters are passed to controller methods in order:
// routes/web.php
Route::get('/users/{user}/posts/{post}', [PostController::class, 'show']);
// PostController.php - Parameters must be IN ORDER!
public function show($user, $post)
{
// $user = {user} route parameter
// $post = {post} route parameter
}
// ❌ This DOESN'T WORK! Wrong order means $post gets user value
public function show($post, $user)
{
// $post = {user} route parameter (WRONG!)
// $user = {post} route parameter (WRONG!)
}
The Solution
With this package, parameters are matched by name:
// routes/web.php
Route::get('/users/{user}/posts/{post}', [PostController::class, 'show']);
// PostController.php - Order NO LONGER matters!
public function show($post, $user)
{
// ✅ $post = {post} route parameter (MATCHED BY NAME!)
// ✅ $user = {user} route parameter (MATCHED BY NAME!)
}
// Write them in any order you want
public function show($user, $post) // ✅ Works
public function show($post, $user) // ✅ Works
Installation
Install the package via Composer:
composer require umutcangungormus/laravel-named-route-binding
The package will be auto-discovered (Laravel 5.5+). For manual registration:
// config/app.php
'providers' => [
// ...
UmutcanGungormus\NamedRouteBinding\NamedRouteBindingServiceProvider::class,
],
Configuration (Optional)
Publish the configuration file:
php artisan vendor:publish --provider="UmutcanGungormus\NamedRouteBinding\NamedRouteBindingServiceProvider"
config/named-route-binding.php:
return [
// Enable/disable the feature
'enabled' => env('NAMED_ROUTE_BINDING_ENABLED', true),
];
Features
1. Name-Based Matching
Route::get('/categories/{category}/products/{product}', [ProductController::class, 'show']);
// Both work
public function show($category, $product) { }
public function show($product, $category) { }
2. Snake_case / CamelCase Support
If route parameter is user_id, method parameter can be userId or user_id:
Route::get('/users/{user_id}', [UserController::class, 'show']);
// Both work
public function show($user_id) { }
public function show($userId) { }
3. Dependency Injection Support
Request and other dependencies are automatically injected:
Route::get('/users/{user}', [UserController::class, 'show']);
public function show(Request $request, $user)
{
// $request is auto-injected
// $user comes from route parameter
}
// Order can be changed
public function show($user, Request $request) { }
4. Default Values
Route::get('/posts/{post}', [PostController::class, 'show']);
public function show($post, $format = 'json')
{
// $format uses default value
}
5. Nullable Parameters
public function show($post, ?string $optional)
{
// $optional is null if not in route
}
Usage with Route Model Binding
Fully compatible with Laravel's Route Model Binding:
Route::get('/users/{user}/posts/{post}', [PostController::class, 'show']);
// Type-hinted models are automatically resolved
public function show(Post $post, User $user)
{
// $post and $user come as model instances
}
Real World Examples
Example 1: E-commerce
// routes/web.php
Route::get('/shops/{shop}/categories/{category}/products/{product}', [ProductController::class, 'show']);
// ProductController.php - Any order you want
public function show(
Request $request,
Product $product, // 3rd route parameter
Category $category, // 2nd route parameter
Shop $shop // 1st route parameter
) {
// All matched correctly!
}
Example 2: API Resource
// routes/api.php
Route::get('/teams/{team}/members/{member}/tasks/{task}', [TaskController::class, 'show']);
// TaskController.php
public function show(Task $task, Member $member, Team $team)
{
$this->authorize('view', [$task, $team]);
return new TaskResource($task);
}
Testing
composer test
Contributing
Pull requests are welcome!
License
MIT License. See LICENSE for details.