Lae/bootstrap/app.php

152 lines
4.5 KiB
PHP
Raw Normal View History

2022-08-12 07:56:56 +00:00
<?php
2022-09-08 16:12:02 +00:00
require_once __DIR__ . '/../vendor/autoload.php';
(new Laravel\Lumen\Bootstrap\LoadEnvironmentVariables(
dirname(__DIR__)
))->bootstrap();
date_default_timezone_set(env('APP_TIMEZONE', 'UTC'));
2022-08-12 07:56:56 +00:00
/*
|--------------------------------------------------------------------------
| Create The Application
|--------------------------------------------------------------------------
|
2022-09-08 16:12:02 +00:00
| Here we will load the environment and create the application instance
| that serves as the central piece of this framework. We'll use this
| application as an "IoC" container and router for this framework.
2022-08-12 07:56:56 +00:00
|
*/
2022-09-08 16:12:02 +00:00
$app = new Laravel\Lumen\Application(
dirname(__DIR__)
2022-08-12 07:56:56 +00:00
);
2022-09-08 16:12:02 +00:00
$app->withFacades();
$app->withEloquent();
2022-08-12 07:56:56 +00:00
/*
|--------------------------------------------------------------------------
2022-09-08 16:12:02 +00:00
| Register Container Bindings
2022-08-12 07:56:56 +00:00
|--------------------------------------------------------------------------
|
2022-09-08 16:12:02 +00:00
| Now we will register a few bindings in the service container. We will
| register the exception handler and the console kernel. You may add
| your own bindings here if you like or you can make another file.
2022-08-12 07:56:56 +00:00
|
*/
$app->singleton(
2022-09-08 16:12:02 +00:00
Illuminate\Contracts\Debug\ExceptionHandler::class,
App\Exceptions\Handler::class
2022-08-12 07:56:56 +00:00
);
$app->singleton(
Illuminate\Contracts\Console\Kernel::class,
App\Console\Kernel::class
);
2022-09-08 16:12:02 +00:00
/*
|--------------------------------------------------------------------------
| Register Config Files
|--------------------------------------------------------------------------
|
| Now we will register the "app" configuration file. If the file exists in
| your configuration directory it will be loaded; otherwise, we'll load
| the default version. You may register other files below as needed.
|
*/
$app->configure('app');
$app->configure('auth');
$app->configure('cache');
$app->configure('database');
$app->configure('laravels');
$app->configure('oauth');
$app->configure('queue');
$app->configure('session');
$app->configure('alipay');
2022-08-12 07:56:56 +00:00
/*
|--------------------------------------------------------------------------
2022-09-08 16:12:02 +00:00
| Register Middleware
2022-08-12 07:56:56 +00:00
|--------------------------------------------------------------------------
|
2022-09-08 16:12:02 +00:00
| Next, we will register the middleware with the application. These can
| be global middleware that run before and after each request into a
| route or middleware that'll be assigned to some specific routes.
2022-08-12 07:56:56 +00:00
|
*/
2022-09-08 16:12:02 +00:00
$app->middleware([
// App\Http\Middleware\ExampleMiddleware::class
\App\Http\Middleware\AllowCors::class,
]);
$app->routeMiddleware([
'auth' => App\Http\Middleware\Authenticate::class,
// 'remote' => [
// \Illuminate\Routing\Middleware\SubstituteBindings::class,
// \App\Http\Middleware\AllowCors::class,
// ],
]);
/*
|--------------------------------------------------------------------------
| Register Service Providers
|--------------------------------------------------------------------------
|
| Here we will register all of the application's service providers which
| are used to bind services into the container. Service providers are
| totally optional, so you are not required to uncomment this line.
|
*/
$app->register(App\Providers\AppServiceProvider::class);
$app->register(App\Providers\AuthServiceProvider::class);
$app->register(Illuminate\Redis\RedisServiceProvider::class);
$app->register(Hhxsv5\LaravelS\Illuminate\LaravelSServiceProvider::class);
$app->register(Flipbox\LumenGenerator\LumenGeneratorServiceProvider::class);
// $app->register(App\Providers\EventServiceProvider::class);
$app->register(\Anik\Form\FormRequestServiceProvider::class);
$app->register(App\Providers\RouteBindingServiceProvider::class);
/*
|--------------------------------------------------------------------------
| Load The Application Routes
|--------------------------------------------------------------------------
|
| Next we will include the routes file so that they can all be added to
| the application. This will provide all of the URLs the application
| can respond to, as well as the controllers that may handle them.
|
*/
$app->router->group([
'namespace' => 'App\Http\Controllers',
], function ($router) {
require __DIR__ . '/../routes/web.php';
});
$app->router->group([
'namespace' => 'App\Http\Controllers',
'prefix' => 'api',
'middleware' => ['auth:api'],
], function ($router) {
require __DIR__ . '/../routes/api.php';
});
$app->router->group([
'namespace' => 'App\Http\Controllers\Remote',
'prefix' => 'remote',
'middleware' => ['auth:remote'],
], function ($router) {
require __DIR__ . '/../routes/remote.php';
});
2022-08-12 07:56:56 +00:00
return $app;