Laravel framework mastery - Eloquent, Blade, APIs, queues, and Laravel 11.x ecosystem
Provides expert guidance for Laravel 10.x-11.x development, covering Eloquent, APIs, queues, and Blade. Activates when you need help with specific Laravel topics like ORM relationships, API resources, or queue management.
/plugin marketplace add pluginagentmarketplace/custom-plugin-php/plugin install php-assistant@pluginagentmarketplace-phpThis skill inherits all available tools. When active, it can use any tool Claude has access to.
assets/config.yamlassets/schema.jsonreferences/GUIDE.mdreferences/PATTERNS.mdscripts/validate.pyAtomic skill for mastering Laravel application development
Comprehensive skill for building production-ready Laravel applications. Covers Laravel 10.x-11.x with focus on Eloquent ORM, Blade templating, API development, and queues.
interface SkillParams {
topic:
| "eloquent" // ORM, relationships, queries
| "routing" // Routes, middleware, controllers
| "blade" // Templates, components, layouts
| "authentication" // Sanctum, Passport, Fortify
| "queues" // Jobs, workers, Horizon
| "testing" // Feature tests, factories
| "api"; // API resources, versioning
level: "beginner" | "intermediate" | "advanced";
laravel_version?: "10" | "11";
stack?: "livewire" | "inertia-vue" | "inertia-react" | "blade-only";
}
validation:
topic:
required: true
allowed: [eloquent, routing, blade, authentication, queues, testing, api]
level:
required: true
laravel_version:
default: "11"
beginner:
- Model basics and conventions
- CRUD operations
- Basic relationships
intermediate:
- Advanced relationships (morphTo, hasManyThrough)
- Eager loading and N+1 prevention
- Query scopes
advanced:
- Custom casts and accessors
- Performance optimization
- Database transactions
exercises:
- Build blog with posts, comments, tags
- Implement soft deletes
- Create polymorphic media system
beginner:
- API routes and controllers
- JSON responses
- Basic authentication (Sanctum)
intermediate:
- API Resources and Collections
- Pagination and filtering
- Rate limiting
advanced:
- OAuth with Passport
- API versioning patterns
- OpenAPI documentation
beginner:
- Job basics and dispatching
- Queue connections
- Failed jobs handling
intermediate:
- Job chaining and batching
- Horizon monitoring
advanced:
- Custom queue drivers
- Saga patterns
graph TD
A[Skill Invoked] --> B{Validate Params}
B -->|Invalid| C[Return Error]
B -->|Valid| D{Check Laravel Version}
D --> E[Load Version-Specific Content]
E --> F{Topic Router}
F --> G[Generate Examples + Exercises]
errors:
VERSION_INCOMPATIBLE:
code: "LARAVEL_001"
recovery: "Suggest upgrade or alternative"
PACKAGE_MISSING:
code: "LARAVEL_002"
recovery: "Provide composer require command"
retry:
max_attempts: 3
backoff:
type: exponential
initial_delay_ms: 100
<?php
declare(strict_types=1);
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\HasMany;
final class Post extends Model
{
use HasFactory;
protected $fillable = ['title', 'slug', 'content', 'author_id'];
protected function casts(): array
{
return [
'published_at' => 'datetime',
];
}
public function author(): BelongsTo
{
return $this->belongsTo(User::class, 'author_id');
}
public function comments(): HasMany
{
return $this->hasMany(Comment::class);
}
public function scopePublished($query)
{
return $query->whereNotNull('published_at');
}
}
<?php
declare(strict_types=1);
namespace App\Http\Controllers\Api\V1;
use App\Http\Controllers\Controller;
use App\Http\Resources\PostResource;
use App\Models\Post;
use Illuminate\Http\Response;
final class PostController extends Controller
{
public function index()
{
return PostResource::collection(
Post::with(['author'])->paginate(15)
);
}
public function store(StorePostRequest $request)
{
$post = Post::create($request->validated());
return (new PostResource($post))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
}
<?php
declare(strict_types=1);
namespace App\Jobs;
use App\Models\User;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\Middleware\WithoutOverlapping;
final class SendWelcomeEmail implements ShouldQueue
{
use Queueable, InteractsWithQueue;
public int $tries = 3;
public int $backoff = 60;
public function __construct(
public readonly User $user,
) {}
public function middleware(): array
{
return [new WithoutOverlapping($this->user->id)];
}
public function handle(): void
{
$this->user->notify(new WelcomeNotification());
}
}
<?php
declare(strict_types=1);
namespace Tests\Feature\Api;
use App\Models\Post;
use App\Models\User;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Laravel\Sanctum\Sanctum;
use Tests\TestCase;
final class PostApiTest extends TestCase
{
use RefreshDatabase;
public function test_can_list_posts(): void
{
Post::factory()->count(5)->create();
$this->getJson('/api/v1/posts')
->assertOk()
->assertJsonCount(5, 'data');
}
public function test_authenticated_user_can_create(): void
{
Sanctum::actingAs(User::factory()->create());
$this->postJson('/api/v1/posts', ['title' => 'Test'])
->assertCreated();
}
}
| Problem | Solution |
|---|---|
| N+1 queries | Use with() for eager loading |
| Queue jobs stuck | Check QUEUE_CONNECTION, run queue:work |
| Route not found | Run route:clear, check middleware |
| Metric | Target |
|---|---|
| Code accuracy | 100% |
| Laravel conventions | 100% |
| N+1 prevention | 100% |
Skill("php-laravel", {topic: "eloquent", level: "intermediate"})
This skill should be used when the user asks to "create a slash command", "add a command", "write a custom command", "define command arguments", "use command frontmatter", "organize commands", "create command with file references", "interactive command", "use AskUserQuestion in command", or needs guidance on slash command structure, YAML frontmatter fields, dynamic arguments, bash execution in commands, user interaction patterns, or command development best practices for Claude Code.
This skill should be used when the user asks to "create an agent", "add an agent", "write a subagent", "agent frontmatter", "when to use description", "agent examples", "agent tools", "agent colors", "autonomous agent", or needs guidance on agent structure, system prompts, triggering conditions, or agent development best practices for Claude Code plugins.
This skill should be used when the user asks to "create a hook", "add a PreToolUse/PostToolUse/Stop hook", "validate tool use", "implement prompt-based hooks", "use ${CLAUDE_PLUGIN_ROOT}", "set up event-driven automation", "block dangerous commands", or mentions hook events (PreToolUse, PostToolUse, Stop, SubagentStop, SessionStart, SessionEnd, UserPromptSubmit, PreCompact, Notification). Provides comprehensive guidance for creating and implementing Claude Code plugin hooks with focus on advanced prompt-based hooks API.