MoonShine under the hood uses standard Laravel Routing
.
All displayed pages are rendered through PageController
, which has a very simple appearance.
public function __invoke(MoonShineRequest $request): PageContract{ $request->getResource()?->loaded(); $page = $request ->getPage() ->checkUrl() ->loaded(); return $page;}
Thus, you are free to use self-declared routes and controllers (if needed) and render pages or whatever is required.
For CRUD pages to work correctly, it is necessary to pass route parameters resourceUri
and pageUri
. resourceUri
is optional, as not all pages have a resource.
Example of a standard route:
Route::get('/admin/resource/{resourceUri}/{pageUri}', CustomController::class) ->middleware(['moonshine', \MoonShine\Laravel\Http\Middleware\Authenticate::class]) ->name('moonshine.name');
The prefix resource
can be changed or removed through configuration settings.
This example includes a route with parameters for the resource and page, as well as a group of middleware moonshine
, the list of which is located in the moonshine.php
config file, and the middleware Authenticate
for access to the endpoint only for authorized users.
For a quick implementation of the example above, you can use the Route
directive moonshine
:
Route::moonshine(static function (Router $router) { $router->post( 'permissions/{resourceItem}', PermissionController::class )->name('permissions');}, withResource: true, withPage: true, withAuthenticate: true); // result// POST /admin/resource/{resourceUri}/{pageUri}/permissions/{resourceItem}// middleware: moonshine, Authenticate::class
Example of retrieving a route from the resource context:
$this->getRoute('permissions')
Example of retrieving a route outside the resource:
route('moonshine.permissions', ['resourceUri' => 'user-resource', 'pageUri' => 'custom-page'])
Route::moonshine(static function (Router $router) { //},// add prefix {resourceUri}withResource: false,// add prefix {pageUri}withPage: false,// add middleware Authenticate::classwithAuthenticate: false);
The best way is to create routes/moonshine.php
and declare your own routes inside.
When creating the file routes/moonshine.php
, remember to declare it in the system.
You cannot use middleware groups web
and moonshine
simultaneously, as they do the same thing and start sessions at the same time.