lpmatrix / postman-generator
Laravel package that automatically generates a Postman collection from Laravel routes
Requires
- php: ^7.4|^8.0|^8.1|^8.2|^8.3
- illuminate/support: 6.0|^7.0|^8.0|^9.0|^10.0|^11.0
Requires (Dev)
- orchestra/testbench: ^6.0
- phpunit/phpunit: ^9.0
This package is auto-updated.
Last update: 2025-04-04 00:55:01 UTC
README
A Laravel package that automatically generates a Postman collection from your Laravel routes, including support for route groups, authentication settings, and customization options.
Features
- Automatic generation of Postman Collection v2.1 from Laravel routes
- Support for route grouping (by prefix, controller, or middleware)
- Intelligent handling of route parameters and request bodies
- Support for FormRequest validation rules to generate example requests
- Authentication configuration (Bearer token, Basic auth)
- Environment variables support
- Customizable output with pretty-printing option
- Works with Laravel 10.x and above
Installation
You can install the package via composer:
composer require lpmatrix/postman-generator
The service provider will be automatically registered for Laravel 8+.
Configuration
To publish the configuration file:
php artisan vendor:publish --provider="LPMatrix\PostmanGenerator\PostmanGeneratorServiceProvider" --tag="config"
This will create a config/postman-generator.php
file where you can customize the behavior of the package.
Usage
Basic Usage
To generate a Postman collection:
php artisan postman:generate
This will create a postman-collection.json
file in your project root that you can import into Postman.
Command Options
# Specify a custom output path php artisan postman:generate --output=custom-file.json # Pretty-print the JSON output php artisan postman:generate --pretty # Include environment variables php artisan postman:generate --include-env
Configuration Options
Collection Settings
// The name of the generated Postman collection 'collection_name' => env('POSTMAN_COLLECTION_NAME', config('app.name') . ' API'), // Description for the collection 'description' => env('POSTMAN_COLLECTION_DESCRIPTION', 'API Documentation'), // Base URL for all requests (can use Postman variables) 'base_url' => '{{baseUrl}}', // Default base URL value 'default_base_url' => env('APP_URL', 'http://localhost') . '/api',
Route Filtering
// Only include API routes (those with uri starting with 'api/') 'api_routes_only' => true, // Route URI patterns to exclude 'exclude_patterns' => [ '_debugbar/*', 'sanctum/*', // ... ], // HTTP methods to exclude 'exclude_methods' => [ 'HEAD', 'OPTIONS', ],
Route Grouping
// Strategy for grouping routes into folders // Supported values: 'prefix', 'controller', 'middleware', 'custom' 'grouping_strategy' => 'prefix', // Custom grouping function - only used when grouping_strategy is 'custom' 'custom_grouping' => function ($route) { // Your custom logic here return 'Your Group Name'; },
Authentication
// Authentication type for the collection // Supported values: 'noauth', 'bearer', 'basic' 'auth' => [ 'type' => 'bearer', 'token' => 'your-default-token', ],
Advanced Usage Examples
Custom Route Grouping
If you want to implement a custom grouping logic, you can define a closure in your AppServiceProvider
:
use Acme\PostmanGenerator\PostmanGenerator; public function boot() { config(['postman-generator.grouping_strategy' => 'custom']); config(['postman-generator.custom_grouping' => function ($route) { // Your custom grouping logic $uri = $route->uri(); $method = $route->methods()[0]; // Group by HTTP method return strtoupper($method); }]); }
Extracting Documentation from Route Annotations
This package automatically extracts documentation from PHPDoc comments in your controller methods. For best results, document your API endpoints like this:
/** * Get a list of all products. * * This endpoint returns a paginated list of products with basic information. * * @return \Illuminate\Http\Response */ public function index() { // Your code here }
Using with FormRequest Validation
The package automatically detects FormRequest validation rules to generate example request bodies:
public function store(StoreProductRequest $request) { // When StoreProductRequest contains validation rules, they will be used // to generate an example request body with appropriate data types }
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
The MIT License (MIT). Please see License File for more information.