A Laravel practice development package, ready to use out of the box. It simplifies handling responses, filters, services, and exception management.
caleb/laravel-practice is a Laravel package for a laravel practice development package, ready to use out of the box. it simplifies handling responses, filters, services, and exception management..
It currently has 0 GitHub stars and 35 downloads on Packagist (latest version v1.0.0).
Install it with composer require caleb/laravel-practice.
Discover more Laravel packages by caleb
or browse all Laravel packages to compare alternatives.
Last updated
A Laravel practice development package, ready to use out of the box. It simplifies handling responses, filters, services, and exception management.
Install the package via Composer:
composer require caleb/laravel-practice
The package will automatically register its service provider.
php artisan vendor:publish --tag=practice-lang
php artisan vendor:publish --tag=practice-stubs
Use the Response trait in your controllers to standardize API responses:
<?php
namespace App\Http\Controllers;
use Caleb\Practice\Response;
use Illuminate\Http\Controller;
class UserController extends Controller
{
use Response;
public function index()
{
$users = User::all();
return $this->success($users);
}
public function store(Request $request)
{
try {
$user = User::create($request->validated());
return $this->success($user);
} catch (Exception $e) {
return $this->error('Failed to create user', 422);
}
}
}
Response format:
{
"code": 200,
"msg": "success",
"data": {...},
"request_id": "uuid-string"
}
Create a filter class:
php artisan practice:make:filter UserFilter
Define your filter:
<?php
namespace App\Filters;
use Caleb\Practice\QueryFilter;
class UserFilter extends QueryFilter
{
public function name($name)
{
$this->query->where('name', 'like', "%{$name}%");
}
public function email($email)
{
$this->query->where('email', $email);
}
}
Use in your model:
<?php
namespace App\Models;
use Caleb\Practice\Standardization;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
use Standardization;
}
Apply filters in controller:
public function index(UserFilter $filter)
{
$users = User::filter($filter)->paginate();
return $this->success($users);
}
Create a service class:
php artisan practice:make:service UserService
Define your service:
<?php
namespace App\Services;
use Caleb\Practice\Service;
use App\Models\User;
class UserService extends Service
{
public function createUser(array $data)
{
if (User::where('email', $data['email'])->exists()) {
$this->throwAppException('Email already exists', 422);
}
return User::create($data);
}
public function getUserById(int $id)
{
$user = User::find($id);
if (!$user) {
$this->throwAppException('User not found', 404);
}
return $user;
}
}
Use in controller:
public function store(Request $request)
{
$user = UserService::instance()->createUser($request->validated());
return $this->success($user);
}
Use the Standardization trait in your models:
<?php
namespace App\Models;
use Caleb\Practice\Standardization;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
use Standardization;
protected $casts = [
'settings' => 'array',
'created_at' => 'datetime',
];
}
Benefits:
JSON_UNESCAPED_UNICODE flagper_page from request parametersfilter scope for query filteringThe package provides automatic exception handling with localized messages:
Custom exceptions:
// Application exceptions (logged as DEBUG level)
$this->throwAppException('Custom error message', 422, $additionalData);
// External service exceptions (logged normally)
$this->throwExternalAppException('External service error', 503);
The package automatically adds a unique request ID to each request context and includes it in all responses. This helps with request tracking and debugging.
The package automatically registers the AddContext middleware which:
The package supports multiple languages. Currently included:
English (en):
Chinese (zh-CN):
You can publish and customize these messages:
php artisan vendor:publish --tag=practice-lang
Contributions are welcome! Please feel free to submit a Pull Request.
This package is open-sourced software licensed under the MIT license.