-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathPlugin.php
120 lines (109 loc) · 2.97 KB
/
Plugin.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php namespace Trepmag\Solr;
use Backend;
use System\Classes\PluginBase;
use Event;
use Config;
/**
* Solr Plugin Information File
*/
class Plugin extends PluginBase
{
/**
* Returns information about this plugin.
*
* @return array
*/
public function pluginDetails()
{
return [
'name' => 'Solr',
'description' => 'Provides an interface with Solarium for indexing, search and displaying content.',
'author' => 'Trepmag',
'icon' => 'icon-leaf'
];
}
/**
* Register method, called when the plugin is first registered.
*
* @return void
*/
public function register()
{
$this->registerConsoleCommand('solr.ping', 'Trepmag\Solr\Console\Ping');
$this->registerConsoleCommand('solr.index-update', 'Trepmag\Solr\Console\UpdateIndex');
$this->registerConsoleCommand('solr.index-empty', 'Trepmag\Solr\Console\EmptyIndex');
}
/**
* Boot method, called right before the request route.
*
* @return array
*/
public function boot()
{
parent::boot();
// Subscribe any search index update event classes
$updateEventClassesAdded = [];
foreach (Config::get('solr.search_index_classes', []) as $class) {
$updateEventClass = $class::getUpdateEventClass();
if (!in_array($updateEventClass, $updateEventClassesAdded)) {
Event::subscribe(new $updateEventClass);
$updateEventClassesAdded[] = $updateEventClass;
}
}
}
/**
* Registers any front-end components implemented in this plugin.
*
* @return array
*/
public function registerComponents()
{
return [
'\Trepmag\Solr\Components\Search' => 'solrSearch',
];
}
/**
* Registers any rainlab-page snippets from component.
*
* @return array
*/
public function registerPageSnippets()
{
return [
'\Trepmag\Solr\Components\Search' => 'solrSearch'
];
}
/**
* Registers any back-end permissions used by this plugin.
*
* @return array
*/
public function registerPermissions()
{
return []; // Remove this line to activate
return [
'trepmag.solr.some_permission' => [
'tab' => 'Solr',
'label' => 'Some permission'
],
];
}
/**
* Registers back-end navigation items for this plugin.
*
* @return array
*/
public function registerNavigation()
{
return []; // Remove this line to activate
return [
'solr' => [
'label' => 'Solr',
'url' => Backend::url('trepmag/solr/mycontroller'),
'icon' => 'icon-leaf',
'permissions' => ['trepmag.solr.*'],
'order' => 500,
],
];
}
}