1. Go to this page and download the library: Download rogervila/openapi-laravel library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
rogervila / openapi-laravel example snippets
namespace App\Specifications;
use LaravelOpenAPI\Specification\YamlSpecification;
use LaravelOpenAPI\Specification\JsonSpecification;
// The Specification class must implement YamlSpecification or JsonSpecification interface.
class PetsSpecification implements YamlSpecification
{
public function __invoke(): string
{
// As long as it returns a yaml or json string, you can resolve it as needed.
return file_get_contents(storage_path('openapi/pets.yml'));
// Another example (JSON in this case)
// return \Cache::rememberForever(self::class, fn () => \Http::get('https://petstore3.swagger.io/api/v3/openapi.json')->body());
}
}
namespace App\Http\Requests\OpenAPI;
use LaravelOpenAPI\Request;
class PetRequest extends Request
{
/** {@inheritDoc} */
public function getSpecification(): string
{
return \App\Specifications\PetsSpecification::class;
}
}
namespace App\Http\Controllers\Pet;
use App\Http\Controllers\Controller;
use App\Http\Requests\OpenAPI\PetRequest;
use App\Http\Resources\PetResource;
use App\Models\Pet;
use Illuminate\Http\JsonResponse;
use LaravelOpenAPI\OpenAPI;
// GET /api/pet/{petId}
class FindPetByIdController extends Controller
{
public function __invoke(PetRequest $request, int $petId): JsonResponse
{
if (is_null($pet = Pet::find($petId))) {
OpenAPI::abort(JsonResponse::HTTP_NOT_FOUND)->forRequest($request);
}
return OpenAPI::response(new PetResource($pet))->forRequest($request);
}
}
sh
# The namespace is optional, you can place specification classes anywhere.
php artisan openapi:make-specification Specifications/PetsSpecification
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.