/
EventScanCommand.php
92 lines (78 loc) · 1.74 KB
/
EventScanCommand.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php namespace Illuminate\Foundation\Console;
use Illuminate\Console\Command;
use Illuminate\Filesystem\Filesystem;
use Illuminate\Events\Annotations\Scanner;
use Symfony\Component\Console\Input\InputOption;
class EventScanCommand extends Command {
/**
* The console command name.
*
* @var string
*/
protected $name = 'event:scan';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Scan a directory for event annotations';
/**
* The filesystem instance.
*
* @var \Illuminate\Filesystem\Filesystem
*/
protected $files;
/**
* Create a new event scan command instance.
*
* @param \Illuminate\Filesystem\Filesystem $files
* @return void
*/
public function __construct(Filesystem $files)
{
parent::__construct();
$this->files = $files;
}
/**
* Execute the console command.
*
* @return void
*/
public function fire()
{
$this->files->put($this->getOutputPath(), $this->getEventDefinitions());
$this->info('Events scanned!');
}
/**
* Get the route definitions for the annotations.
*
* @return string
*/
protected function getEventDefinitions()
{
$provider = 'Illuminate\Foundation\Support\Providers\EventServiceProvider';
return '<?php '.PHP_EOL.PHP_EOL.Scanner::create(
$this->laravel->getProvider($provider)->scans()
)->getEventDefinitions().PHP_EOL;
}
/**
* Get the path to which the routes should be written.
*
* @return string
*/
protected function getOutputPath()
{
return $this->laravel['path.storage'].'/framework/events.scanned.php';
}
/**
* Get the console command options.
*
* @return array
*/
protected function getOptions()
{
return [
['path', null, InputOption::VALUE_OPTIONAL, 'The path to scan.'],
];
}
}