Архив за месяц: Ноябрь 2019

Сброс cached views в Laravel через middleware

Создаем middleware ClearViewCache

<?php

namespace App\Http\Middleware;

use Artisan;
use Closure;

class ClearViewCache
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
if (env('APP_DEBUG') || env('APP_ENV') === 'local')
Artisan::call('view:clear');

return $next($request);
}
}

регистрируем его в app/Http/Kernel.php в блоке protected $middleware

\App\Http\Middleware\ClearViewCache::class,

Изменяем в config/app.php

'env' => env('APP_ENV', 'local'), // production
'debug' => env('APP_DEBUG', true),

Сборка проекта на Laravel 6

скачиваем и устанавливаем node.js если его в системе нет https://nodejs.org/en/

устанавливаем Laravel using Composer

composer global require laravel/installer
laravel new project_name
composer require laravel/ui
php artisan ui bootstrap
npm install && npm run dev

Установка последней версии Bootstrap через NPM

npm install bootstrap --save-dev
composer require maatwebsite/excel

composer require phpoffice/phpword

composer require mpdf/mpdf

composer require dompdf/dompdf

composer require tecnickcom/tcpdf

composer require jpgraph/jpgraph

composer require setasign/fpdf

composer require doctrine/dbal

composer require laravelcollective/html

composer require components/jquery

composer require components/jqueryui

composer require select2/select2

composer require fortawesome/font-awesome

composer require techlab/smartwizard

Настраиваем jquery jqueryui select2 awesome

Create Service Provider in ‘app/Providers/AssetServiceProvider.php

<?php
namespace App\Providers;

use Illuminate\Support\ServiceProvider;

class AssetServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*/
public function boot()
{
// jquery
$this->publishes([
base_path('vendor/components/jquery/jquery.js') => public_path('vendor/jquery/js/jquery.js'),
], 'jquery');
// jqueryui
$this->publishes([
base_path('vendor/components/jqueryui/jquery-ui.js') => public_path('vendor/jqueryui/js/jquery-ui.js'),
base_path('vendor/components/jqueryui/themes/base/jquery-ui.css') => public_path('vendor/jqueryui/css/jquery-ui.css'),
], 'jquery-ui');
// select2
$this->publishes(
[
base_path('vendor/select2/select2/dist/css/select2.min.css') => public_path('vendor/select2/css/select2.min.css'),
base_path('vendor/select2/select2/dist/js/select2.min.js') => public_path('vendor/select2/js/select2.min.js'),
],
'select2'
);
//FONT AWESOME
$this->publishes(
[
//css
base_path('vendor/fortawesome/font-awesome/css/all.min.css') => public_path('vendor/fortawesome/css/all.min.css'),
base_path('vendor/fortawesome/font-awesome/css/brands.min.css') => public_path('vendor/fortawesome/css/brands.min.css'),
base_path('vendor/fortawesome/font-awesome/css/fontawesome.min.css') => public_path('vendor/fortawesome/css/fontawesome.min.css'),
base_path('vendor/fortawesome/font-awesome/css/regular.min.css') => public_path('vendor/fortawesome/css/regular.min.css'),
base_path('vendor/fortawesome/font-awesome/css/solid.min.css') => public_path('vendor/fortawesome/css/solid.min.css'),
base_path('vendor/fortawesome/font-awesome/css/svg-with-js.min.css') => public_path('vendor/fortawesome/css/svg-with-js.min.css'),
base_path('vendor/fortawesome/font-awesome/css/v4-shims.min.css') => public_path('vendor/fortawesome/css/v4-shims.min.css'),
//js
base_path('vendor/fortawesome/font-awesome/js/all.min.js') => public_path('vendor/fortawesome/js/all.min.js'),
base_path('vendor/fortawesome/font-awesome/js/brands.min.js') => public_path('vendor/fortawesome/js/brands.min.js'),
base_path('vendor/fortawesome/font-awesome/js/conflict-detection.min.js') => public_path('vendor/fortawesome/js/conflict-detection.min.js'),
base_path('vendor/fortawesome/font-awesome/js/fontawesome.min.js') => public_path('vendor/fortawesome/js/fontawesome.min.js'),
base_path('vendor/fortawesome/font-awesome/js/regular.min.js') => public_path('vendor/fortawesome/js/regular.min.js'),
base_path('vendor/fortawesome/font-awesome/js/solid.min.js') => public_path('vendor/fortawesome/js/solid.min.js'),
base_path('vendor/fortawesome/font-awesome/js/v4-shims.min.js') => public_path('vendor/fortawesome/js/v4-shims.min.js'),
// web fonts
base_path('vendor/fortawesome/font-awesome/webfonts/fa-brands-400.eot') => public_path('vendor/fortawesome/webfonts/fa-brands-400.eot'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-brands-400.svg') => public_path('vendor/fortawesome/webfonts/fa-brands-400.svg'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-brands-400.ttf') => public_path('vendor/fortawesome/webfonts/fa-brands-400.ttf'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-brands-400.woff') => public_path('vendor/fortawesome/webfonts/fa-brands-400.woff'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-brands-400.woff2') => public_path('vendor/fortawesome/webfonts/fa-brands-400.woff2'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-regular-400.eot') => public_path('vendor/fortawesome/webfonts/fa-regular-400.eot'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-regular-400.svg') => public_path('vendor/fortawesome/webfonts/fa-regular-400.svg'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-regular-400.ttf') => public_path('vendor/fortawesome/webfonts/fa-regular-400.ttf'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-regular-400.woff') => public_path('vendor/fortawesome/webfonts/fa-regular-400.woff'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-regular-400.woff2') => public_path('vendor/fortawesome/webfonts/fa-regular-400.woff2'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-solid-900.eot') => public_path('vendor/fortawesome/webfonts/fa-solid-900.eot'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-solid-900.svg') => public_path('vendor/fortawesome/webfonts/fa-solid-900.svg'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-solid-900.ttf') => public_path('vendor/fortawesome/webfonts/fa-solid-900.ttf'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-solid-900.woff') => public_path('vendor/fortawesome/webfonts/fa-solid-900.woff'),
base_path('vendor/fortawesome/font-awesome/webfonts/fa-solid-900.woff2') => public_path('vendor/fortawesome/webfonts/fa-solid-900.woff2'),

],
'awesome'
);
}

/**
* Register any application services.
*/
public function register()
{
//
}
}

Register Service Provider in ‘config/app.php‘:

'providers' => [
    ...
    App\Providers\AssetServiceProvider::class,
    ...
]

Edit in  ‘composer.json‘:

"scripts": {

...

"post-update-cmd": [
"php artisan config:clear",
"php artisan cache:clear",

"php artisan vendor:publish --tag=jquery --force",
"php artisan vendor:publish --tag=jquery-ui --force",
"php artisan vendor:publish --tag=select2 --force",
"php artisan vendor:publish --tag=awesome --force"
]
}

Run composer update

Добавляем в template

{{--jquery--}}
<script src="{{asset('vendor/jquery/js/jquery.js')}}"></script>

<!-- Fonts fontawesome -->
<link media="all" type="text/css" rel="stylesheet" href="{{asset('vendor/fortawesome/css/all.min.css')}}">
<script src="{{asset('vendor/fortawesome/js/all.min.js')}}"></script>

{{--jquery-ui--}}
<script src="{{asset('vendor/jqueryui/js/jquery-ui.js')}}"></script>

{{--select2--}}
<link rel="stylesheet" href="{{ asset('vendor/select2/css/select2.min.css') }}">
<script src="{{ asset('vendor/select2/js/select2.min.js') }}"></script>

Ставим центавр и настраиваем его согласно инструкции

composer require srlabs/centaur
composer require vinkla/hashids

Installation

Install the Package Via Composer:

$ composer require srlabs/centaur

Add the Service Provider to your config/app.php file:

'providers' => array(
    ...
    Centaur\CentaurServiceProvider::class,
    ...
)

This package will not make use of automatic package discovery — you will need to register it manually. This is intentional.

Usage in New Applications

If you are starting a new Laravel 5.* application, this package provides a convenient way to get up and running with Cartalyst\Sentinel very quickly. Start by removing the default auth scaffolding that ships with a new Laravel 5.1 application:

$ php artisan centaur:spruce

Next, use Centaur’s scaffolding command to create basic Auth Controllers and Views in your application:

$ php artisan centaur:scaffold

Publish the Cartalyst\Sentinel assets:

$ php artisan vendor:publish --provider="Cartalyst\Sentinel\Laravel\SentinelServiceProvider"

Run your database migrations:

$ php artisan migrate

Run the Database Seeder. You may need to re-generate the autoloader before this will work:

$ composer dump-autoload
$ php artisan db:seed --class="SentinelDatabaseSeeder"

You will also need to add these routes to your routes.php file:

// Authorization
Route::get('login', 'Auth\SessionController@getLogin')->name('auth.login.form');
Route::post('login', 'Auth\SessionController@postLogin')->name('auth.login.attempt');
Route::any('logout', 'Auth\SessionController@getLogout')->name('auth.logout');

// Registration
Route::get('register', 'Auth\RegistrationController@getRegister')->name('auth.register.form');
Route::post('register', 'Auth\RegistrationController@postRegister')->name('auth.register.attempt');

// Activation
Route::get('activate/{code}', 'Auth\RegistrationController@getActivate')->name('auth.activation.attempt');
Route::get('resend', 'Auth\RegistrationController@getResend')->name('auth.activation.request');
Route::post('resend', 'Auth\RegistrationController@postResend')->name('auth.activation.resend');

// Password Reset
Route::get('password/reset/{code}', 'Auth\PasswordController@getReset')->name('auth.password.reset.form');
Route::post('password/reset/{code}', 'Auth\PasswordController@postReset')->name('auth.password.reset.attempt');
Route::get('password/reset', 'Auth\PasswordController@getRequest')->name('auth.password.request.form');
Route::post('password/reset', 'Auth\PasswordController@postRequest')->name('auth.password.request.attempt');

// Users
Route::resource('users', 'UserController');

// Roles
Route::resource('roles', 'RoleController');

// Dashboard
Route::get('dashboard', function () {
    return view('Centaur::dashboard');
})->name('dashboard');

This is only meant to be a starting point; you can change them as you see fit. Make sure you read through your new Auth Controllers and understand how they work before you make any changes.

Centaur automatically installs Sentinel and registers the SentinelActivations, and Reminders aliases for you. Detailed instructions for using Sentinel can be found here.

If you do decide to make use of Laravel’s Route::resource() option, you will need to use Form Method Spoofing to access some of those generated routes.