🚀 Automatically generate TypeScript or JavaScript interfaces from your Laravel API Resource Controllers!
- ✅ Auto-generate TypeScript or JavaScript interfaces from API responses
- ✅ Support for Laravel Resource and ResourceCollection
- ✅ Smart type inference from actual data
- ✅ Artisan command for manual generation with output type selection
- ✅ Middleware for automatic generation
- ✅ Trait for easy controller integration
- ✅ Configurable type mappings
- ✅ Pagination support
composer require andrazero121/api-resource-typer
Publish the config file:
php artisan vendor:publish --provider="AndraZero121\ApiResourceTyper\Providers\ApiResourceTyperServiceProvider" --tag=api-resource-typer-config
php artisan vendor:publish --provider="AndraZero121\ApiResourceTyper\Providers\ApiResourceTyperServiceProvider" --tag=api-resource-typer-extension
Add the trait to your API controllers:
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Http\Resources\UserResource;
use App\Models\User;
use AndraZero121\ApiResourceTyper\Traits\ApiResourceTyper;
class UserController extends Controller
{
use ApiResourceTyper;
public function index()
{
$users = User::paginate();
return $this->responseWithTypes(UserResource::collection($users));
}
public function show(User $user)
{
return $this->responseWithTypes(new UserResource($user));
}
}
Add middleware to your API routes:
// routes/api.php
Route::middleware(['api', 'api-typer'])->group(function () {
Route::apiResource('users', UserController::class);
});
Generate types manually using Artisan command:
# Generate for all models as TypeScript (default)
php artisan generate:api-types
# Generate for all models as JavaScript JSDoc
printf artisan generate:api-types --output-type=js
# Generate for specific model
php artisan generate:api-types --model=User --output-type=ts
The package will generate TypeScript or JSDoc interfaces like this:
// TypeScript
export interface UserResource {
id: number;
name: string;
email: string;
created_at: Date;
updated_at: Date;
}
// JavaScript JSDoc
/**
* @typedef {Object} UserResource
* @property {number} id
* @property {string} name
* ...
*/
Edit config/api-resource-typer.php
for output path, type mappings, and excluded columns.
You can add your own helper or type modifier in app/ApiResourceTyperExtension.php
after publishing the extension file.
- PHP 8.2+
- Laravel 11.x+
MIT