Frontend

API

Basics

MoonShine allows you to switch the admin panel to API mode; to do this, simply add Accept: application/json to the request header, after which CRUD operations will return json responses. We also provide tools that allow you to switch authentication to JWT tokens, as well as generate OpenApi specifications and documentation based on resources.

When fully using MoonShine in API mode, don't forget to disable session middleware in the MoonShine configuration.

Also, take a look at the SDUI section.

JWT

MoonShine also provides a simple way to switch the admin panel to API mode and interact via tokens.

Installation:

composer require moonshine/jwt
composer require moonshine/jwt

Next, publish the config:

php artisan vendor:publish --provider="MoonShine\JWT\Providers\JWTServiceProvider"
php artisan vendor:publish --provider="MoonShine\JWT\Providers\JWTServiceProvider"

Then add the secret key in base64 to .env:

JWT_SECRET=YOUR_BASE64_SECRET_HERE
JWT_SECRET=YOUR_BASE64_SECRET_HERE

Next, change the set of middleware in the system and add authPipeline and authMiddleware:

use MoonShine\JWT\JWTAuthPipe;use MoonShine\JWT\Http\Middleware\AuthenticateApi;return [ 'middleware' => [ AuthenticateApi::class ], // ... 'auth' => [ // ... 'pipelines' => [ JWTAuthPipe::class ], // ... ] // ...];
use MoonShine\JWT\JWTAuthPipe;
use MoonShine\JWT\Http\Middleware\AuthenticateApi;
 
return [
'middleware' => [
AuthenticateApi::class
],
// ...
'auth' => [
// ...
'pipelines' => [
JWTAuthPipe::class
],
// ...
]
// ...
];
use MoonShine\JWT\JWTAuthPipe;use MoonShine\JWT\Http\Middleware\AuthenticateApi;$config->authPipelines([ JWTAuthPipe::class])->middlewares([])->authMiddleware(AuthenticateApi::class);
use MoonShine\JWT\JWTAuthPipe;
use MoonShine\JWT\Http\Middleware\AuthenticateApi;
 
$config->authPipelines([
JWTAuthPipe::class
])->middlewares([])->authMiddleware(AuthenticateApi::class);

All set! Upon successful authentication, you will receive a token, which can subsequently be used in the header Authorization: Bearer <token>.

OpenApi Generator

Installation:

composer require moonshine/oag
composer require moonshine/oag

Next, publish the config:

php artisan vendor:publish --provider="MoonShine\OAG\Providers\OAGServiceProvider"
php artisan vendor:publish --provider="MoonShine\OAG\Providers\OAGServiceProvider"

The configuration is already set up; in special cases, you can override specific settings:

'Docs', // Documentation title 'path' => realpath( resource_path('oag.yaml') ), // Location path for the specification 'route' => 'oag.json', // Route to retrieve data for documentation 'view' => 'oag::docs', // View for documentation ];
<?php
 
return [
'title' => 'Docs', // Documentation title
'path' => realpath(
resource_path('oag.yaml')
), // Location path for the specification
'route' => 'oag.json', // Route to retrieve data for documentation
'view' => 'oag::docs', // View for documentation
];

Next, based on the declared and configured resources in the system, a specification will be generated:

php artisan oag:generate
php artisan oag:generate

The specification files are by default located in the resources directory:

  • resources/oag.yaml
  • resources/oag.json

Documentation is available at the address:

  • /docs