/
Module.php
73 lines (64 loc) · 2.22 KB
/
Module.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
<?php
namespace BgIntercom;
use Zend\ModuleManager\Feature\AutoloaderProviderInterface;
use Zend\ModuleManager\Feature\ServiceProviderInterface;
use Zend\ModuleManager\Feature\ViewHelperProviderInterface;
use Zend\ServiceManager\ServiceManager;
use Zend\View\HelperPluginManager;
class Module implements AutoloaderProviderInterface, ServiceProviderInterface, ViewHelperProviderInterface
{
/**
* Return an array for passing to Zend\Loader\AutoloaderFactory.
*
* @return array
*/
public function getAutoloaderConfig()
{
return array(
'Zend\Loader\ClassMapAutoloader' => array(
__DIR__ . '/autoload_classmap.php',
),
'Zend\Loader\StandardAutoloader' => array(
'namespaces' => array(
__NAMESPACE__ => __DIR__ . '/src/' . __NAMESPACE__,
),
),
);
}
/**
* Expected to return \Zend\ServiceManager\Config object or array to
* seed such an object.
*
* @return array|\Zend\ServiceManager\Config
*/
public function getServiceConfig()
{
return array(
'factories' => array(
'BgIntercom\Options\ModuleOptions' => function (ServiceManager $serviceLocator) {
$config = $serviceLocator->get('Config');
return new Options\ModuleOptions(isset($config['bgintercom']) ? $config['bgintercom'] : array());
}
)
);
}
/**
* Expected to return \Zend\ServiceManager\Config object or array to
* seed such an object.
*
* @return array|\Zend\ServiceManager\Config
*/
public function getViewHelperConfig()
{
return array(
'factories' => array(
'intercom' => function (HelperPluginManager $helperPluginManager) {
$options = $helperPluginManager->getServiceLocator()->get('BgIntercom\Options\ModuleOptions');
$zfcUserAuth = $helperPluginManager->getServiceLocator()->get('zfcuser_auth_service');
$helper = new View\Helper\Intercom($options, $zfcUserAuth);
return $helper;
},
),
);
}
}