1
|
|
|
<?php |
2
|
|
|
/** @var $app Silex\Application */ |
3
|
|
|
// templating |
4
|
|
|
$app->register(new Silex\Provider\TwigServiceProvider(), [ |
5
|
|
|
'twig.path' => __DIR__ . '/../views' |
6
|
|
|
]); |
7
|
|
|
|
8
|
|
|
// logging |
9
|
|
|
$app->register(new Silex\Provider\MonologServiceProvider(), [ |
10
|
|
|
'monolog.logfile' => __DIR__ . '/../logs/development.log', |
11
|
|
|
'monolog.name' => 'dashboard' |
12
|
|
|
]); |
13
|
|
|
|
14
|
|
|
// database |
15
|
|
|
$app->register(new Silex\Provider\DoctrineServiceProvider(), array( |
16
|
|
|
'db.options' => array( |
17
|
|
|
'user' => null, |
18
|
|
|
'driver' => 'pdo_sqlite', |
19
|
|
|
'path' => __DIR__ . '/dashboard.db', |
20
|
|
|
), |
21
|
|
|
)); |
22
|
|
|
|
23
|
|
|
// ldap |
24
|
|
|
$app->register(new SOG\Dashboard\ZendLdapServiceProvider(), [ |
25
|
|
|
'ldap.options' => $dashboard_config['ldap.options'] |
26
|
|
|
]); |
27
|
|
|
|
28
|
|
|
// convenience: random strings for passwords, token etc. |
29
|
|
|
$app->register(new SOG\Dashboard\RandomStringServiceProvider()); |
30
|
|
|
|
31
|
|
|
// mailing |
32
|
|
|
$app->register(new Silex\Provider\SwiftmailerServiceProvider()); |
33
|
|
|
$app['mailer.from'] = $dashboard_config['mailer.from']; |
34
|
|
|
$app['swiftmailer.options'] = $dashboard_config['swiftmailer.options']; |
35
|
|
|
|
36
|
|
|
$app->register(new Silex\Provider\SessionServiceProvider()); |
|
|
|
|
37
|
|
|
|
38
|
|
|
// used for handy `path()` calls inside Twig templates |
39
|
|
|
$app->register(new Silex\Provider\UrlGeneratorServiceProvider()); |
|
|
|
|
40
|
|
|
|
41
|
|
|
// security / login |
42
|
|
|
$app->register(new SOG\Dashboard\Authentication\LdapAuthenticationServiceProvider()); |
|
|
|
|
43
|
|
|
$app->register(new Silex\Provider\SecurityServiceProvider(), [ |
|
|
|
|
44
|
|
|
'security.firewalls' => [ |
45
|
|
|
'members' => [ |
46
|
|
|
'pattern' => '^/members/', |
47
|
|
|
'logout' => [ |
48
|
|
|
'logout_path' => '/members/logout' |
49
|
|
|
], |
50
|
|
|
'ldap' => [ |
51
|
|
|
'check_path' => '/members/login_check', |
52
|
|
|
'require_previous_session' => false |
53
|
|
|
], |
54
|
|
|
'users' => function () use ($app) { |
55
|
|
|
return $app['security.ldap.user_provider']($app['ldap']); |
56
|
|
|
}, |
57
|
|
|
'remember_me' => $dashboard_config['remember_me'] |
58
|
|
|
] |
59
|
|
|
], |
60
|
|
|
'security.role_hierarchy' => [ |
61
|
|
|
// 'ROLE_ADMIN' => ['ROLE_GROUP_ADMIN', 'ROLE_USER'], // unused |
62
|
|
|
'ROLE_GROUP_ADMIN' => ['ROLE_USER'] |
63
|
|
|
] |
64
|
|
|
]); |
65
|
|
|
|
66
|
|
|
$app->register(new Silex\Provider\RememberMeServiceProvider()); |
|
|
|
|
67
|
|
|
|
68
|
|
|
$app->register(new \SOG\Dashboard\DataUtilityServiceProvider()); |
|
|
|
|
69
|
|
|
|
70
|
|
|
// password recovery |
71
|
|
|
$app->mount('/password', new SOG\Dashboard\PasswordRecoveryControllerProvider()); |
|
|
|
|
72
|
|
|
|
73
|
|
|
// signing up guests for mailing lists |
74
|
|
|
$app->mount('/members/guests', new SOG\Dashboard\GuestControllerProvider()); |
|
|
|
|
75
|
|
|
|
76
|
|
|
// group management functionality |
77
|
|
|
$app->mount('/members/groups', new \SOG\Dashboard\GroupControllerProvider()); |
|
|
|
|
Methods can only be called on objects. This check looks for methods being called on variables that have been inferred to never be objects.