Laravel wrapper to use Lightship PHP.
Lightship is a way to get web page audits without using a headless browser.
This package just a wrapper around the PHP implementation of Lightship (https://github.com/lightship-core/lightship-php).
- Provides a Facade to easily use Lightship PHP
On your terminal, install the package:
composer require --dev lightship-core/lightship-laravel
In this example, we will generate an array report using the Laravel facade.
namespace App\Controllers;
use Lightship\Facades\Lightship;
class HomeController extends Controller
{
public function index()
{
$report = Lightship::route("https://example.com")
->analyse()
->toArray();
return view("home.index", [
"report" => $report,
]);
}
}
In this example, we will call Lightship from the command.
php artisan lightship:run --url https://example.com
You can also pass a route name.
php artisan lightship:run --route home.index
You can even pass multiple routes.
php artisan lightship:run --route home.index --route contact-us.index
And you can mix both.
php artisan lightship:run --route home.index --route contact-us.index --url https://example.com --url https://google.com
Since the command do not support passing query strings, you can do it by creating your own command and call this one.
namespace App\Console\Commands;
use Illuminate\Console\Command;
class MyCommand extends Command
{
protected $signature = 'my-command:run';
protected $description = 'Scan my routes.';
public function handle()
{
$this->call("lightship:run", [
"--url" => [
route("home.index", ["lang" => "en"]),
route("contact-us.index", ["theme" => "dark"]),
]
]);
}
}
By default, the command does not show the failed/passed rules of each URLs to save some space. If you want to show the detail, use the --detailed
option.
php artisan lightship:run --route home.index --detailed
Or by calling Artisan::call
:
use Illuminate\Support\Facades\Artisan;
// ...
Artisan::call("lightship:run", [
"--route" => "home.index",
"--detailed" => true,
]);
composer check-platform-reqs
composer install
composer run analyse
composer run test
composer run lint
composer run scan
composer run check
composer run updates
Or
composer run all