jerrydepredator/laravel-predator-api-utils
最新稳定版本:v0.0.9
Composer 安装命令:
composer require jerrydepredator/laravel-predator-api-utils
包简介
A collection of utility classes and traits to streamline common Laravel development tasks, including error handling, paginated responses, data handling, middleware creation, a base repository for advanced filtering, keyset pagination, base query filtering, and more. This package aims to reduce boile
README 文档
README
This package provides a collection of utility classes and traits to streamline common Laravel development tasks, such as:
- Error Handling: Easily handle and format API errors.
- Paginated Responses: Create paginated responses with consistent structure.
- Data Handling: Simplify data manipulation and extraction.
- Middleware: Implement custom middleware for authentication, authorization, and other cross-cutting concerns.
- Repository Pattern: Provides a base repository class for common database operations.
⚠️⚠️ Disclaimer ⚠️⚠️
This package aims to reduce boilerplate code often encountered in "MY LARAVEL PROJECTS" by providing reusable components. It was created based on my personal preferences and may not be suitable for all projects or development styles. It is not intended to be a comprehensive solution for all Laravel development needs and may require customization for specific requirements.
Installation
-
Install via Composer:
composer require jerrydepredator/laravel-predator-api-utils
-
Publish Configuration (Optional):
-
If you want to customize the default property names for the
DecryptedJWTokenservice, publish the configuration file:php artisan vendor:publish --provider="LaravelPredatorApiUtils\ServiceProvider" --tag="config"
-
This will create a
config/decrypted_jwt_token.phpfile in your project where you can modify the property names.
-
Usage
1. DecryptedJWTToken Service:
-
Location:
src/Services/DecryptedJWToken.php -
Purpose: Provides methods to access data from a decrypted JWT token.
-
Usage:
use LaravelPredatorApiUtils\Services\DecryptedJWToken; // In your controller public function showProfile(Request $request, DecryptedJWToken $decryptedJWToken) { $userId = $decryptedJWToken->getUserId(); $userName = $decryptedJWToken->getUserName(); $userData = $decryptedJWToken->getData(); // Get all user data // ... your logic using user data }
2. Middlewares:
-
DecryptJWToken:
- Location:
src/Middlewares/DecryptJWToken.php - Purpose: Decrypts the JWT token from the
Authorizationheader and adds the decrypted data to the request object. - Usage:
-
Register the middleware in
app/Http/Kernel.php:protected $routeMiddleware = [ // ... other middleware 'decrypt_jwt' => \App\Http\Middleware\DecryptJWToken::class, ];
-
Apply the middleware to routes:
Route::get('/protected-route', [MyController::class, 'showData'])->middleware('decrypt_jwt');
-
- Location:
-
RoleMiddleware:
- Location:
src/Middlewares/RoleMiddleware.php - Purpose: Restricts access to routes based on user roles.
- Usage:
-
Register the middleware in
app/Http/Kernel.php:protected $routeMiddleware = [ // ... other middleware 'role' => \App\Http\Middleware\RoleMiddleware::class, ];
-
Apply the middleware to routes:
Route::get('/admin', [AdminController::class, 'index'])->middleware('role:admin');
-
- Location:
3. Traits:
-
ApiResponse:
- Location:
src/Traits/ApiResponse.php - Purpose: Provides helper methods for creating API responses with standardized structures.
- Location:
-
HandlesErrors:
- Location:
src/Traits/HandlesErrors.php - Purpose: Provides helper methods for handling and formatting API errors.
- Location:
-
PaginationRules:
- Location:
src/Traits/PaginationRules.php - Purpose: Provides rules for validating pagination parameters.
- Location:
4. Repositories:
- BaseRepository:
- Location:
src/Repositories/BaseRepository.php - Purpose: Provides a base class for implementing repositories with common database operations.
- Location:
Configuration:
decrypted_jwt_token.php:- Located in the
configdirectory. - Defines default property names for the
DecryptedJWTokenservice. - Can be customized to match your specific JWT token structure.
- Located in the
Contributing
Contributions are welcome! Please submit pull requests to the project's GitHub repository.
License
This package is licensed under the MIT License.
统计信息
- 总下载量: 86
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2024-12-23