Upgrade Laravel to 10.0.0
This commit is contained in:
		| @@ -3,9 +3,9 @@ root = true | |||||||
| [*] | [*] | ||||||
| charset = utf-8 | charset = utf-8 | ||||||
| end_of_line = lf | end_of_line = lf | ||||||
| insert_final_newline = true |  | ||||||
| indent_style = space |  | ||||||
| indent_size = 4 | indent_size = 4 | ||||||
|  | indent_style = space | ||||||
|  | insert_final_newline = true | ||||||
| trim_trailing_whitespace = true | trim_trailing_whitespace = true | ||||||
|  |  | ||||||
| [*.md] | [*.md] | ||||||
| @@ -13,3 +13,6 @@ trim_trailing_whitespace = false | |||||||
|  |  | ||||||
| [*.{yml,yaml}] | [*.{yml,yaml}] | ||||||
| indent_size = 2 | indent_size = 2 | ||||||
|  |  | ||||||
|  | [docker-compose.yml] | ||||||
|  | indent_size = 4 | ||||||
							
								
								
									
										22
									
								
								.env.example
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								.env.example
									
									
									
									
									
								
							| @@ -5,6 +5,8 @@ APP_DEBUG=true | |||||||
| APP_URL=http://localhost | APP_URL=http://localhost | ||||||
|  |  | ||||||
| LOG_CHANNEL=stack | LOG_CHANNEL=stack | ||||||
|  | LOG_DEPRECATIONS_CHANNEL=null | ||||||
|  | LOG_LEVEL=debug | ||||||
|  |  | ||||||
| DB_CONNECTION=mysql | DB_CONNECTION=mysql | ||||||
| DB_HOST=127.0.0.1 | DB_HOST=127.0.0.1 | ||||||
| @@ -15,32 +17,42 @@ DB_PASSWORD= | |||||||
|  |  | ||||||
| BROADCAST_DRIVER=log | BROADCAST_DRIVER=log | ||||||
| CACHE_DRIVER=file | CACHE_DRIVER=file | ||||||
|  | FILESYSTEM_DISK=local | ||||||
| QUEUE_CONNECTION=sync | QUEUE_CONNECTION=sync | ||||||
| SESSION_DRIVER=file | SESSION_DRIVER=file | ||||||
| SESSION_LIFETIME=120 | SESSION_LIFETIME=120 | ||||||
|  |  | ||||||
|  | MEMCACHED_HOST=127.0.0.1 | ||||||
|  |  | ||||||
| REDIS_HOST=127.0.0.1 | REDIS_HOST=127.0.0.1 | ||||||
| REDIS_PASSWORD=null | REDIS_PASSWORD=null | ||||||
| REDIS_PORT=6379 | REDIS_PORT=6379 | ||||||
|  |  | ||||||
| MAIL_MAILER=smtp | MAIL_MAILER=smtp | ||||||
| MAIL_HOST=smtp.mailtrap.io | MAIL_HOST=mailpit | ||||||
| MAIL_PORT=2525 | MAIL_PORT=1025 | ||||||
| MAIL_USERNAME=null | MAIL_USERNAME=null | ||||||
| MAIL_PASSWORD=null | MAIL_PASSWORD=null | ||||||
| MAIL_ENCRYPTION=null | MAIL_ENCRYPTION=null | ||||||
| MAIL_FROM_ADDRESS=null | MAIL_FROM_ADDRESS="hello@example.com" | ||||||
| MAIL_FROM_NAME="${APP_NAME}" | MAIL_FROM_NAME="${APP_NAME}" | ||||||
|  |  | ||||||
| AWS_ACCESS_KEY_ID= | AWS_ACCESS_KEY_ID= | ||||||
| AWS_SECRET_ACCESS_KEY= | AWS_SECRET_ACCESS_KEY= | ||||||
| AWS_DEFAULT_REGION=us-east-1 | AWS_DEFAULT_REGION=us-east-1 | ||||||
| AWS_BUCKET= | AWS_BUCKET= | ||||||
|  | AWS_USE_PATH_STYLE_ENDPOINT=false | ||||||
|  |  | ||||||
| PUSHER_APP_ID= | PUSHER_APP_ID= | ||||||
| PUSHER_APP_KEY= | PUSHER_APP_KEY= | ||||||
| PUSHER_APP_SECRET= | PUSHER_APP_SECRET= | ||||||
|  | PUSHER_HOST= | ||||||
|  | PUSHER_PORT=443 | ||||||
|  | PUSHER_SCHEME=https | ||||||
| PUSHER_APP_CLUSTER=mt1 | PUSHER_APP_CLUSTER=mt1 | ||||||
|  |  | ||||||
| MIX_PUSHER_APP_KEY="${PUSHER_APP_KEY}" | VITE_PUSHER_APP_KEY="${PUSHER_APP_KEY}" | ||||||
| MIX_PUSHER_APP_CLUSTER="${PUSHER_APP_CLUSTER}" | VITE_PUSHER_HOST="${PUSHER_HOST}" | ||||||
|  | VITE_PUSHER_PORT="${PUSHER_PORT}" | ||||||
|  | VITE_PUSHER_SCHEME="${PUSHER_SCHEME}" | ||||||
|  | VITE_PUSHER_APP_CLUSTER="${PUSHER_APP_CLUSTER}" | ||||||
							
								
								
									
										14
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,11 @@ | |||||||
| * text=auto | * text=auto eol=lf | ||||||
| *.css linguist-vendored |  | ||||||
| *.scss linguist-vendored | *.blade.php diff=html | ||||||
| *.js linguist-vendored | *.css diff=css | ||||||
|  | *.html diff=html | ||||||
|  | *.md diff=markdown | ||||||
|  | *.php diff=php | ||||||
|  |  | ||||||
|  | /.github export-ignore | ||||||
| CHANGELOG.md export-ignore | CHANGELOG.md export-ignore | ||||||
|  | .styleci.yml export-ignore | ||||||
							
								
								
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,12 +1,18 @@ | |||||||
|  | /.phpunit.cache | ||||||
| /node_modules | /node_modules | ||||||
|  | /public/build | ||||||
| /public/hot | /public/hot | ||||||
| /public/storage | /public/storage | ||||||
| /storage/*.key | /storage/*.key | ||||||
| /vendor | /vendor | ||||||
| .env | .env | ||||||
| .env.backup | .env.backup | ||||||
| .phpunit.result.cache | .env.production | ||||||
| Homestead.json | Homestead.json | ||||||
| Homestead.yaml | Homestead.yaml | ||||||
|  | auth.json | ||||||
| npm-debug.log | npm-debug.log | ||||||
| yarn-error.log | yarn-error.log | ||||||
|  | /.fleet | ||||||
|  | /.idea | ||||||
|  | /.vscode | ||||||
| @@ -1,13 +1,9 @@ | |||||||
| php: | php: | ||||||
|   preset: laravel |   preset: laravel | ||||||
|   disabled: |   disabled: | ||||||
|     - unused_use |     - no_unused_imports | ||||||
|   finder: |   finder: | ||||||
|     not-name: |     not-name: | ||||||
|       - index.php |       - index.php | ||||||
|       - server.php | js: true | ||||||
| js: |  | ||||||
|   finder: |  | ||||||
|     not-name: |  | ||||||
|       - webpack.mix.js |  | ||||||
| css: true | css: true | ||||||
| @@ -7,32 +7,18 @@ use Illuminate\Foundation\Console\Kernel as ConsoleKernel; | |||||||
| 
 | 
 | ||||||
| class Kernel extends ConsoleKernel | class Kernel extends ConsoleKernel | ||||||
| { | { | ||||||
|     /** |  | ||||||
|      * The Artisan commands provided by your application. |  | ||||||
|      * |  | ||||||
|      * @var array |  | ||||||
|      */ |  | ||||||
|     protected $commands = [ |  | ||||||
|         //
 |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * Define the application's command schedule. |      * Define the application's command schedule. | ||||||
|      * |  | ||||||
|      * @param  \Illuminate\Console\Scheduling\Schedule  $schedule |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     protected function schedule(Schedule $schedule) |     protected function schedule(Schedule $schedule): void | ||||||
|     { |     { | ||||||
|         // $schedule->command('inspire')->hourly();
 |         // $schedule->command('inspire')->hourly();
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Register the commands for the application. |      * Register the commands for the application. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     protected function commands() |     protected function commands(): void | ||||||
|     { |     { | ||||||
|         $this->load(__DIR__.'/Commands'); |         $this->load(__DIR__.'/Commands'); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -7,49 +7,42 @@ use Throwable; | |||||||
| 
 | 
 | ||||||
| class Handler extends ExceptionHandler | class Handler extends ExceptionHandler | ||||||
| { | { | ||||||
|  |     /** | ||||||
|  |      * A list of exception types with their corresponding custom log levels. | ||||||
|  |      * | ||||||
|  |      * @var array<class-string<\Throwable>, \Psr\Log\LogLevel::*> | ||||||
|  |      */ | ||||||
|  |     protected $levels = [ | ||||||
|  |         //
 | ||||||
|  |     ]; | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * A list of the exception types that are not reported. |      * A list of the exception types that are not reported. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<int, class-string<\Throwable>> | ||||||
|      */ |      */ | ||||||
|     protected $dontReport = [ |     protected $dontReport = [ | ||||||
|         //
 |         //
 | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * A list of the inputs that are never flashed for validation exceptions. |      * A list of the inputs that are never flashed to the session on validation exceptions. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<int, string> | ||||||
|      */ |      */ | ||||||
|     protected $dontFlash = [ |     protected $dontFlash = [ | ||||||
|  |         'current_password', | ||||||
|         'password', |         'password', | ||||||
|         'password_confirmation', |         'password_confirmation', | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Report or log an exception. |      * Register the exception handling callbacks for the application. | ||||||
|      * |  | ||||||
|      * @param  \Throwable  $exception |  | ||||||
|      * @return void |  | ||||||
|      * |  | ||||||
|      * @throws \Exception |  | ||||||
|      */ |      */ | ||||||
|     public function report(Throwable $exception) |     public function register(): void | ||||||
|     { |     { | ||||||
|         parent::report($exception); |         $this->reportable(function (Throwable $e) { | ||||||
|     } |             //
 | ||||||
| 
 |         }); | ||||||
|     /** |  | ||||||
|      * Render an exception into an HTTP response. |  | ||||||
|      * |  | ||||||
|      * @param  \Illuminate\Http\Request  $request |  | ||||||
|      * @param  \Throwable  $exception |  | ||||||
|      * @return \Symfony\Component\HttpFoundation\Response |  | ||||||
|      * |  | ||||||
|      * @throws \Throwable |  | ||||||
|      */ |  | ||||||
|     public function render($request, Throwable $exception) |  | ||||||
|     { |  | ||||||
|         return parent::render($request, $exception); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -3,11 +3,10 @@ | |||||||
| namespace App\Http\Controllers; | namespace App\Http\Controllers; | ||||||
| 
 | 
 | ||||||
| use Illuminate\Foundation\Auth\Access\AuthorizesRequests; | use Illuminate\Foundation\Auth\Access\AuthorizesRequests; | ||||||
| use Illuminate\Foundation\Bus\DispatchesJobs; |  | ||||||
| use Illuminate\Foundation\Validation\ValidatesRequests; | use Illuminate\Foundation\Validation\ValidatesRequests; | ||||||
| use Illuminate\Routing\Controller as BaseController; | use Illuminate\Routing\Controller as BaseController; | ||||||
| 
 | 
 | ||||||
| class Controller extends BaseController | class Controller extends BaseController | ||||||
| { | { | ||||||
|     use AuthorizesRequests, DispatchesJobs, ValidatesRequests; |     use AuthorizesRequests, ValidatesRequests; | ||||||
| } | } | ||||||
| @@ -11,12 +11,13 @@ class Kernel extends HttpKernel | |||||||
|      * |      * | ||||||
|      * These middleware are run during every request to your application. |      * These middleware are run during every request to your application. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<int, class-string|string> | ||||||
|      */ |      */ | ||||||
|     protected $middleware = [ |     protected $middleware = [ | ||||||
|  |         // \App\Http\Middleware\TrustHosts::class,
 | ||||||
|         \App\Http\Middleware\TrustProxies::class, |         \App\Http\Middleware\TrustProxies::class, | ||||||
|         \Fruitcake\Cors\HandleCors::class, |         \Illuminate\Http\Middleware\HandleCors::class, | ||||||
|         \App\Http\Middleware\CheckForMaintenanceMode::class, |         \App\Http\Middleware\PreventRequestsDuringMaintenance::class, | ||||||
|         \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class, |         \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class, | ||||||
|         \App\Http\Middleware\TrimStrings::class, |         \App\Http\Middleware\TrimStrings::class, | ||||||
|         \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class, |         \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class, | ||||||
| @@ -25,41 +26,41 @@ class Kernel extends HttpKernel | |||||||
|     /** |     /** | ||||||
|      * The application's route middleware groups. |      * The application's route middleware groups. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<string, array<int, class-string|string>> | ||||||
|      */ |      */ | ||||||
|     protected $middlewareGroups = [ |     protected $middlewareGroups = [ | ||||||
|         'web' => [ |         'web' => [ | ||||||
|             \App\Http\Middleware\EncryptCookies::class, |             \App\Http\Middleware\EncryptCookies::class, | ||||||
|             \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, |             \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, | ||||||
|             \Illuminate\Session\Middleware\StartSession::class, |             \Illuminate\Session\Middleware\StartSession::class, | ||||||
|             // \Illuminate\Session\Middleware\AuthenticateSession::class,
 |  | ||||||
|             \Illuminate\View\Middleware\ShareErrorsFromSession::class, |             \Illuminate\View\Middleware\ShareErrorsFromSession::class, | ||||||
|             \App\Http\Middleware\VerifyCsrfToken::class, |             \App\Http\Middleware\VerifyCsrfToken::class, | ||||||
|             \Illuminate\Routing\Middleware\SubstituteBindings::class, |             \Illuminate\Routing\Middleware\SubstituteBindings::class, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'api' => [ |         'api' => [ | ||||||
|             'throttle:60,1', |             // \Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class,
 | ||||||
|  |             \Illuminate\Routing\Middleware\ThrottleRequests::class.':api', | ||||||
|             \Illuminate\Routing\Middleware\SubstituteBindings::class, |             \Illuminate\Routing\Middleware\SubstituteBindings::class, | ||||||
|         ], |         ], | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * The application's route middleware. |      * The application's middleware aliases. | ||||||
|      * |      * | ||||||
|      * These middleware may be assigned to groups or used individually. |      * Aliases may be used to conveniently assign middleware to routes and groups. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<string, class-string|string> | ||||||
|      */ |      */ | ||||||
|     protected $routeMiddleware = [ |     protected $middlewareAliases = [ | ||||||
|         'auth' => \App\Http\Middleware\Authenticate::class, |         'auth' => \App\Http\Middleware\Authenticate::class, | ||||||
|         'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class, |         'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class, | ||||||
|         'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class, |         'auth.session' => \Illuminate\Session\Middleware\AuthenticateSession::class, | ||||||
|         'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class, |         'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class, | ||||||
|         'can' => \Illuminate\Auth\Middleware\Authorize::class, |         'can' => \Illuminate\Auth\Middleware\Authorize::class, | ||||||
|         'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class, |         'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class, | ||||||
|         'password.confirm' => \Illuminate\Auth\Middleware\RequirePassword::class, |         'password.confirm' => \Illuminate\Auth\Middleware\RequirePassword::class, | ||||||
|         'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class, |         'signed' => \App\Http\Middleware\ValidateSignature::class, | ||||||
|         'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class, |         'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class, | ||||||
|         'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class, |         'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class, | ||||||
|     ]; |     ]; | ||||||
|   | |||||||
| @@ -3,19 +3,15 @@ | |||||||
| namespace App\Http\Middleware; | namespace App\Http\Middleware; | ||||||
| 
 | 
 | ||||||
| use Illuminate\Auth\Middleware\Authenticate as Middleware; | use Illuminate\Auth\Middleware\Authenticate as Middleware; | ||||||
|  | use Illuminate\Http\Request; | ||||||
| 
 | 
 | ||||||
| class Authenticate extends Middleware | class Authenticate extends Middleware | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Get the path the user should be redirected to when they are not authenticated. |      * Get the path the user should be redirected to when they are not authenticated. | ||||||
|      * |  | ||||||
|      * @param  \Illuminate\Http\Request  $request |  | ||||||
|      * @return string|null |  | ||||||
|      */ |      */ | ||||||
|     protected function redirectTo($request) |     protected function redirectTo(Request $request): ?string | ||||||
|     { |     { | ||||||
|         if (! $request->expectsJson()) { |         return $request->expectsJson() ? null : route('login'); | ||||||
|             return route('login'); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -9,7 +9,7 @@ class EncryptCookies extends Middleware | |||||||
|     /** |     /** | ||||||
|      * The names of the cookies that should not be encrypted. |      * The names of the cookies that should not be encrypted. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<int, string> | ||||||
|      */ |      */ | ||||||
|     protected $except = [ |     protected $except = [ | ||||||
|         //
 |         //
 | ||||||
|   | |||||||
| @@ -2,14 +2,14 @@ | |||||||
| 
 | 
 | ||||||
| namespace App\Http\Middleware; | namespace App\Http\Middleware; | ||||||
| 
 | 
 | ||||||
| use Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode as Middleware; | use Illuminate\Foundation\Http\Middleware\PreventRequestsDuringMaintenance as Middleware; | ||||||
| 
 | 
 | ||||||
| class CheckForMaintenanceMode extends Middleware | class PreventRequestsDuringMaintenance extends Middleware | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * The URIs that should be reachable while maintenance mode is enabled. |      * The URIs that should be reachable while maintenance mode is enabled. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<int, string> | ||||||
|      */ |      */ | ||||||
|     protected $except = [ |     protected $except = [ | ||||||
|         //
 |         //
 | ||||||
| @@ -4,22 +4,25 @@ namespace App\Http\Middleware; | |||||||
| 
 | 
 | ||||||
| use App\Providers\RouteServiceProvider; | use App\Providers\RouteServiceProvider; | ||||||
| use Closure; | use Closure; | ||||||
|  | use Illuminate\Http\Request; | ||||||
| use Illuminate\Support\Facades\Auth; | use Illuminate\Support\Facades\Auth; | ||||||
|  | use Symfony\Component\HttpFoundation\Response; | ||||||
| 
 | 
 | ||||||
| class RedirectIfAuthenticated | class RedirectIfAuthenticated | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Handle an incoming request. |      * Handle an incoming request. | ||||||
|      * |      * | ||||||
|      * @param  \Illuminate\Http\Request  $request |      * @param  \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response)  $next | ||||||
|      * @param  \Closure  $next |  | ||||||
|      * @param  string|null  $guard |  | ||||||
|      * @return mixed |  | ||||||
|      */ |      */ | ||||||
|     public function handle($request, Closure $next, $guard = null) |     public function handle(Request $request, Closure $next, string ...$guards): Response | ||||||
|     { |     { | ||||||
|         if (Auth::guard($guard)->check()) { |         $guards = empty($guards) ? [null] : $guards; | ||||||
|             return redirect(RouteServiceProvider::HOME); | 
 | ||||||
|  |         foreach ($guards as $guard) { | ||||||
|  |             if (Auth::guard($guard)->check()) { | ||||||
|  |                 return redirect(RouteServiceProvider::HOME); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return $next($request); |         return $next($request); | ||||||
|   | |||||||
| @@ -9,9 +9,10 @@ class TrimStrings extends Middleware | |||||||
|     /** |     /** | ||||||
|      * The names of the attributes that should not be trimmed. |      * The names of the attributes that should not be trimmed. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<int, string> | ||||||
|      */ |      */ | ||||||
|     protected $except = [ |     protected $except = [ | ||||||
|  |         'current_password', | ||||||
|         'password', |         'password', | ||||||
|         'password_confirmation', |         'password_confirmation', | ||||||
|     ]; |     ]; | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								app/Http/Middleware/TrustHosts.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								app/Http/Middleware/TrustHosts.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | namespace App\Http\Middleware; | ||||||
|  | 
 | ||||||
|  | use Illuminate\Http\Middleware\TrustHosts as Middleware; | ||||||
|  | 
 | ||||||
|  | class TrustHosts extends Middleware | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Get the host patterns that should be trusted. | ||||||
|  |      * | ||||||
|  |      * @return array<int, string|null> | ||||||
|  |      */ | ||||||
|  |     public function hosts(): array | ||||||
|  |     { | ||||||
|  |         return [ | ||||||
|  |             $this->allSubdomainsOfApplicationUrl(), | ||||||
|  |         ]; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -2,7 +2,7 @@ | |||||||
| 
 | 
 | ||||||
| namespace App\Http\Middleware; | namespace App\Http\Middleware; | ||||||
| 
 | 
 | ||||||
| use Fideloper\Proxy\TrustProxies as Middleware; | use Illuminate\Http\Middleware\TrustProxies as Middleware; | ||||||
| use Illuminate\Http\Request; | use Illuminate\Http\Request; | ||||||
| 
 | 
 | ||||||
| class TrustProxies extends Middleware | class TrustProxies extends Middleware | ||||||
| @@ -10,7 +10,7 @@ class TrustProxies extends Middleware | |||||||
|     /** |     /** | ||||||
|      * The trusted proxies for this application. |      * The trusted proxies for this application. | ||||||
|      * |      * | ||||||
|      * @var array|string |      * @var array<int, string>|string|null | ||||||
|      */ |      */ | ||||||
|     protected $proxies; |     protected $proxies; | ||||||
| 
 | 
 | ||||||
| @@ -19,5 +19,10 @@ class TrustProxies extends Middleware | |||||||
|      * |      * | ||||||
|      * @var int |      * @var int | ||||||
|      */ |      */ | ||||||
|     protected $headers = Request::HEADER_X_FORWARDED_ALL; |     protected $headers = | ||||||
|  |         Request::HEADER_X_FORWARDED_FOR | | ||||||
|  |         Request::HEADER_X_FORWARDED_HOST | | ||||||
|  |         Request::HEADER_X_FORWARDED_PORT | | ||||||
|  |         Request::HEADER_X_FORWARDED_PROTO | | ||||||
|  |         Request::HEADER_X_FORWARDED_AWS_ELB; | ||||||
| } | } | ||||||
							
								
								
									
										22
									
								
								app/Http/Middleware/ValidateSignature.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								app/Http/Middleware/ValidateSignature.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | namespace App\Http\Middleware; | ||||||
|  | 
 | ||||||
|  | use Illuminate\Routing\Middleware\ValidateSignature as Middleware; | ||||||
|  | 
 | ||||||
|  | class ValidateSignature extends Middleware | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * The names of the query string parameters that should be ignored. | ||||||
|  |      * | ||||||
|  |      * @var array<int, string> | ||||||
|  |      */ | ||||||
|  |     protected $except = [ | ||||||
|  |         // 'fbclid',
 | ||||||
|  |         // 'utm_campaign',
 | ||||||
|  |         // 'utm_content',
 | ||||||
|  |         // 'utm_medium',
 | ||||||
|  |         // 'utm_source',
 | ||||||
|  |         // 'utm_term',
 | ||||||
|  |     ]; | ||||||
|  | } | ||||||
| @@ -9,7 +9,7 @@ class VerifyCsrfToken extends Middleware | |||||||
|     /** |     /** | ||||||
|      * The URIs that should be excluded from CSRF verification. |      * The URIs that should be excluded from CSRF verification. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<int, string> | ||||||
|      */ |      */ | ||||||
|     protected $except = [ |     protected $except = [ | ||||||
|         //
 |         //
 | ||||||
|   | |||||||
							
								
								
									
										44
									
								
								app/Models/User.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								app/Models/User.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | namespace App\Models; | ||||||
|  | 
 | ||||||
|  | // use Illuminate\Contracts\Auth\MustVerifyEmail;
 | ||||||
|  | use Illuminate\Database\Eloquent\Factories\HasFactory; | ||||||
|  | use Illuminate\Foundation\Auth\User as Authenticatable; | ||||||
|  | use Illuminate\Notifications\Notifiable; | ||||||
|  | use Laravel\Sanctum\HasApiTokens; | ||||||
|  | 
 | ||||||
|  | class User extends Authenticatable | ||||||
|  | { | ||||||
|  |     use HasApiTokens, HasFactory, Notifiable; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * The attributes that are mass assignable. | ||||||
|  |      * | ||||||
|  |      * @var array<int, string> | ||||||
|  |      */ | ||||||
|  |     protected $fillable = [ | ||||||
|  |         'name', | ||||||
|  |         'email', | ||||||
|  |         'password', | ||||||
|  |     ]; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * The attributes that should be hidden for serialization. | ||||||
|  |      * | ||||||
|  |      * @var array<int, string> | ||||||
|  |      */ | ||||||
|  |     protected $hidden = [ | ||||||
|  |         'password', | ||||||
|  |         'remember_token', | ||||||
|  |     ]; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * The attributes that should be cast. | ||||||
|  |      * | ||||||
|  |      * @var array<string, string> | ||||||
|  |      */ | ||||||
|  |     protected $casts = [ | ||||||
|  |         'email_verified_at' => 'datetime', | ||||||
|  |     ]; | ||||||
|  | } | ||||||
| @@ -8,20 +8,16 @@ class AppServiceProvider extends ServiceProvider | |||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Register any application services. |      * Register any application services. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function register() |     public function register(): void | ||||||
|     { |     { | ||||||
|         //
 |         //
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Bootstrap any application services. |      * Bootstrap any application services. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function boot() |     public function boot(): void | ||||||
|     { |     { | ||||||
|         //
 |         //
 | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -2,26 +2,24 @@ | |||||||
| 
 | 
 | ||||||
| namespace App\Providers; | namespace App\Providers; | ||||||
| 
 | 
 | ||||||
|  | // use Illuminate\Support\Facades\Gate;
 | ||||||
| use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider; | use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider; | ||||||
| use Illuminate\Support\Facades\Gate; |  | ||||||
| 
 | 
 | ||||||
| class AuthServiceProvider extends ServiceProvider | class AuthServiceProvider extends ServiceProvider | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * The policy mappings for the application. |      * The model to policy mappings for the application. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<class-string, class-string> | ||||||
|      */ |      */ | ||||||
|     protected $policies = [ |     protected $policies = [ | ||||||
|         // 'App\Model' => 'App\Policies\ModelPolicy',
 |         // 'App\Models\Model' => 'App\Policies\ModelPolicy',
 | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Register any authentication / authorization services. |      * Register any authentication / authorization services. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function boot() |     public function boot(): void | ||||||
|     { |     { | ||||||
|         $this->registerPolicies(); |         $this->registerPolicies(); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -9,10 +9,8 @@ class BroadcastServiceProvider extends ServiceProvider | |||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Bootstrap any application services. |      * Bootstrap any application services. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function boot() |     public function boot(): void | ||||||
|     { |     { | ||||||
|         Broadcast::routes(); |         Broadcast::routes(); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -10,9 +10,9 @@ use Illuminate\Support\Facades\Event; | |||||||
| class EventServiceProvider extends ServiceProvider | class EventServiceProvider extends ServiceProvider | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * The event listener mappings for the application. |      * The event to listener mappings for the application. | ||||||
|      * |      * | ||||||
|      * @var array |      * @var array<class-string, array<int, class-string>> | ||||||
|      */ |      */ | ||||||
|     protected $listen = [ |     protected $listen = [ | ||||||
|         Registered::class => [ |         Registered::class => [ | ||||||
| @@ -22,13 +22,17 @@ class EventServiceProvider extends ServiceProvider | |||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Register any events for your application. |      * Register any events for your application. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function boot() |     public function boot(): void | ||||||
|     { |     { | ||||||
|         parent::boot(); |  | ||||||
| 
 |  | ||||||
|         //
 |         //
 | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Determine if events and listeners should be automatically discovered. | ||||||
|  |      */ | ||||||
|  |     public function shouldDiscoverEvents(): bool | ||||||
|  |     { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
| } | } | ||||||
| @@ -2,79 +2,47 @@ | |||||||
| 
 | 
 | ||||||
| namespace App\Providers; | namespace App\Providers; | ||||||
| 
 | 
 | ||||||
|  | use Illuminate\Cache\RateLimiting\Limit; | ||||||
| use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; | use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; | ||||||
|  | use Illuminate\Http\Request; | ||||||
|  | use Illuminate\Support\Facades\RateLimiter; | ||||||
| use Illuminate\Support\Facades\Route; | use Illuminate\Support\Facades\Route; | ||||||
| 
 | 
 | ||||||
| class RouteServiceProvider extends ServiceProvider | class RouteServiceProvider extends ServiceProvider | ||||||
| { | { | ||||||
|     /** |  | ||||||
|      * This namespace is applied to your controller routes. |  | ||||||
|      * |  | ||||||
|      * In addition, it is set as the URL generator's root namespace. |  | ||||||
|      * |  | ||||||
|      * @var string |  | ||||||
|      */ |  | ||||||
|     protected $namespace = 'App\Http\Controllers'; |  | ||||||
| 
 |  | ||||||
|     /** |     /** | ||||||
|      * The path to the "home" route for your application. |      * The path to the "home" route for your application. | ||||||
|      * |      * | ||||||
|  |      * Typically, users are redirected here after authentication. | ||||||
|  |      * | ||||||
|      * @var string |      * @var string | ||||||
|      */ |      */ | ||||||
|     public const HOME = '/home'; |     public const HOME = '/home'; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Define your route model bindings, pattern filters, etc. |      * Define your route model bindings, pattern filters, and other route configuration. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function boot() |     public function boot(): void | ||||||
|     { |     { | ||||||
|         //
 |         $this->configureRateLimiting(); | ||||||
| 
 | 
 | ||||||
|         parent::boot(); |         $this->routes(function () { | ||||||
|  |             Route::middleware('api') | ||||||
|  |                 ->prefix('api') | ||||||
|  |                 ->group(base_path('routes/api.php')); | ||||||
|  | 
 | ||||||
|  |             Route::middleware('web') | ||||||
|  |                 ->group(base_path('routes/web.php')); | ||||||
|  |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Define the routes for the application. |      * Configure the rate limiters for the application. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function map() |     protected function configureRateLimiting(): void | ||||||
|     { |     { | ||||||
|         $this->mapApiRoutes(); |         RateLimiter::for('api', function (Request $request) { | ||||||
| 
 |             return Limit::perMinute(60)->by($request->user()?->id ?: $request->ip()); | ||||||
|         $this->mapWebRoutes(); |         }); | ||||||
| 
 |  | ||||||
|         //
 |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Define the "web" routes for the application. |  | ||||||
|      * |  | ||||||
|      * These routes all receive session state, CSRF protection, etc. |  | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |  | ||||||
|     protected function mapWebRoutes() |  | ||||||
|     { |  | ||||||
|         Route::middleware('web') |  | ||||||
|             ->namespace($this->namespace) |  | ||||||
|             ->group(base_path('routes/web.php')); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Define the "api" routes for the application. |  | ||||||
|      * |  | ||||||
|      * These routes are typically stateless. |  | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |  | ||||||
|     protected function mapApiRoutes() |  | ||||||
|     { |  | ||||||
|         Route::prefix('api') |  | ||||||
|             ->middleware('api') |  | ||||||
|             ->namespace($this->namespace) |  | ||||||
|             ->group(base_path('routes/api.php')); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
							
								
								
									
										39
									
								
								app/User.php
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								app/User.php
									
									
									
									
									
								
							| @@ -1,39 +0,0 @@ | |||||||
| <?php |  | ||||||
| 
 |  | ||||||
| namespace App; |  | ||||||
| 
 |  | ||||||
| use Illuminate\Contracts\Auth\MustVerifyEmail; |  | ||||||
| use Illuminate\Foundation\Auth\User as Authenticatable; |  | ||||||
| use Illuminate\Notifications\Notifiable; |  | ||||||
| 
 |  | ||||||
| class User extends Authenticatable |  | ||||||
| { |  | ||||||
|     use Notifiable; |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * The attributes that are mass assignable. |  | ||||||
|      * |  | ||||||
|      * @var array |  | ||||||
|      */ |  | ||||||
|     protected $fillable = [ |  | ||||||
|         'name', 'email', 'password', |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * The attributes that should be hidden for arrays. |  | ||||||
|      * |  | ||||||
|      * @var array |  | ||||||
|      */ |  | ||||||
|     protected $hidden = [ |  | ||||||
|         'password', 'remember_token', |  | ||||||
|     ]; |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * The attributes that should be cast to native types. |  | ||||||
|      * |  | ||||||
|      * @var array |  | ||||||
|      */ |  | ||||||
|     protected $casts = [ |  | ||||||
|         'email_verified_at' => 'datetime', |  | ||||||
|     ]; |  | ||||||
| } |  | ||||||
							
								
								
									
										2
									
								
								artisan
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								artisan
									
									
									
									
									
								
							| @@ -11,7 +11,7 @@ define('LARAVEL_START', microtime(true)); | |||||||
| | Composer provides a convenient, automatically generated class loader | | Composer provides a convenient, automatically generated class loader | ||||||
| | for our application. We just need to utilize it! We'll require it | | for our application. We just need to utilize it! We'll require it | ||||||
| | into the script here so that we do not have to worry about the | | into the script here so that we do not have to worry about the | ||||||
| | loading of any our classes "manually". Feels great to relax. | | loading of any of our classes manually. It's great to relax. | ||||||
| | | | | ||||||
| */ | */ | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								bootstrap/cache/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								bootstrap/cache/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -2,37 +2,24 @@ | |||||||
|     "name": "laravel/laravel", |     "name": "laravel/laravel", | ||||||
|     "type": "project", |     "type": "project", | ||||||
|     "description": "The Laravel Framework.", |     "description": "The Laravel Framework.", | ||||||
|     "keywords": [ |     "keywords": ["framework", "laravel"], | ||||||
|         "framework", |  | ||||||
|         "laravel" |  | ||||||
|     ], |  | ||||||
|     "license": "MIT", |     "license": "MIT", | ||||||
|     "require": { |     "require": { | ||||||
|         "php": "^7.3", |         "php": "^8.1", | ||||||
|         "fideloper/proxy": "^4.2", |         "guzzlehttp/guzzle": "^7.2", | ||||||
|         "fruitcake/laravel-cors": "^1.0", |         "laravel/framework": "^10.0", | ||||||
|         "guzzlehttp/guzzle": "^7.0.1", |         "laravel/sanctum": "^3.2", | ||||||
|         "laravel/framework": "^8.0", |         "laravel/tinker": "^2.8" | ||||||
|         "laravel/ui": "^3.0", |  | ||||||
|         "laravel/tinker": "^2.0" |  | ||||||
|     }, |     }, | ||||||
|     "require-dev": { |     "require-dev": { | ||||||
|         "facade/ignition": "^2.2.6", |         "fakerphp/faker": "^1.9.1", | ||||||
|         "fzaninotto/faker": "^1.9.1", |         "barryvdh/laravel-debugbar": "^3.6", | ||||||
|         "mockery/mockery": "^1.3.1", |         "laravel/pint": "^1.0", | ||||||
|         "nunomaduro/collision": "^5.0", |         "laravel/sail": "^1.18", | ||||||
|         "phpunit/phpunit": "^9.0", |         "mockery/mockery": "^1.4.4", | ||||||
|         "barryvdh/laravel-debugbar": "^3.6" |         "nunomaduro/collision": "^7.0", | ||||||
|     }, |         "phpunit/phpunit": "^10.0", | ||||||
|     "config": { |         "spatie/laravel-ignition": "^2.0" | ||||||
|         "optimize-autoloader": true, |  | ||||||
|         "preferred-install": "dist", |  | ||||||
|         "sort-packages": true |  | ||||||
|     }, |  | ||||||
|     "extra": { |  | ||||||
|         "laravel": { |  | ||||||
|             "dont-discover": [] |  | ||||||
|         } |  | ||||||
|     }, |     }, | ||||||
|     "autoload": { |     "autoload": { | ||||||
|         "psr-4": { |         "psr-4": { | ||||||
| @@ -46,18 +33,37 @@ | |||||||
|             "Tests\\": "tests/" |             "Tests\\": "tests/" | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|     "minimum-stability": "dev", |  | ||||||
|     "prefer-stable": true, |  | ||||||
|     "scripts": { |     "scripts": { | ||||||
|         "post-autoload-dump": [ |         "post-autoload-dump": [ | ||||||
|             "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump", |             "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump", | ||||||
|             "@php artisan package:discover --ansi" |             "@php artisan package:discover --ansi" | ||||||
|         ], |         ], | ||||||
|  |         "post-update-cmd": [ | ||||||
|  |             "@php artisan vendor:publish --tag=laravel-assets --ansi --force" | ||||||
|  |         ], | ||||||
|         "post-root-package-install": [ |         "post-root-package-install": [ | ||||||
|             "@php -r \"file_exists('.env') || copy('.env.example', '.env');\"" |             "@php -r \"file_exists('.env') || copy('.env.example', '.env');\"" | ||||||
|         ], |         ], | ||||||
|         "post-create-project-cmd": [ |         "post-create-project-cmd": [ | ||||||
|             "@php artisan key:generate --ansi" |             "@php artisan key:generate --ansi" | ||||||
|         ] |         ] | ||||||
|     } |     }, | ||||||
|  |     "extra": { | ||||||
|  |         "branch-alias": { | ||||||
|  |             "dev-master": "10.x-dev" | ||||||
|  |         }, | ||||||
|  |         "laravel": { | ||||||
|  |             "dont-discover": [] | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "config": { | ||||||
|  |         "optimize-autoloader": true, | ||||||
|  |         "preferred-install": "dist", | ||||||
|  |         "sort-packages": true, | ||||||
|  |         "allow-plugins": { | ||||||
|  |             "pestphp/pest-plugin": true | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "minimum-stability": "stable", | ||||||
|  |     "prefer-stable": true | ||||||
| } | } | ||||||
							
								
								
									
										4043
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4043
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,5 +1,7 @@ | |||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
|  | use Illuminate\Support\Facades\Facade; | ||||||
|  | 
 | ||||||
| return [ | return [ | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
| @@ -39,7 +41,7 @@ return [ | |||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'debug' => (bool) env('APP_DEBUG', true), |     'debug' => (bool) env('APP_DEBUG', false), | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
| @@ -54,7 +56,7 @@ return [ | |||||||
| 
 | 
 | ||||||
|     'url' => env('APP_URL', 'http://localhost'), |     'url' => env('APP_URL', 'http://localhost'), | ||||||
| 
 | 
 | ||||||
|     'asset_url' => env('ASSET_URL', null), |     'asset_url' => env('ASSET_URL', '/'), | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
| @@ -123,6 +125,24 @@ return [ | |||||||
| 
 | 
 | ||||||
|     'cipher' => 'AES-256-CBC', |     'cipher' => 'AES-256-CBC', | ||||||
| 
 | 
 | ||||||
|  |     /* | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | Maintenance Mode Driver | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | | ||||||
|  |     | These configuration options determine the driver used to determine and | ||||||
|  |     | manage Laravel's "maintenance mode" status. The "cache" driver will | ||||||
|  |     | allow maintenance mode to be controlled across multiple machines. | ||||||
|  |     | | ||||||
|  |     | Supported drivers: "file", "cache" | ||||||
|  |     | | ||||||
|  |     */ | ||||||
|  | 
 | ||||||
|  |     'maintenance' => [ | ||||||
|  |         'driver' => 'file', | ||||||
|  |         // 'store'  => 'redis',
 | ||||||
|  |     ], | ||||||
|  | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
|     | Autoloaded Service Providers |     | Autoloaded Service Providers | ||||||
| @@ -165,11 +185,11 @@ return [ | |||||||
|         /* |         /* | ||||||
|          * Package Service Providers... |          * Package Service Providers... | ||||||
|          */ |          */ | ||||||
|         Barryvdh\Debugbar\ServiceProvider::class, |  | ||||||
| 
 | 
 | ||||||
|         /* |         /* | ||||||
|          * Application Service Providers... |          * Application Service Providers... | ||||||
|          */ |          */ | ||||||
|  |          | ||||||
|         App\Providers\AppServiceProvider::class, |         App\Providers\AppServiceProvider::class, | ||||||
|         App\Providers\AuthServiceProvider::class, |         App\Providers\AuthServiceProvider::class, | ||||||
|         // App\Providers\BroadcastServiceProvider::class,
 |         // App\Providers\BroadcastServiceProvider::class,
 | ||||||
| @@ -189,45 +209,9 @@ return [ | |||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'aliases' => [ |     'aliases' => Facade::defaultAliases()->merge([ | ||||||
| 
 |  | ||||||
|         'App' => Illuminate\Support\Facades\App::class, |  | ||||||
|         'Arr' => Illuminate\Support\Arr::class, |  | ||||||
|         'Artisan' => Illuminate\Support\Facades\Artisan::class, |  | ||||||
|         'Auth' => Illuminate\Support\Facades\Auth::class, |  | ||||||
|         'Blade' => Illuminate\Support\Facades\Blade::class, |  | ||||||
|         'Broadcast' => Illuminate\Support\Facades\Broadcast::class, |  | ||||||
|         'Bus' => Illuminate\Support\Facades\Bus::class, |  | ||||||
|         'Cache' => Illuminate\Support\Facades\Cache::class, |  | ||||||
|         'Config' => Illuminate\Support\Facades\Config::class, |  | ||||||
|         'Cookie' => Illuminate\Support\Facades\Cookie::class, |  | ||||||
|         'Crypt' => Illuminate\Support\Facades\Crypt::class, |  | ||||||
|         'DB' => Illuminate\Support\Facades\DB::class, |  | ||||||
|         'Eloquent' => Illuminate\Database\Eloquent\Model::class, |  | ||||||
|         'Event' => Illuminate\Support\Facades\Event::class, |  | ||||||
|         'File' => Illuminate\Support\Facades\File::class, |  | ||||||
|         'Gate' => Illuminate\Support\Facades\Gate::class, |  | ||||||
|         'Hash' => Illuminate\Support\Facades\Hash::class, |  | ||||||
|         'Http' => Illuminate\Support\Facades\Http::class, |  | ||||||
|         'Lang' => Illuminate\Support\Facades\Lang::class, |  | ||||||
|         'Log' => Illuminate\Support\Facades\Log::class, |  | ||||||
|         'Mail' => Illuminate\Support\Facades\Mail::class, |  | ||||||
|         'Notification' => Illuminate\Support\Facades\Notification::class, |  | ||||||
|         'Password' => Illuminate\Support\Facades\Password::class, |  | ||||||
|         'Queue' => Illuminate\Support\Facades\Queue::class, |  | ||||||
|         'Redirect' => Illuminate\Support\Facades\Redirect::class, |  | ||||||
|         'Redis' => Illuminate\Support\Facades\Redis::class, |  | ||||||
|         'Request' => Illuminate\Support\Facades\Request::class, |  | ||||||
|         'Response' => Illuminate\Support\Facades\Response::class, |  | ||||||
|         'Route' => Illuminate\Support\Facades\Route::class, |  | ||||||
|         'Schema' => Illuminate\Support\Facades\Schema::class, |  | ||||||
|         'Session' => Illuminate\Support\Facades\Session::class, |  | ||||||
|         'Storage' => Illuminate\Support\Facades\Storage::class, |  | ||||||
|         'Str' => Illuminate\Support\Str::class, |  | ||||||
|         'URL' => Illuminate\Support\Facades\URL::class, |  | ||||||
|         'Validator' => Illuminate\Support\Facades\Validator::class, |  | ||||||
|         'View' => Illuminate\Support\Facades\View::class, |  | ||||||
|         'Debugbar' => Barryvdh\Debugbar\Facades\Debugbar::class, |         'Debugbar' => Barryvdh\Debugbar\Facades\Debugbar::class, | ||||||
|     ], |         // 'ExampleClass' => App\Example\ExampleClass::class,
 | ||||||
|  |     ])->toArray(), | ||||||
| 
 | 
 | ||||||
| ]; | ]; | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ return [ | |||||||
|     | users are actually retrieved out of your database or other storage |     | users are actually retrieved out of your database or other storage | ||||||
|     | mechanisms used by this application to persist your user's data. |     | mechanisms used by this application to persist your user's data. | ||||||
|     | |     | | ||||||
|     | Supported: "session", "token" |     | Supported: "session" | ||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
| @@ -40,12 +40,6 @@ return [ | |||||||
|             'driver' => 'session', |             'driver' => 'session', | ||||||
|             'provider' => 'users', |             'provider' => 'users', | ||||||
|         ], |         ], | ||||||
| 
 |  | ||||||
|         'api' => [ |  | ||||||
|             'driver' => 'token', |  | ||||||
|             'provider' => 'users', |  | ||||||
|             'hash' => false, |  | ||||||
|         ], |  | ||||||
|     ], |     ], | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
| @@ -68,7 +62,7 @@ return [ | |||||||
|     'providers' => [ |     'providers' => [ | ||||||
|         'users' => [ |         'users' => [ | ||||||
|             'driver' => 'eloquent', |             'driver' => 'eloquent', | ||||||
|             'model' => App\User::class, |             'model' => App\Models\User::class, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         // 'users' => [
 |         // 'users' => [
 | ||||||
| @@ -86,16 +80,20 @@ return [ | |||||||
|     | than one user table or model in the application and you want to have |     | than one user table or model in the application and you want to have | ||||||
|     | separate password reset settings based on the specific user types. |     | separate password reset settings based on the specific user types. | ||||||
|     | |     | | ||||||
|     | The expire time is the number of minutes that the reset token should be |     | The expire time is the number of minutes that each reset token will be | ||||||
|     | considered valid. This security feature keeps tokens short-lived so |     | considered valid. This security feature keeps tokens short-lived so | ||||||
|     | they have less time to be guessed. You may change this as needed. |     | they have less time to be guessed. You may change this as needed. | ||||||
|     | |     | | ||||||
|  |     | The throttle setting is the number of seconds a user must wait before | ||||||
|  |     | generating more password reset tokens. This prevents the user from | ||||||
|  |     | quickly generating a very large amount of password reset tokens. | ||||||
|  |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'passwords' => [ |     'passwords' => [ | ||||||
|         'users' => [ |         'users' => [ | ||||||
|             'provider' => 'users', |             'provider' => 'users', | ||||||
|             'table' => 'password_resets', |             'table' => 'password_reset_tokens', | ||||||
|             'expire' => 60, |             'expire' => 60, | ||||||
|             'throttle' => 60, |             'throttle' => 60, | ||||||
|         ], |         ], | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ return [ | |||||||
|     | framework when an event needs to be broadcast. You may set this to |     | framework when an event needs to be broadcast. You may set this to | ||||||
|     | any of the connections defined in the "connections" array below. |     | any of the connections defined in the "connections" array below. | ||||||
|     | |     | | ||||||
|     | Supported: "pusher", "redis", "log", "null" |     | Supported: "pusher", "ably", "redis", "log", "null" | ||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
| @@ -36,9 +36,20 @@ return [ | |||||||
|             'secret' => env('PUSHER_APP_SECRET'), |             'secret' => env('PUSHER_APP_SECRET'), | ||||||
|             'app_id' => env('PUSHER_APP_ID'), |             'app_id' => env('PUSHER_APP_ID'), | ||||||
|             'options' => [ |             'options' => [ | ||||||
|                 'cluster' => env('PUSHER_APP_CLUSTER'), |                 'host' => env('PUSHER_HOST') ?: 'api-'.env('PUSHER_APP_CLUSTER', 'mt1').'.pusher.com', | ||||||
|                 'useTLS' => true, |                 'port' => env('PUSHER_PORT', 443), | ||||||
|  |                 'scheme' => env('PUSHER_SCHEME', 'https'), | ||||||
|  |                 'encrypted' => true, | ||||||
|  |                 'useTLS' => env('PUSHER_SCHEME', 'https') === 'https', | ||||||
|             ], |             ], | ||||||
|  |             'client_options' => [ | ||||||
|  |                 // Guzzle client options: https://docs.guzzlephp.org/en/stable/request-options.html
 | ||||||
|  |             ], | ||||||
|  |         ], | ||||||
|  | 
 | ||||||
|  |         'ably' => [ | ||||||
|  |             'driver' => 'ably', | ||||||
|  |             'key' => env('ABLY_KEY'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'redis' => [ |         'redis' => [ | ||||||
|   | |||||||
| @@ -13,9 +13,6 @@ return [ | |||||||
|     | using this caching library. This connection is used when another is |     | using this caching library. This connection is used when another is | ||||||
|     | not explicitly specified when executing a given caching function. |     | not explicitly specified when executing a given caching function. | ||||||
|     | |     | | ||||||
|     | Supported: "apc", "array", "database", "file", |  | ||||||
|     |            "memcached", "redis", "dynamodb" |  | ||||||
|     | |  | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'default' => env('CACHE_DRIVER', 'file'), |     'default' => env('CACHE_DRIVER', 'file'), | ||||||
| @@ -29,6 +26,9 @@ return [ | |||||||
|     | well as their drivers. You may even define multiple stores for the |     | well as their drivers. You may even define multiple stores for the | ||||||
|     | same cache driver to group types of items stored in your caches. |     | same cache driver to group types of items stored in your caches. | ||||||
|     | |     | | ||||||
|  |     | Supported drivers: "apc", "array", "database", "file", | ||||||
|  |     |         "memcached", "redis", "dynamodb", "octane", "null" | ||||||
|  |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'stores' => [ |     'stores' => [ | ||||||
| @@ -46,6 +46,7 @@ return [ | |||||||
|             'driver' => 'database', |             'driver' => 'database', | ||||||
|             'table' => 'cache', |             'table' => 'cache', | ||||||
|             'connection' => null, |             'connection' => null, | ||||||
|  |             'lock_connection' => null, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'file' => [ |         'file' => [ | ||||||
| @@ -75,6 +76,7 @@ return [ | |||||||
|         'redis' => [ |         'redis' => [ | ||||||
|             'driver' => 'redis', |             'driver' => 'redis', | ||||||
|             'connection' => 'cache', |             'connection' => 'cache', | ||||||
|  |             'lock_connection' => 'default', | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'dynamodb' => [ |         'dynamodb' => [ | ||||||
| @@ -86,6 +88,10 @@ return [ | |||||||
|             'endpoint' => env('DYNAMODB_ENDPOINT'), |             'endpoint' => env('DYNAMODB_ENDPOINT'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|  |         'octane' => [ | ||||||
|  |             'driver' => 'octane', | ||||||
|  |         ], | ||||||
|  | 
 | ||||||
|     ], |     ], | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
| @@ -93,12 +99,12 @@ return [ | |||||||
|     | Cache Key Prefix |     | Cache Key Prefix | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
|     | |     | | ||||||
|     | When utilizing a RAM based store such as APC or Memcached, there might |     | When utilizing the APC, database, memcached, Redis, or DynamoDB cache | ||||||
|     | be other applications utilizing the same cache. So, we'll specify a |     | stores there might be other applications using the same cache. For | ||||||
|     | value to get prefixed to all our keys so we can avoid collisions. |     | that reason, you may prefix every cache key to avoid collisions. | ||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'prefix' => env('CACHE_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_cache'), |     'prefix' => env('CACHE_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_cache_'), | ||||||
| 
 | 
 | ||||||
| ]; | ]; | ||||||
| @@ -15,7 +15,7 @@ return [ | |||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'paths' => ['api/*'], |     'paths' => ['api/*', 'sanctum/csrf-cookie'], | ||||||
| 
 | 
 | ||||||
|     'allowed_methods' => ['*'], |     'allowed_methods' => ['*'], | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -74,7 +74,7 @@ return [ | |||||||
|             'charset' => 'utf8', |             'charset' => 'utf8', | ||||||
|             'prefix' => '', |             'prefix' => '', | ||||||
|             'prefix_indexes' => true, |             'prefix_indexes' => true, | ||||||
|             'schema' => 'public', |             'search_path' => 'public', | ||||||
|             'sslmode' => 'prefer', |             'sslmode' => 'prefer', | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
| @@ -89,6 +89,8 @@ return [ | |||||||
|             'charset' => 'utf8', |             'charset' => 'utf8', | ||||||
|             'prefix' => '', |             'prefix' => '', | ||||||
|             'prefix_indexes' => true, |             'prefix_indexes' => true, | ||||||
|  |             // 'encrypt' => env('DB_ENCRYPT', 'yes'),
 | ||||||
|  |             // 'trust_server_certificate' => env('DB_TRUST_SERVER_CERTIFICATE', 'false'),
 | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|     ], |     ], | ||||||
| @@ -129,7 +131,8 @@ return [ | |||||||
|         'default' => [ |         'default' => [ | ||||||
|             'url' => env('REDIS_URL'), |             'url' => env('REDIS_URL'), | ||||||
|             'host' => env('REDIS_HOST', '127.0.0.1'), |             'host' => env('REDIS_HOST', '127.0.0.1'), | ||||||
|             'password' => env('REDIS_PASSWORD', null), |             'username' => env('REDIS_USERNAME'), | ||||||
|  |             'password' => env('REDIS_PASSWORD'), | ||||||
|             'port' => env('REDIS_PORT', '6379'), |             'port' => env('REDIS_PORT', '6379'), | ||||||
|             'database' => env('REDIS_DB', '0'), |             'database' => env('REDIS_DB', '0'), | ||||||
|         ], |         ], | ||||||
| @@ -137,7 +140,8 @@ return [ | |||||||
|         'cache' => [ |         'cache' => [ | ||||||
|             'url' => env('REDIS_URL'), |             'url' => env('REDIS_URL'), | ||||||
|             'host' => env('REDIS_HOST', '127.0.0.1'), |             'host' => env('REDIS_HOST', '127.0.0.1'), | ||||||
|             'password' => env('REDIS_PASSWORD', null), |             'username' => env('REDIS_USERNAME'), | ||||||
|  |             'password' => env('REDIS_PASSWORD'), | ||||||
|             'port' => env('REDIS_PORT', '6379'), |             'port' => env('REDIS_PORT', '6379'), | ||||||
|             'database' => env('REDIS_CACHE_DB', '1'), |             'database' => env('REDIS_CACHE_DB', '1'), | ||||||
|         ], |         ], | ||||||
|   | |||||||
| @@ -13,20 +13,7 @@ return [ | |||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'default' => env('FILESYSTEM_DRIVER', 'local'), |     'default' => env('FILESYSTEM_DISK', 'local'), | ||||||
| 
 |  | ||||||
|     /* |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | Default Cloud Filesystem Disk |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | |  | ||||||
|     | Many applications store files both locally and in the cloud. For this |  | ||||||
|     | reason, you may specify a default "cloud" driver here. This driver |  | ||||||
|     | will be bound as the Cloud disk implementation in the container. |  | ||||||
|     | |  | ||||||
|     */ |  | ||||||
| 
 |  | ||||||
|     'cloud' => env('FILESYSTEM_CLOUD', 's3'), |  | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
| @@ -35,7 +22,7 @@ return [ | |||||||
|     | |     | | ||||||
|     | Here you may configure as many filesystem "disks" as you wish, and you |     | Here you may configure as many filesystem "disks" as you wish, and you | ||||||
|     | may even configure multiple disks of the same driver. Defaults have |     | may even configure multiple disks of the same driver. Defaults have | ||||||
|     | been setup for each driver as an example of the required options. |     | been set up for each driver as an example of the required values. | ||||||
|     | |     | | ||||||
|     | Supported Drivers: "local", "ftp", "sftp", "s3" |     | Supported Drivers: "local", "ftp", "sftp", "s3" | ||||||
|     | |     | | ||||||
| @@ -46,6 +33,7 @@ return [ | |||||||
|         'local' => [ |         'local' => [ | ||||||
|             'driver' => 'local', |             'driver' => 'local', | ||||||
|             'root' => storage_path('app'), |             'root' => storage_path('app'), | ||||||
|  |             'throw' => false, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'public' => [ |         'public' => [ | ||||||
| @@ -53,6 +41,7 @@ return [ | |||||||
|             'root' => storage_path('app/public'), |             'root' => storage_path('app/public'), | ||||||
|             'url' => env('APP_URL').'/storage', |             'url' => env('APP_URL').'/storage', | ||||||
|             'visibility' => 'public', |             'visibility' => 'public', | ||||||
|  |             'throw' => false, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         's3' => [ |         's3' => [ | ||||||
| @@ -63,6 +52,8 @@ return [ | |||||||
|             'bucket' => env('AWS_BUCKET'), |             'bucket' => env('AWS_BUCKET'), | ||||||
|             'url' => env('AWS_URL'), |             'url' => env('AWS_URL'), | ||||||
|             'endpoint' => env('AWS_ENDPOINT'), |             'endpoint' => env('AWS_ENDPOINT'), | ||||||
|  |             'use_path_style_endpoint' => env('AWS_USE_PATH_STYLE_ENDPOINT', false), | ||||||
|  |             'throw' => false, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|     ], |     ], | ||||||
|   | |||||||
| @@ -44,9 +44,9 @@ return [ | |||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'argon' => [ |     'argon' => [ | ||||||
|         'memory' => 1024, |         'memory' => 65536, | ||||||
|         'threads' => 2, |         'threads' => 1, | ||||||
|         'time' => 2, |         'time' => 4, | ||||||
|     ], |     ], | ||||||
| 
 | 
 | ||||||
| ]; | ]; | ||||||
|   | |||||||
| @@ -19,6 +19,22 @@ return [ | |||||||
| 
 | 
 | ||||||
|     'default' => env('LOG_CHANNEL', 'stack'), |     'default' => env('LOG_CHANNEL', 'stack'), | ||||||
| 
 | 
 | ||||||
|  |     /* | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | Deprecations Log Channel | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | | ||||||
|  |     | This option controls the log channel that should be used to log warnings | ||||||
|  |     | regarding deprecated PHP and library features. This allows you to get | ||||||
|  |     | your application ready for upcoming major versions of dependencies. | ||||||
|  |     | | ||||||
|  |     */ | ||||||
|  | 
 | ||||||
|  |     'deprecations' => [ | ||||||
|  |         'channel' => env('LOG_DEPRECATIONS_CHANNEL', 'null'), | ||||||
|  |         'trace' => false, | ||||||
|  |     ], | ||||||
|  | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
|     | Log Channels |     | Log Channels | ||||||
| @@ -44,13 +60,13 @@ return [ | |||||||
|         'single' => [ |         'single' => [ | ||||||
|             'driver' => 'single', |             'driver' => 'single', | ||||||
|             'path' => storage_path('logs/laravel.log'), |             'path' => storage_path('logs/laravel.log'), | ||||||
|             'level' => 'debug', |             'level' => env('LOG_LEVEL', 'debug'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'daily' => [ |         'daily' => [ | ||||||
|             'driver' => 'daily', |             'driver' => 'daily', | ||||||
|             'path' => storage_path('logs/laravel.log'), |             'path' => storage_path('logs/laravel.log'), | ||||||
|             'level' => 'debug', |             'level' => env('LOG_LEVEL', 'debug'), | ||||||
|             'days' => 14, |             'days' => 14, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
| @@ -59,21 +75,23 @@ return [ | |||||||
|             'url' => env('LOG_SLACK_WEBHOOK_URL'), |             'url' => env('LOG_SLACK_WEBHOOK_URL'), | ||||||
|             'username' => 'Laravel Log', |             'username' => 'Laravel Log', | ||||||
|             'emoji' => ':boom:', |             'emoji' => ':boom:', | ||||||
|             'level' => 'critical', |             'level' => env('LOG_LEVEL', 'critical'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'papertrail' => [ |         'papertrail' => [ | ||||||
|             'driver' => 'monolog', |             'driver' => 'monolog', | ||||||
|             'level' => 'debug', |             'level' => env('LOG_LEVEL', 'debug'), | ||||||
|             'handler' => SyslogUdpHandler::class, |             'handler' => env('LOG_PAPERTRAIL_HANDLER', SyslogUdpHandler::class), | ||||||
|             'handler_with' => [ |             'handler_with' => [ | ||||||
|                 'host' => env('PAPERTRAIL_URL'), |                 'host' => env('PAPERTRAIL_URL'), | ||||||
|                 'port' => env('PAPERTRAIL_PORT'), |                 'port' => env('PAPERTRAIL_PORT'), | ||||||
|  |                 'connectionString' => 'tls://'.env('PAPERTRAIL_URL').':'.env('PAPERTRAIL_PORT'), | ||||||
|             ], |             ], | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'stderr' => [ |         'stderr' => [ | ||||||
|             'driver' => 'monolog', |             'driver' => 'monolog', | ||||||
|  |             'level' => env('LOG_LEVEL', 'debug'), | ||||||
|             'handler' => StreamHandler::class, |             'handler' => StreamHandler::class, | ||||||
|             'formatter' => env('LOG_STDERR_FORMATTER'), |             'formatter' => env('LOG_STDERR_FORMATTER'), | ||||||
|             'with' => [ |             'with' => [ | ||||||
| @@ -83,12 +101,12 @@ return [ | |||||||
| 
 | 
 | ||||||
|         'syslog' => [ |         'syslog' => [ | ||||||
|             'driver' => 'syslog', |             'driver' => 'syslog', | ||||||
|             'level' => 'debug', |             'level' => env('LOG_LEVEL', 'debug'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'errorlog' => [ |         'errorlog' => [ | ||||||
|             'driver' => 'errorlog', |             'driver' => 'errorlog', | ||||||
|             'level' => 'debug', |             'level' => env('LOG_LEVEL', 'debug'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'null' => [ |         'null' => [ | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ return [ | |||||||
|     | mailers below. You are free to add additional mailers as required. |     | mailers below. You are free to add additional mailers as required. | ||||||
|     | |     | | ||||||
|     | Supported: "smtp", "sendmail", "mailgun", "ses", |     | Supported: "smtp", "sendmail", "mailgun", "ses", | ||||||
|     |            "postmark", "log", "array" |     |            "postmark", "log", "array", "failover" | ||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
| @@ -42,6 +42,7 @@ return [ | |||||||
|             'username' => env('MAIL_USERNAME'), |             'username' => env('MAIL_USERNAME'), | ||||||
|             'password' => env('MAIL_PASSWORD'), |             'password' => env('MAIL_PASSWORD'), | ||||||
|             'timeout' => null, |             'timeout' => null, | ||||||
|  |             'local_domain' => env('MAIL_EHLO_DOMAIN'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'ses' => [ |         'ses' => [ | ||||||
| @@ -50,15 +51,21 @@ return [ | |||||||
| 
 | 
 | ||||||
|         'mailgun' => [ |         'mailgun' => [ | ||||||
|             'transport' => 'mailgun', |             'transport' => 'mailgun', | ||||||
|  |             // 'client' => [
 | ||||||
|  |             //     'timeout' => 5,
 | ||||||
|  |             // ],
 | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'postmark' => [ |         'postmark' => [ | ||||||
|             'transport' => 'postmark', |             'transport' => 'postmark', | ||||||
|  |             // 'client' => [
 | ||||||
|  |             //     'timeout' => 5,
 | ||||||
|  |             // ],
 | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'sendmail' => [ |         'sendmail' => [ | ||||||
|             'transport' => 'sendmail', |             'transport' => 'sendmail', | ||||||
|             'path' => '/usr/sbin/sendmail -bs', |             'path' => env('MAIL_SENDMAIL_PATH', '/usr/sbin/sendmail -bs -i'), | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'log' => [ |         'log' => [ | ||||||
| @@ -69,6 +76,14 @@ return [ | |||||||
|         'array' => [ |         'array' => [ | ||||||
|             'transport' => 'array', |             'transport' => 'array', | ||||||
|         ], |         ], | ||||||
|  | 
 | ||||||
|  |         'failover' => [ | ||||||
|  |             'transport' => 'failover', | ||||||
|  |             'mailers' => [ | ||||||
|  |                 'smtp', | ||||||
|  |                 'log', | ||||||
|  |             ], | ||||||
|  |         ], | ||||||
|     ], |     ], | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|   | |||||||
| @@ -39,6 +39,7 @@ return [ | |||||||
|             'table' => 'jobs', |             'table' => 'jobs', | ||||||
|             'queue' => 'default', |             'queue' => 'default', | ||||||
|             'retry_after' => 90, |             'retry_after' => 90, | ||||||
|  |             'after_commit' => false, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'beanstalkd' => [ |         'beanstalkd' => [ | ||||||
| @@ -47,6 +48,7 @@ return [ | |||||||
|             'queue' => 'default', |             'queue' => 'default', | ||||||
|             'retry_after' => 90, |             'retry_after' => 90, | ||||||
|             'block_for' => 0, |             'block_for' => 0, | ||||||
|  |             'after_commit' => false, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'sqs' => [ |         'sqs' => [ | ||||||
| @@ -54,9 +56,10 @@ return [ | |||||||
|             'key' => env('AWS_ACCESS_KEY_ID'), |             'key' => env('AWS_ACCESS_KEY_ID'), | ||||||
|             'secret' => env('AWS_SECRET_ACCESS_KEY'), |             'secret' => env('AWS_SECRET_ACCESS_KEY'), | ||||||
|             'prefix' => env('SQS_PREFIX', 'https://sqs.us-east-1.amazonaws.com/your-account-id'), |             'prefix' => env('SQS_PREFIX', 'https://sqs.us-east-1.amazonaws.com/your-account-id'), | ||||||
|             'queue' => env('SQS_QUEUE', 'your-queue-name'), |             'queue' => env('SQS_QUEUE', 'default'), | ||||||
|             'suffix' => env('SQS_SUFFIX'), |             'suffix' => env('SQS_SUFFIX'), | ||||||
|             'region' => env('AWS_DEFAULT_REGION', 'us-east-1'), |             'region' => env('AWS_DEFAULT_REGION', 'us-east-1'), | ||||||
|  |             'after_commit' => false, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|         'redis' => [ |         'redis' => [ | ||||||
| @@ -65,6 +68,7 @@ return [ | |||||||
|             'queue' => env('REDIS_QUEUE', 'default'), |             'queue' => env('REDIS_QUEUE', 'default'), | ||||||
|             'retry_after' => 90, |             'retry_after' => 90, | ||||||
|             'block_for' => null, |             'block_for' => null, | ||||||
|  |             'after_commit' => false, | ||||||
|         ], |         ], | ||||||
| 
 | 
 | ||||||
|     ], |     ], | ||||||
| @@ -81,7 +85,7 @@ return [ | |||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'failed' => [ |     'failed' => [ | ||||||
|         'driver' => env('QUEUE_FAILED_DRIVER', 'database'), |         'driver' => env('QUEUE_FAILED_DRIVER', 'database-uuids'), | ||||||
|         'database' => env('DB_CONNECTION', 'mysql'), |         'database' => env('DB_CONNECTION', 'mysql'), | ||||||
|         'table' => 'failed_jobs', |         'table' => 'failed_jobs', | ||||||
|     ], |     ], | ||||||
|   | |||||||
							
								
								
									
										67
									
								
								config/sanctum.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								config/sanctum.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | use Laravel\Sanctum\Sanctum; | ||||||
|  | 
 | ||||||
|  | return [ | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | Stateful Domains | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | | ||||||
|  |     | Requests from the following domains / hosts will receive stateful API | ||||||
|  |     | authentication cookies. Typically, these should include your local | ||||||
|  |     | and production domains which access your API via a frontend SPA. | ||||||
|  |     | | ||||||
|  |     */ | ||||||
|  | 
 | ||||||
|  |     'stateful' => explode(',', env('SANCTUM_STATEFUL_DOMAINS', sprintf( | ||||||
|  |         '%s%s', | ||||||
|  |         'localhost,localhost:3000,127.0.0.1,127.0.0.1:8000,::1', | ||||||
|  |         Sanctum::currentApplicationUrlWithPort() | ||||||
|  |     ))), | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | Sanctum Guards | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | | ||||||
|  |     | This array contains the authentication guards that will be checked when | ||||||
|  |     | Sanctum is trying to authenticate a request. If none of these guards | ||||||
|  |     | are able to authenticate the request, Sanctum will use the bearer | ||||||
|  |     | token that's present on an incoming request for authentication. | ||||||
|  |     | | ||||||
|  |     */ | ||||||
|  | 
 | ||||||
|  |     'guard' => ['web'], | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | Expiration Minutes | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | | ||||||
|  |     | This value controls the number of minutes until an issued token will be | ||||||
|  |     | considered expired. If this value is null, personal access tokens do | ||||||
|  |     | not expire. This won't tweak the lifetime of first-party sessions. | ||||||
|  |     | | ||||||
|  |     */ | ||||||
|  | 
 | ||||||
|  |     'expiration' => null, | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | Sanctum Middleware | ||||||
|  |     |-------------------------------------------------------------------------- | ||||||
|  |     | | ||||||
|  |     | When authenticating your first-party SPA with Sanctum you may need to | ||||||
|  |     | customize some of the middleware Sanctum uses while processing the | ||||||
|  |     | request. You may change the middleware listed below as required. | ||||||
|  |     | | ||||||
|  |     */ | ||||||
|  | 
 | ||||||
|  |     'middleware' => [ | ||||||
|  |         'verify_csrf_token' => App\Http\Middleware\VerifyCsrfToken::class, | ||||||
|  |         'encrypt_cookies' => App\Http\Middleware\EncryptCookies::class, | ||||||
|  |     ], | ||||||
|  | 
 | ||||||
|  | ]; | ||||||
| @@ -18,6 +18,7 @@ return [ | |||||||
|         'domain' => env('MAILGUN_DOMAIN'), |         'domain' => env('MAILGUN_DOMAIN'), | ||||||
|         'secret' => env('MAILGUN_SECRET'), |         'secret' => env('MAILGUN_SECRET'), | ||||||
|         'endpoint' => env('MAILGUN_ENDPOINT', 'api.mailgun.net'), |         'endpoint' => env('MAILGUN_ENDPOINT', 'api.mailgun.net'), | ||||||
|  |         'scheme' => 'https', | ||||||
|     ], |     ], | ||||||
| 
 | 
 | ||||||
|     'postmark' => [ |     'postmark' => [ | ||||||
|   | |||||||
| @@ -72,7 +72,7 @@ return [ | |||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'connection' => env('SESSION_CONNECTION', null), |     'connection' => env('SESSION_CONNECTION'), | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
| @@ -92,13 +92,15 @@ return [ | |||||||
|     | Session Cache Store |     | Session Cache Store | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
|     | |     | | ||||||
|     | When using the "apc", "memcached", or "dynamodb" session drivers you may |     | While using one of the framework's cache driven session backends you may | ||||||
|     | list a cache store that should be used for these sessions. This value |     | list a cache store that should be used for these sessions. This value | ||||||
|     | must match with one of the application's configured cache "stores". |     | must match with one of the application's configured cache "stores". | ||||||
|     | |     | | ||||||
|  |     | Affects: "apc", "dynamodb", "memcached", "redis" | ||||||
|  |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'store' => env('SESSION_STORE', null), |     'store' => env('SESSION_STORE'), | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
| @@ -153,7 +155,7 @@ return [ | |||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     'domain' => env('SESSION_DOMAIN', null), |     'domain' => env('SESSION_DOMAIN'), | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
| @@ -162,7 +164,7 @@ return [ | |||||||
|     | |     | | ||||||
|     | By setting this option to true, session cookies will only be sent back |     | By setting this option to true, session cookies will only be sent back | ||||||
|     | to the server if the browser has a HTTPS connection. This will keep |     | to the server if the browser has a HTTPS connection. This will keep | ||||||
|     | the cookie from being sent to you if it can not be done securely. |     | the cookie from being sent to you when it can't be done securely. | ||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								database/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								database/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,2 +1 @@ | |||||||
| *.sqlite | *.sqlite* | ||||||
| *.sqlite-journal |  | ||||||
| @@ -1,28 +1,40 @@ | |||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
| /** @var \Illuminate\Database\Eloquent\Factory $factory */ | namespace Database\Factories; | ||||||
| 
 | 
 | ||||||
| use App\User; | use Illuminate\Database\Eloquent\Factories\Factory; | ||||||
| use Faker\Generator as Faker; |  | ||||||
| use Illuminate\Support\Str; | use Illuminate\Support\Str; | ||||||
| 
 | 
 | ||||||
| /* | /** | ||||||
| |-------------------------------------------------------------------------- |  * @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\User> | ||||||
| | Model Factories |  */ | ||||||
| |-------------------------------------------------------------------------- | class UserFactory extends Factory | ||||||
| | | { | ||||||
| | This directory should contain each of the model factory definitions for |     /** | ||||||
| | your application. Factories provide a convenient way to generate new |      * Define the model's default state. | ||||||
| | model instances for testing / seeding your application's database. |      * | ||||||
| | |      * @return array<string, mixed> | ||||||
| */ |      */ | ||||||
|  |     public function definition(): array | ||||||
|  |     { | ||||||
|  |         return [ | ||||||
|  |             'name' => fake()->name(), | ||||||
|  |             'email' => fake()->unique()->safeEmail(), | ||||||
|  |             'email_verified_at' => now(), | ||||||
|  |             'password' => '$2y$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', // password
 | ||||||
|  |             'remember_token' => Str::random(10), | ||||||
|  |         ]; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
| $factory->define(User::class, function (Faker $faker) { |     /** | ||||||
|     return [ |      * Indicate that the model's email address should be unverified. | ||||||
|         'name' => $faker->name, |      * | ||||||
|         'email' => $faker->unique()->safeEmail, |      * @return $this | ||||||
|         'email_verified_at' => now(), |      */ | ||||||
|         'password' => '$2y$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', // password
 |     public function unverified(): static | ||||||
|         'remember_token' => Str::random(10), |     { | ||||||
|     ]; |         return $this->state(fn (array $attributes) => [ | ||||||
| }); |             'email_verified_at' => null, | ||||||
|  |         ]); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -4,14 +4,12 @@ use Illuminate\Database\Migrations\Migration; | |||||||
| use Illuminate\Database\Schema\Blueprint; | use Illuminate\Database\Schema\Blueprint; | ||||||
| use Illuminate\Support\Facades\Schema; | use Illuminate\Support\Facades\Schema; | ||||||
| 
 | 
 | ||||||
| class CreateUsersTable extends Migration | return new class extends Migration | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Run the migrations. |      * Run the migrations. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function up() |     public function up(): void | ||||||
|     { |     { | ||||||
|         Schema::create('users', function (Blueprint $table) { |         Schema::create('users', function (Blueprint $table) { | ||||||
|             $table->id(); |             $table->id(); | ||||||
| @@ -26,11 +24,9 @@ class CreateUsersTable extends Migration | |||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Reverse the migrations. |      * Reverse the migrations. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function down() |     public function down(): void | ||||||
|     { |     { | ||||||
|         Schema::dropIfExists('users'); |         Schema::dropIfExists('users'); | ||||||
|     } |     } | ||||||
| } | }; | ||||||
| @@ -0,0 +1,28 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | use Illuminate\Database\Migrations\Migration; | ||||||
|  | use Illuminate\Database\Schema\Blueprint; | ||||||
|  | use Illuminate\Support\Facades\Schema; | ||||||
|  | 
 | ||||||
|  | return new class extends Migration | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Run the migrations. | ||||||
|  |      */ | ||||||
|  |     public function up(): void | ||||||
|  |     { | ||||||
|  |         Schema::create('password_reset_tokens', function (Blueprint $table) { | ||||||
|  |             $table->string('email')->primary(); | ||||||
|  |             $table->string('token'); | ||||||
|  |             $table->timestamp('created_at')->nullable(); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Reverse the migrations. | ||||||
|  |      */ | ||||||
|  |     public function down(): void | ||||||
|  |     { | ||||||
|  |         Schema::dropIfExists('password_reset_tokens'); | ||||||
|  |     } | ||||||
|  | }; | ||||||
| @@ -4,17 +4,16 @@ use Illuminate\Database\Migrations\Migration; | |||||||
| use Illuminate\Database\Schema\Blueprint; | use Illuminate\Database\Schema\Blueprint; | ||||||
| use Illuminate\Support\Facades\Schema; | use Illuminate\Support\Facades\Schema; | ||||||
| 
 | 
 | ||||||
| class CreateFailedJobsTable extends Migration | return new class extends Migration | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Run the migrations. |      * Run the migrations. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function up() |     public function up(): void | ||||||
|     { |     { | ||||||
|         Schema::create('failed_jobs', function (Blueprint $table) { |         Schema::create('failed_jobs', function (Blueprint $table) { | ||||||
|             $table->id(); |             $table->id(); | ||||||
|  |             $table->string('uuid')->unique(); | ||||||
|             $table->text('connection'); |             $table->text('connection'); | ||||||
|             $table->text('queue'); |             $table->text('queue'); | ||||||
|             $table->longText('payload'); |             $table->longText('payload'); | ||||||
| @@ -25,11 +24,9 @@ class CreateFailedJobsTable extends Migration | |||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * Reverse the migrations. |      * Reverse the migrations. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function down() |     public function down(): void | ||||||
|     { |     { | ||||||
|         Schema::dropIfExists('failed_jobs'); |         Schema::dropIfExists('failed_jobs'); | ||||||
|     } |     } | ||||||
| } | }; | ||||||
| @@ -0,0 +1,33 @@ | |||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | use Illuminate\Database\Migrations\Migration; | ||||||
|  | use Illuminate\Database\Schema\Blueprint; | ||||||
|  | use Illuminate\Support\Facades\Schema; | ||||||
|  | 
 | ||||||
|  | return new class extends Migration | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Run the migrations. | ||||||
|  |      */ | ||||||
|  |     public function up(): void | ||||||
|  |     { | ||||||
|  |         Schema::create('personal_access_tokens', function (Blueprint $table) { | ||||||
|  |             $table->id(); | ||||||
|  |             $table->morphs('tokenable'); | ||||||
|  |             $table->string('name'); | ||||||
|  |             $table->string('token', 64)->unique(); | ||||||
|  |             $table->text('abilities')->nullable(); | ||||||
|  |             $table->timestamp('last_used_at')->nullable(); | ||||||
|  |             $table->timestamp('expires_at')->nullable(); | ||||||
|  |             $table->timestamps(); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Reverse the migrations. | ||||||
|  |      */ | ||||||
|  |     public function down(): void | ||||||
|  |     { | ||||||
|  |         Schema::dropIfExists('personal_access_tokens'); | ||||||
|  |     } | ||||||
|  | }; | ||||||
| @@ -2,18 +2,21 @@ | |||||||
| 
 | 
 | ||||||
| namespace Database\Seeders; | namespace Database\Seeders; | ||||||
| 
 | 
 | ||||||
| use App\Models\User; | // use Illuminate\Database\Console\Seeds\WithoutModelEvents;
 | ||||||
| use Illuminate\Database\Seeder; | use Illuminate\Database\Seeder; | ||||||
| 
 | 
 | ||||||
| class DatabaseSeeder extends Seeder | class DatabaseSeeder extends Seeder | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Seed the application's database. |      * Seed the application's database. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function run() |     public function run(): void | ||||||
|     { |     { | ||||||
|  |         // \App\Models\User::factory(10)->create();
 | ||||||
| 
 | 
 | ||||||
|  |         // \App\Models\User::factory()->create([
 | ||||||
|  |         //     'name' => 'Test User',
 | ||||||
|  |         //     'email' => 'test@example.com',
 | ||||||
|  |         // ]);
 | ||||||
|     } |     } | ||||||
| } | } | ||||||
							
								
								
									
										19
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,21 +1,12 @@ | |||||||
| { | { | ||||||
|     "private": true, |     "private": true, | ||||||
|     "scripts": { |     "scripts": { | ||||||
|         "dev": "npm run development", |         "dev": "vite", | ||||||
|         "development": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js", |         "build": "vite build" | ||||||
|         "watch": "npm run development -- --watch", |  | ||||||
|         "watch-poll": "npm run watch -- --watch-poll", |  | ||||||
|         "hot": "cross-env NODE_ENV=development node_modules/webpack-dev-server/bin/webpack-dev-server.js --inline --hot --config=node_modules/laravel-mix/setup/webpack.config.js", |  | ||||||
|         "prod": "npm run production", |  | ||||||
|         "production": "cross-env NODE_ENV=production node_modules/webpack/bin/webpack.js --no-progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js" |  | ||||||
|     }, |     }, | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "axios": "^0.19", |         "axios": "^1.1.2", | ||||||
|         "cross-env": "^7.0", |         "laravel-vite-plugin": "^0.7.2", | ||||||
|         "laravel-mix": "^5.0.1", |         "vite": "^4.0.0" | ||||||
|         "lodash": "^4.17.13", |  | ||||||
|         "resolve-url-loader": "^3.1.0", |  | ||||||
|         "sass": "^1.15.2", |  | ||||||
|         "sass-loader": "^8.0.0" |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
							
								
								
									
										26
									
								
								phpunit.xml
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								phpunit.xml
									
									
									
									
									
								
							| @@ -12,20 +12,20 @@ | |||||||
|             <directory suffix="Test.php">./tests/Feature</directory> |             <directory suffix="Test.php">./tests/Feature</directory> | ||||||
|         </testsuite> |         </testsuite> | ||||||
|     </testsuites> |     </testsuites> | ||||||
|     <filter> |     <coverage> | ||||||
|         <whitelist processUncoveredFilesFromWhitelist="true"> |         <include> | ||||||
|             <directory suffix=".php">./app</directory> |             <directory suffix=".php">./app</directory> | ||||||
|         </whitelist> |         </include> | ||||||
|     </filter> |     </coverage> | ||||||
|     <php> |     <php> | ||||||
|         <server name="APP_ENV" value="testing"/> |         <env name="APP_ENV" value="testing"/> | ||||||
|         <server name="BCRYPT_ROUNDS" value="4"/> |         <env name="BCRYPT_ROUNDS" value="4"/> | ||||||
|         <server name="CACHE_DRIVER" value="array"/> |         <env name="CACHE_DRIVER" value="array"/> | ||||||
|         <server name="DB_CONNECTION" value="sqlite"/> |         <!-- <env name="DB_CONNECTION" value="sqlite"/> --> | ||||||
|         <server name="DB_DATABASE" value=":memory:"/> |         <!-- <env name="DB_DATABASE" value=":memory:"/> --> | ||||||
|         <server name="MAIL_MAILER" value="array"/> |         <env name="MAIL_MAILER" value="array"/> | ||||||
|         <server name="QUEUE_CONNECTION" value="sync"/> |         <env name="QUEUE_CONNECTION" value="sync"/> | ||||||
|         <server name="SESSION_DRIVER" value="array"/> |         <env name="SESSION_DRIVER" value="array"/> | ||||||
|         <server name="TELESCOPE_ENABLED" value="false"/> |         <env name="TELESCOPE_ENABLED" value="false"/> | ||||||
|     </php> |     </php> | ||||||
| </phpunit> | </phpunit> | ||||||
| @@ -1,16 +1,23 @@ | |||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
| /** | use Illuminate\Contracts\Http\Kernel; | ||||||
|  * Laravel - A PHP Framework For Web Artisans | use Illuminate\Http\Request; | ||||||
|  * |  | ||||||
|  * @package  Laravel |  | ||||||
|  * @author   Taylor Otwell <taylor@laravel.com> |  | ||||||
|  */ |  | ||||||
| 
 | 
 | ||||||
| define('LARAVEL_START', microtime(true)); | define('LARAVEL_START', microtime(true)); | ||||||
| 
 | 
 | ||||||
| if (file_exists(__DIR__.'/../storage/framework/maintenance.php')) { | /* | ||||||
|     require __DIR__.'/../storage/framework/maintenance.php'; | |-------------------------------------------------------------------------- | ||||||
|  | | Check If The Application Is Under Maintenance | ||||||
|  | |-------------------------------------------------------------------------- | ||||||
|  | | | ||||||
|  | | If the application is in maintenance / demo mode via the "down" command | ||||||
|  | | we will load this file so that any pre-rendered content can be shown | ||||||
|  | | instead of starting the framework, which could cause an exception. | ||||||
|  | | | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | if (file_exists($maintenance = __DIR__.'/../storage/framework/maintenance.php')) { | ||||||
|  |     require $maintenance; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* | /* | ||||||
| @@ -19,9 +26,8 @@ if (file_exists(__DIR__.'/../storage/framework/maintenance.php')) { | |||||||
| |-------------------------------------------------------------------------- | |-------------------------------------------------------------------------- | ||||||
| | | | | ||||||
| | Composer provides a convenient, automatically generated class loader for | | Composer provides a convenient, automatically generated class loader for | ||||||
| | our application. We just need to utilize it! We'll simply require it | | this application. We just need to utilize it! We'll simply require it | ||||||
| | into the script here so that we don't have to worry about manual | | into the script here so we don't need to manually load our classes. | ||||||
| | loading any of our classes later on. It feels great to relax. |  | ||||||
| | | | | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| @@ -29,36 +35,21 @@ require __DIR__.'/../vendor/autoload.php'; | |||||||
| 
 | 
 | ||||||
| /* | /* | ||||||
| |-------------------------------------------------------------------------- | |-------------------------------------------------------------------------- | ||||||
| | Turn On The Lights | | Run The Application | ||||||
| |-------------------------------------------------------------------------- | |-------------------------------------------------------------------------- | ||||||
| | | | | ||||||
| | We need to illuminate PHP development, so let us turn on the lights. | | Once we have the application, we can handle the incoming request using | ||||||
| | This bootstraps the framework and gets it ready for use, then it | | the application's HTTP kernel. Then, we will send the response back | ||||||
| | will load up this application so that we can run it and send | | to this client's browser, allowing them to enjoy our application. | ||||||
| | the responses back to the browser and delight our users. |  | ||||||
| | | | | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| $app = require_once __DIR__.'/../bootstrap/app.php'; | $app = require_once __DIR__.'/../bootstrap/app.php'; | ||||||
| 
 | 
 | ||||||
| /* | $kernel = $app->make(Kernel::class); | ||||||
| |-------------------------------------------------------------------------- |  | ||||||
| | Run The Application |  | ||||||
| |-------------------------------------------------------------------------- |  | ||||||
| | |  | ||||||
| | Once we have the application, we can handle the incoming request |  | ||||||
| | through the kernel, and send the associated response back to |  | ||||||
| | the client's browser allowing them to enjoy the creative |  | ||||||
| | and wonderful application we have prepared for them. |  | ||||||
| | |  | ||||||
| */ |  | ||||||
| 
 |  | ||||||
| $kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); |  | ||||||
| 
 | 
 | ||||||
| $response = $kernel->handle( | $response = $kernel->handle( | ||||||
|     $request = Illuminate\Http\Request::capture() |     $request = Request::capture() | ||||||
| ); | )->send(); | ||||||
| 
 |  | ||||||
| $response->send(); |  | ||||||
| 
 | 
 | ||||||
| $kernel->terminate($request, $response); | $kernel->terminate($request, $response); | ||||||
| @@ -1,28 +0,0 @@ | |||||||
| <!-- |  | ||||||
|     Rewrites requires Microsoft URL Rewrite Module for IIS |  | ||||||
|     Download: https://www.microsoft.com/en-us/download/details.aspx?id=47337 |  | ||||||
|     Debug Help: https://docs.microsoft.com/en-us/iis/extensions/url-rewrite-module/using-failed-request-tracing-to-trace-rewrite-rules |  | ||||||
| --> |  | ||||||
| <configuration> |  | ||||||
|   <system.webServer> |  | ||||||
|     <rewrite> |  | ||||||
|       <rules> |  | ||||||
|         <rule name="Imported Rule 1" stopProcessing="true"> |  | ||||||
|           <match url="^(.*)/$" ignoreCase="false" /> |  | ||||||
|           <conditions> |  | ||||||
|             <add input="{REQUEST_FILENAME}" matchType="IsDirectory" ignoreCase="false" negate="true" /> |  | ||||||
|           </conditions> |  | ||||||
|           <action type="Redirect" redirectType="Permanent" url="/{R:1}" /> |  | ||||||
|         </rule> |  | ||||||
|         <rule name="Imported Rule 2" stopProcessing="true"> |  | ||||||
|           <match url="^" ignoreCase="false" /> |  | ||||||
|           <conditions> |  | ||||||
|             <add input="{REQUEST_FILENAME}" matchType="IsDirectory" ignoreCase="false" negate="true" /> |  | ||||||
|             <add input="{REQUEST_FILENAME}" matchType="IsFile" ignoreCase="false" negate="true" /> |  | ||||||
|           </conditions> |  | ||||||
|           <action type="Rewrite" url="index.php" /> |  | ||||||
|         </rule> |  | ||||||
|       </rules> |  | ||||||
|     </rewrite> |  | ||||||
|   </system.webServer> |  | ||||||
| </configuration> |  | ||||||
							
								
								
									
										0
									
								
								resources/css/app.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								resources/css/app.css
									
									
									
									
									
										Normal file
									
								
							| @@ -1 +1 @@ | |||||||
| require('./bootstrap'); | import './bootstrap'; | ||||||
							
								
								
									
										18
									
								
								resources/js/bootstrap.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								resources/js/bootstrap.js
									
									
									
									
										vendored
									
									
								
							| @@ -1,12 +1,11 @@ | |||||||
| window._ = require('lodash'); |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * We'll load the axios HTTP library which allows us to easily issue requests |  * We'll load the axios HTTP library which allows us to easily issue requests | ||||||
|  * to our Laravel back-end. This library automatically handles sending the |  * to our Laravel back-end. This library automatically handles sending the | ||||||
|  * CSRF token as a header based on the value of the "XSRF" token cookie. |  * CSRF token as a header based on the value of the "XSRF" token cookie. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| window.axios = require('axios'); | import axios from 'axios'; | ||||||
|  | window.axios = axios; | ||||||
|  |  | ||||||
| window.axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest'; | window.axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest'; | ||||||
|  |  | ||||||
| @@ -18,11 +17,16 @@ window.axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest'; | |||||||
|  |  | ||||||
| // import Echo from 'laravel-echo'; | // import Echo from 'laravel-echo'; | ||||||
|  |  | ||||||
| // window.Pusher = require('pusher-js'); | // import Pusher from 'pusher-js'; | ||||||
|  | // window.Pusher = Pusher; | ||||||
|  |  | ||||||
| // window.Echo = new Echo({ | // window.Echo = new Echo({ | ||||||
| //     broadcaster: 'pusher', | //     broadcaster: 'pusher', | ||||||
| //     key: process.env.MIX_PUSHER_APP_KEY, | //     key: import.meta.env.VITE_PUSHER_APP_KEY, | ||||||
| //     cluster: process.env.MIX_PUSHER_APP_CLUSTER, | //     cluster: import.meta.env.VITE_PUSHER_APP_CLUSTER ?? 'mt1', | ||||||
| //     forceTLS: true | //     wsHost: import.meta.env.VITE_PUSHER_HOST ? import.meta.env.VITE_PUSHER_HOST : `ws-${import.meta.env.VITE_PUSHER_APP_CLUSTER}.pusher.com`, | ||||||
|  | //     wsPort: import.meta.env.VITE_PUSHER_PORT ?? 80, | ||||||
|  | //     wssPort: import.meta.env.VITE_PUSHER_PORT ?? 443, | ||||||
|  | //     forceTLS: (import.meta.env.VITE_PUSHER_SCHEME ?? 'https') === 'https', | ||||||
|  | //     enabledTransports: ['ws', 'wss'], | ||||||
| // }); | // }); | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| <?php |  | ||||||
| 
 |  | ||||||
| return [ |  | ||||||
| 
 |  | ||||||
|     /* |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | Authentication Language Lines |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | |  | ||||||
|     | The following language lines are used during authentication for various |  | ||||||
|     | messages that we need to display to the user. You are free to modify |  | ||||||
|     | these language lines according to your application's requirements. |  | ||||||
|     | |  | ||||||
|     */ |  | ||||||
| 
 |  | ||||||
|     'failed' => 'These credentials do not match our records.', |  | ||||||
|     'throttle' => 'Too many login attempts. Please try again in :seconds seconds.', |  | ||||||
| 
 |  | ||||||
| ]; |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| <?php |  | ||||||
| 
 |  | ||||||
| return [ |  | ||||||
| 
 |  | ||||||
|     /* |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | Pagination Language Lines |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | |  | ||||||
|     | The following language lines are used by the paginator library to build |  | ||||||
|     | the simple pagination links. You are free to change them to anything |  | ||||||
|     | you want to customize your views to better match your application. |  | ||||||
|     | |  | ||||||
|     */ |  | ||||||
| 
 |  | ||||||
|     'previous' => '« Previous', |  | ||||||
|     'next' => 'Next »', |  | ||||||
| 
 |  | ||||||
| ]; |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| <?php |  | ||||||
| 
 |  | ||||||
| return [ |  | ||||||
| 
 |  | ||||||
|     /* |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | Password Reset Language Lines |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | |  | ||||||
|     | The following language lines are the default lines which match reasons |  | ||||||
|     | that are given by the password broker for a password update attempt |  | ||||||
|     | has failed, such as for an invalid token or invalid new password. |  | ||||||
|     | |  | ||||||
|     */ |  | ||||||
| 
 |  | ||||||
|     'reset' => 'Your password has been reset!', |  | ||||||
|     'sent' => 'We have emailed your password reset link!', |  | ||||||
|     'throttled' => 'Please wait before retrying.', |  | ||||||
|     'token' => 'This password reset token is invalid.', |  | ||||||
|     'user' => "We can't find a user with that email address.", |  | ||||||
| 
 |  | ||||||
| ]; |  | ||||||
| @@ -1,151 +0,0 @@ | |||||||
| <?php |  | ||||||
| 
 |  | ||||||
| return [ |  | ||||||
| 
 |  | ||||||
|     /* |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | Validation Language Lines |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | |  | ||||||
|     | The following language lines contain the default error messages used by |  | ||||||
|     | the validator class. Some of these rules have multiple versions such |  | ||||||
|     | as the size rules. Feel free to tweak each of these messages here. |  | ||||||
|     | |  | ||||||
|     */ |  | ||||||
| 
 |  | ||||||
|     'accepted' => 'The :attribute must be accepted.', |  | ||||||
|     'active_url' => 'The :attribute is not a valid URL.', |  | ||||||
|     'after' => 'The :attribute must be a date after :date.', |  | ||||||
|     'after_or_equal' => 'The :attribute must be a date after or equal to :date.', |  | ||||||
|     'alpha' => 'The :attribute may only contain letters.', |  | ||||||
|     'alpha_dash' => 'The :attribute may only contain letters, numbers, dashes and underscores.', |  | ||||||
|     'alpha_num' => 'The :attribute may only contain letters and numbers.', |  | ||||||
|     'array' => 'The :attribute must be an array.', |  | ||||||
|     'before' => 'The :attribute must be a date before :date.', |  | ||||||
|     'before_or_equal' => 'The :attribute must be a date before or equal to :date.', |  | ||||||
|     'between' => [ |  | ||||||
|         'numeric' => 'The :attribute must be between :min and :max.', |  | ||||||
|         'file' => 'The :attribute must be between :min and :max kilobytes.', |  | ||||||
|         'string' => 'The :attribute must be between :min and :max characters.', |  | ||||||
|         'array' => 'The :attribute must have between :min and :max items.', |  | ||||||
|     ], |  | ||||||
|     'boolean' => 'The :attribute field must be true or false.', |  | ||||||
|     'confirmed' => 'The :attribute confirmation does not match.', |  | ||||||
|     'date' => 'The :attribute is not a valid date.', |  | ||||||
|     'date_equals' => 'The :attribute must be a date equal to :date.', |  | ||||||
|     'date_format' => 'The :attribute does not match the format :format.', |  | ||||||
|     'different' => 'The :attribute and :other must be different.', |  | ||||||
|     'digits' => 'The :attribute must be :digits digits.', |  | ||||||
|     'digits_between' => 'The :attribute must be between :min and :max digits.', |  | ||||||
|     'dimensions' => 'The :attribute has invalid image dimensions.', |  | ||||||
|     'distinct' => 'The :attribute field has a duplicate value.', |  | ||||||
|     'email' => 'The :attribute must be a valid email address.', |  | ||||||
|     'ends_with' => 'The :attribute must end with one of the following: :values.', |  | ||||||
|     'exists' => 'The selected :attribute is invalid.', |  | ||||||
|     'file' => 'The :attribute must be a file.', |  | ||||||
|     'filled' => 'The :attribute field must have a value.', |  | ||||||
|     'gt' => [ |  | ||||||
|         'numeric' => 'The :attribute must be greater than :value.', |  | ||||||
|         'file' => 'The :attribute must be greater than :value kilobytes.', |  | ||||||
|         'string' => 'The :attribute must be greater than :value characters.', |  | ||||||
|         'array' => 'The :attribute must have more than :value items.', |  | ||||||
|     ], |  | ||||||
|     'gte' => [ |  | ||||||
|         'numeric' => 'The :attribute must be greater than or equal :value.', |  | ||||||
|         'file' => 'The :attribute must be greater than or equal :value kilobytes.', |  | ||||||
|         'string' => 'The :attribute must be greater than or equal :value characters.', |  | ||||||
|         'array' => 'The :attribute must have :value items or more.', |  | ||||||
|     ], |  | ||||||
|     'image' => 'The :attribute must be an image.', |  | ||||||
|     'in' => 'The selected :attribute is invalid.', |  | ||||||
|     'in_array' => 'The :attribute field does not exist in :other.', |  | ||||||
|     'integer' => 'The :attribute must be an integer.', |  | ||||||
|     'ip' => 'The :attribute must be a valid IP address.', |  | ||||||
|     'ipv4' => 'The :attribute must be a valid IPv4 address.', |  | ||||||
|     'ipv6' => 'The :attribute must be a valid IPv6 address.', |  | ||||||
|     'json' => 'The :attribute must be a valid JSON string.', |  | ||||||
|     'lt' => [ |  | ||||||
|         'numeric' => 'The :attribute must be less than :value.', |  | ||||||
|         'file' => 'The :attribute must be less than :value kilobytes.', |  | ||||||
|         'string' => 'The :attribute must be less than :value characters.', |  | ||||||
|         'array' => 'The :attribute must have less than :value items.', |  | ||||||
|     ], |  | ||||||
|     'lte' => [ |  | ||||||
|         'numeric' => 'The :attribute must be less than or equal :value.', |  | ||||||
|         'file' => 'The :attribute must be less than or equal :value kilobytes.', |  | ||||||
|         'string' => 'The :attribute must be less than or equal :value characters.', |  | ||||||
|         'array' => 'The :attribute must not have more than :value items.', |  | ||||||
|     ], |  | ||||||
|     'max' => [ |  | ||||||
|         'numeric' => 'The :attribute may not be greater than :max.', |  | ||||||
|         'file' => 'The :attribute may not be greater than :max kilobytes.', |  | ||||||
|         'string' => 'The :attribute may not be greater than :max characters.', |  | ||||||
|         'array' => 'The :attribute may not have more than :max items.', |  | ||||||
|     ], |  | ||||||
|     'mimes' => 'The :attribute must be a file of type: :values.', |  | ||||||
|     'mimetypes' => 'The :attribute must be a file of type: :values.', |  | ||||||
|     'min' => [ |  | ||||||
|         'numeric' => 'The :attribute must be at least :min.', |  | ||||||
|         'file' => 'The :attribute must be at least :min kilobytes.', |  | ||||||
|         'string' => 'The :attribute must be at least :min characters.', |  | ||||||
|         'array' => 'The :attribute must have at least :min items.', |  | ||||||
|     ], |  | ||||||
|     'not_in' => 'The selected :attribute is invalid.', |  | ||||||
|     'not_regex' => 'The :attribute format is invalid.', |  | ||||||
|     'numeric' => 'The :attribute must be a number.', |  | ||||||
|     'password' => 'The password is incorrect.', |  | ||||||
|     'present' => 'The :attribute field must be present.', |  | ||||||
|     'regex' => 'The :attribute format is invalid.', |  | ||||||
|     'required' => 'The :attribute field is required.', |  | ||||||
|     'required_if' => 'The :attribute field is required when :other is :value.', |  | ||||||
|     'required_unless' => 'The :attribute field is required unless :other is in :values.', |  | ||||||
|     'required_with' => 'The :attribute field is required when :values is present.', |  | ||||||
|     'required_with_all' => 'The :attribute field is required when :values are present.', |  | ||||||
|     'required_without' => 'The :attribute field is required when :values is not present.', |  | ||||||
|     'required_without_all' => 'The :attribute field is required when none of :values are present.', |  | ||||||
|     'same' => 'The :attribute and :other must match.', |  | ||||||
|     'size' => [ |  | ||||||
|         'numeric' => 'The :attribute must be :size.', |  | ||||||
|         'file' => 'The :attribute must be :size kilobytes.', |  | ||||||
|         'string' => 'The :attribute must be :size characters.', |  | ||||||
|         'array' => 'The :attribute must contain :size items.', |  | ||||||
|     ], |  | ||||||
|     'starts_with' => 'The :attribute must start with one of the following: :values.', |  | ||||||
|     'string' => 'The :attribute must be a string.', |  | ||||||
|     'timezone' => 'The :attribute must be a valid zone.', |  | ||||||
|     'unique' => 'The :attribute has already been taken.', |  | ||||||
|     'uploaded' => 'The :attribute failed to upload.', |  | ||||||
|     'url' => 'The :attribute format is invalid.', |  | ||||||
|     'uuid' => 'The :attribute must be a valid UUID.', |  | ||||||
| 
 |  | ||||||
|     /* |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | Custom Validation Language Lines |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | |  | ||||||
|     | Here you may specify custom validation messages for attributes using the |  | ||||||
|     | convention "attribute.rule" to name the lines. This makes it quick to |  | ||||||
|     | specify a specific custom language line for a given attribute rule. |  | ||||||
|     | |  | ||||||
|     */ |  | ||||||
| 
 |  | ||||||
|     'custom' => [ |  | ||||||
|         'attribute-name' => [ |  | ||||||
|             'rule-name' => 'custom-message', |  | ||||||
|         ], |  | ||||||
|     ], |  | ||||||
| 
 |  | ||||||
|     /* |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | Custom Validation Attributes |  | ||||||
|     |-------------------------------------------------------------------------- |  | ||||||
|     | |  | ||||||
|     | The following language lines are used to swap our attribute placeholder |  | ||||||
|     | with something more reader friendly such as "E-Mail Address" instead |  | ||||||
|     | of "email". This simply helps us make our message more expressive. |  | ||||||
|     | |  | ||||||
|     */ |  | ||||||
| 
 |  | ||||||
|     'attributes' => [], |  | ||||||
| 
 |  | ||||||
| ]; |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| // |  | ||||||
| @@ -20,7 +20,7 @@ | |||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <?php |     <?php | ||||||
|         Debugbar::warning('Testing, 123.'); |        // Debugbar::warning('Testing, 123.');
 | ||||||
|     ?>
 |     ?>
 | ||||||
| 
 | 
 | ||||||
|     <!-- Optional JavaScript --> |     <!-- Optional JavaScript --> | ||||||
|   | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -9,11 +9,11 @@ use Illuminate\Support\Facades\Route; | |||||||
| |-------------------------------------------------------------------------- | |-------------------------------------------------------------------------- | ||||||
| | | | | ||||||
| | Here is where you can register API routes for your application. These | | Here is where you can register API routes for your application. These | ||||||
| | routes are loaded by the RouteServiceProvider within a group which | | routes are loaded by the RouteServiceProvider and all of them will | ||||||
| | is assigned the "api" middleware group. Enjoy building your API! | | be assigned to the "api" middleware group. Make something great! | ||||||
| | | | | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| Route::middleware('auth:api')->get('/user', function (Request $request) { | Route::middleware('auth:sanctum')->get('/user', function (Request $request) { | ||||||
|     return $request->user(); |     return $request->user(); | ||||||
| }); | }); | ||||||
| @@ -13,6 +13,6 @@ use Illuminate\Support\Facades\Broadcast; | |||||||
| | | | | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| Broadcast::channel('App.User.{id}', function ($user, $id) { | Broadcast::channel('App.Models.User.{id}', function ($user, $id) { | ||||||
|     return (int) $user->id === (int) $id; |     return (int) $user->id === (int) $id; | ||||||
| }); | }); | ||||||
| @@ -16,4 +16,4 @@ use Illuminate\Support\Facades\Artisan; | |||||||
| 
 | 
 | ||||||
| Artisan::command('inspire', function () { | Artisan::command('inspire', function () { | ||||||
|     $this->comment(Inspiring::quote()); |     $this->comment(Inspiring::quote()); | ||||||
| })->describe('Display an inspiring quote'); | })->purpose('Display an inspiring quote'); | ||||||
| @@ -8,12 +8,11 @@ use Illuminate\Support\Facades\Route; | |||||||
| |-------------------------------------------------------------------------- | |-------------------------------------------------------------------------- | ||||||
| | | | | ||||||
| | Here is where you can register web routes for your application. These | | Here is where you can register web routes for your application. These | ||||||
| | routes are loaded by the RouteServiceProvider within a group which | | routes are loaded by the RouteServiceProvider and all of them will | ||||||
| | contains the "web" middleware group. Now create something great! | | be assigned to the "web" middleware group. Make something great! | ||||||
| | | | | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| Route::get('/', function () { | Route::get('/', function () { | ||||||
|     return view('start'); |     return view('start'); | ||||||
| }); | }); | ||||||
| 
 |  | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								server.php
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								server.php
									
									
									
									
									
								
							| @@ -1,21 +0,0 @@ | |||||||
| <?php |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * Laravel - A PHP Framework For Web Artisans |  | ||||||
|  * |  | ||||||
|  * @package  Laravel |  | ||||||
|  * @author   Taylor Otwell <taylor@laravel.com> |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| $uri = urldecode( |  | ||||||
|     parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH) |  | ||||||
| ); |  | ||||||
| 
 |  | ||||||
| // This file allows us to emulate Apache's "mod_rewrite" functionality from the
 |  | ||||||
| // built-in PHP web server. This provides a convenient way to test a Laravel
 |  | ||||||
| // application without having installed a "real" web server software here.
 |  | ||||||
| if ($uri !== '/' && file_exists(__DIR__.'/public'.$uri)) { |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| require_once __DIR__.'/public/index.php'; |  | ||||||
							
								
								
									
										0
									
								
								storage/app/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/app/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								storage/app/public/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/app/public/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								storage/debugbar/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/debugbar/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										13
									
								
								storage/framework/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										13
									
								
								storage/framework/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -1,8 +1,9 @@ | |||||||
| config.php |  | ||||||
| routes.php |  | ||||||
| schedule-* |  | ||||||
| compiled.php | compiled.php | ||||||
| services.json | config.php | ||||||
| events.scanned.php |  | ||||||
| routes.scanned.php |  | ||||||
| down | down | ||||||
|  | events.scanned.php | ||||||
|  | maintenance.php | ||||||
|  | routes.php | ||||||
|  | routes.scanned.php | ||||||
|  | schedule-* | ||||||
|  | services.json | ||||||
							
								
								
									
										0
									
								
								storage/framework/cache/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/framework/cache/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								storage/framework/cache/data/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/framework/cache/data/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								storage/framework/sessions/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/framework/sessions/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								storage/framework/testing/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/framework/testing/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								storage/framework/views/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/framework/views/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										0
									
								
								storage/logs/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								storage/logs/.gitignore
									
									
									
									
										vendored
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -3,15 +3,14 @@ | |||||||
| namespace Tests; | namespace Tests; | ||||||
| 
 | 
 | ||||||
| use Illuminate\Contracts\Console\Kernel; | use Illuminate\Contracts\Console\Kernel; | ||||||
|  | use Illuminate\Foundation\Application; | ||||||
| 
 | 
 | ||||||
| trait CreatesApplication | trait CreatesApplication | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * Creates the application. |      * Creates the application. | ||||||
|      * |  | ||||||
|      * @return \Illuminate\Foundation\Application |  | ||||||
|      */ |      */ | ||||||
|     public function createApplication() |     public function createApplication(): Application | ||||||
|     { |     { | ||||||
|         $app = require __DIR__.'/../bootstrap/app.php'; |         $app = require __DIR__.'/../bootstrap/app.php'; | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -2,17 +2,15 @@ | |||||||
| 
 | 
 | ||||||
| namespace Tests\Feature; | namespace Tests\Feature; | ||||||
| 
 | 
 | ||||||
| use Illuminate\Foundation\Testing\RefreshDatabase; | // use Illuminate\Foundation\Testing\RefreshDatabase;
 | ||||||
| use Tests\TestCase; | use Tests\TestCase; | ||||||
| 
 | 
 | ||||||
| class ExampleTest extends TestCase | class ExampleTest extends TestCase | ||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * A basic test example. |      * A basic test example. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function testBasicTest() |     public function test_the_application_returns_a_successful_response(): void | ||||||
|     { |     { | ||||||
|         $response = $this->get('/'); |         $response = $this->get('/'); | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -8,10 +8,8 @@ class ExampleTest extends TestCase | |||||||
| { | { | ||||||
|     /** |     /** | ||||||
|      * A basic test example. |      * A basic test example. | ||||||
|      * |  | ||||||
|      * @return void |  | ||||||
|      */ |      */ | ||||||
|     public function testBasicTest() |     public function test_that_true_is_true(): void | ||||||
|     { |     { | ||||||
|         $this->assertTrue(true); |         $this->assertTrue(true); | ||||||
|     } |     } | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								vite.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								vite.config.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | import { defineConfig } from 'vite'; | ||||||
|  | import laravel from 'laravel-vite-plugin'; | ||||||
|  |  | ||||||
|  | export default defineConfig({ | ||||||
|  |     plugins: [ | ||||||
|  |         laravel({ | ||||||
|  |             input: ['resources/css/app.css', 'resources/js/app.js'], | ||||||
|  |             refresh: true, | ||||||
|  |         }), | ||||||
|  |     ], | ||||||
|  | }); | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| const mix = require('laravel-mix'); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  |-------------------------------------------------------------------------- |  | ||||||
|  | Mix Asset Management |  | ||||||
|  |-------------------------------------------------------------------------- |  | ||||||
|  | |  | ||||||
|  | Mix provides a clean, fluent API for defining some Webpack build steps |  | ||||||
|  | for your Laravel application. By default, we are compiling the Sass |  | ||||||
|  | file for the application as well as bundling up all the JS files. |  | ||||||
|  | |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| mix.js('resources/js/app.js', 'public/js') |  | ||||||
|     .sass('resources/sass/app.scss', 'public/css'); |  | ||||||
		Reference in New Issue
	
	Block a user