module.config.php 13.8 KB
Newer Older
Bertrand Gauthier's avatar
Bertrand Gauthier committed
1
2
<?php
$settings = array(
3
4
5
6
7
8
9
    /**
     * Fournisseurs d'identité.
     */
    'identity_providers' => array(
        200 => 'UnicaenAuth\Provider\Identity\Db',
        100 => 'UnicaenAuth\Provider\Identity\Ldap',
    ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
10
);
11

Bertrand Gauthier's avatar
Bertrand Gauthier committed
12
13
14
15
16
17
18
19
20
21
22
23
24
25
$zfcuserSettings = array(
    /**
     * Enable registration
     * Allows users to register through the website.
     * Accepted values: boolean true or false
     */
    'enable_registration' => true,
    /**
     * Modes for authentication identity match
     * Specify the allowable identity modes, in the order they should be
     * checked by the Authentication plugin.
     * Default value: array containing 'email'
     * Accepted values: array containing one or more of: email, username
     */
26
    'auth_identity_fields' => array('username', 'email'),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
    /**
     * Login Redirect Route
     * Upon successful login the user will be redirected to the entered route
     * Default value: 'zfcuser'
     * Accepted values: A valid route name within your application
     */
    'login_redirect_route' => 'home',
    /**
     * Logout Redirect Route
     * Upon logging out the user will be redirected to the enterd route
     * Default value: 'zfcuser/login'
     * Accepted values: A valid route name within your application
     */
    'logout_redirect_route' => 'home',
    /**
     * Enable Username
     * Enables username field on the registration form, and allows users to log
     * in using their username OR email address. Default is false.
     * Accepted values: boolean true or false
     */
47
    'enable_username' => false,
48
    /**     
Bertrand Gauthier's avatar
Bertrand Gauthier committed
49
50
51
52
53
54
     * Enable Display Name
     * Enables a display name field on the registration form, which is persisted
     * in the database. Default value is false.
     * Accepted values: boolean true or false
     */
    'enable_display_name' => true,
Bertrand Gauthier's avatar
Bertrand Gauthier committed
55
56
57
58
59
60
61
62
    /**     
     * Authentication Adapters
     * Specify the adapters that will be used to try and authenticate the user
     * Default value: array containing 'ZfcUser\Authentication\Adapter\Db' with priority 100
     * Accepted values: array containing services that implement 'ZfcUser\Authentication\Adapter\ChainableAdapter'
     */
    'auth_adapters' => array(
        300 => 'UnicaenAuth\Authentication\Adapter\Ldap', // notifié en 1er
63
        200 => 'UnicaenAuth\Authentication\Adapter\Db',   //         ensuite (si échec d'authentification Ldap)
Bertrand Gauthier's avatar
Bertrand Gauthier committed
64
        100 => 'UnicaenAuth\Authentication\Adapter\Cas',  //         ensuite (si échec d'authentification Db)
Bertrand Gauthier's avatar
Bertrand Gauthier committed
65
    ),
66
67
68
69
70
    
    // telling ZfcUser to use our own class
    'user_entity_class'       => 'UnicaenAuth\Entity\Db\User',
    // telling ZfcUserDoctrineORM to skip the entities it defines
    'enable_default_entities' => false,
Bertrand Gauthier's avatar
Bertrand Gauthier committed
71
);
72
    
73
74
75
76
77
78
79
$bjyauthorize = array(
    /* this module uses a meta-role that inherits from any roles that should
     * be applied to the active user. the identity provider tells us which
     * roles the "identity role" should inherit from.
     *
     * for ZfcUser, this will be your default identity provider
     */
80
    'identity_provider' => 'UnicaenAuth\Provider\Identity\Chain',
81
82
83
84
85
86
87
    
    /* role providers simply provide a list of roles that should be inserted
     * into the Zend\Acl instance. the module comes with two providers, one
     * to specify roles in a config file and one to load roles using a
     * Zend\Db adapter.
     */
    'role_providers' => array(
88
89
90
91
92
93
        /**
         * 2 rôles doivent systématiquement exister dans les ACL :
         * - le rôle par défaut 'guest', c'est le rôle de tout utilisateur non authentifié.
         * - le rôle 'user', c'est le rôle de tout utilisateur authentifié.
         */
        'UnicaenAuth\Provider\Role\Config' => array(
94
95
            'guest' => array('name' => "Non authentifié(e)", 'selectable' => false, 'children' => array(
                'user' => array('name' => "Authentifié(e)", 'selectable' => false)
96
97
98
99
100
101
            )),
        ),
        /**
         * Fournit les rôles issus de la base de données éventuelle de l'appli.
         * NB: si le rôle par défaut 'guest' est fourni ici, il ne sera pas ajouté en double dans les ACL.
         * NB: si la connexion à la base échoue, ce n'est pas bloquant!
102
         */
103
        'UnicaenAuth\Provider\Role\DbRole' => array(
104
105
            'object_manager'    => 'doctrine.entitymanager.orm_default',
            'role_entity_class' => 'UnicaenAuth\Entity\Db\Role',
106
        ),
107
108
109
110
111
112
        /**
         * Fournit le rôle correspondant à l'identifiant de connexion de l'utilisateur.
         * Cela est utile lorsque l'on veut gérer les habilitations d'un utilisateur unique
         * sur des ressources.
         */
        'UnicaenAuth\Provider\Role\Username' => array(),
113
114
115
    ),

    // strategy service name for the strategy listener to be used when permission-related errors are detected
116
117
//    'unauthorized_strategy' => 'BjyAuthorize\View\RedirectionStrategy',
    'unauthorized_strategy' => 'UnicaenAuth\View\RedirectionStrategy',
118
    
119
120
121
122
123
124
125
126
    /* Currently, only controller and route guards exist
     */
    'guards' => array(
        /* If this guard is specified here (i.e. it is enabled), it will block
         * access to all controllers and actions unless they are specified here.
         * You may omit the 'action' index to allow access to the entire controller
         */
        'BjyAuthorize\Guard\Controller' => array(
127
128
129
            array('controller' => 'index', 'action' => 'index',   'roles' => array()),
            array('controller' => 'zfcuser',                      'roles' => array()),
            array('controller' => 'Application\Controller\Index', 'roles' => array()),
130

131
132
133
134
135
136
            array('controller' => 'UnicaenApp\Controller\Application',  'action' => 'etab',                     'roles' => array()),
            array('controller' => 'UnicaenApp\Controller\Application',  'action' => 'apropos',                  'roles' => array()),
            array('controller' => 'UnicaenApp\Controller\Application',  'action' => 'contact',                  'roles' => array()),
            array('controller' => 'UnicaenApp\Controller\Application',  'action' => 'plan',                     'roles' => array()),
            array('controller' => 'UnicaenApp\Controller\Application',  'action' => 'mentions-legales',         'roles' => array()),
            array('controller' => 'UnicaenApp\Controller\Application',  'action' => 'informatique-et-libertes', 'roles' => array()),
137
            array('controller' => 'UnicaenAuth\Controller\Utilisateur', 'action' => 'selectionner-profil',      'roles' => array()),
138
139
140
        ),
    ),
);
Bertrand Gauthier's avatar
Bertrand Gauthier committed
141
142
143

return array(
    'zfcuser' => $zfcuserSettings,
144
    'bjyauthorize' => $bjyauthorize,
Bertrand Gauthier's avatar
Bertrand Gauthier committed
145
    'unicaen-auth' => $settings,
146
    'doctrine' => array(
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
        'driver' => array(
            // overriding zfc-user-doctrine-orm's config
            'zfcuser_entity' => array(
                'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
                'paths' => array(
                    __DIR__ . '/../src/UnicaenAuth/Entity/Db'
                )
            ),
            'orm_auth_driver' => array(
                'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
                'cache' => 'array',
                'paths' => array(
                    __DIR__ . '/../src/UnicaenAuth/Entity/Db'
                )
            ),
            'orm_default' => array(
                'class'   => 'Doctrine\ORM\Mapping\Driver\DriverChain',
                'drivers' => array(
                    'UnicaenAuth\Entity\Db' => 'zfcuser_entity',
                    'UnicaenAuth\Entity\Db' => 'orm_auth_driver'
                )
            ),
169
170
        ),
    ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
171
    'service_manager' => array(
172
173
174
175
        'aliases' => array(
            'Zend\Authentication\AuthenticationService' => 'zfcuser_auth_service',
        ),
        'invokables' => array(
176
177
178
            'unicaen-auth_user_service'               => 'UnicaenAuth\Service\User',
            'UnicaenAuth\Authentication\Storage\Db'   => 'UnicaenAuth\Authentication\Storage\Db',
            'UnicaenAuth\Authentication\Storage\Ldap' => 'UnicaenAuth\Authentication\Storage\Ldap',
179
            'UnicaenAuth\View\RedirectionStrategy'    => 'UnicaenAuth\View\RedirectionStrategy',
180
            'authUserContext'                         => 'UnicaenAuth\Service\UserContext'
181
        ),
182
183
184
        'abstract_factories' => array(
            'UnicaenAuth\Authentication\Adapter\AbstractFactory',
        ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
185
        'factories' => array(
186
187
            'unicaen-auth_module_options'              => 'UnicaenAuth\Options\ModuleOptionsFactory',
            'zfcuser_auth_service'                     => 'UnicaenAuth\Authentication\AuthenticationServiceFactory',
188
189
190
191
192
            'UnicaenAuth\Authentication\Storage\Chain' => 'UnicaenAuth\Authentication\Storage\ChainServiceFactory',
            'UnicaenAuth\Provider\Identity\Chain'      => 'UnicaenAuth\Provider\Identity\ChainServiceFactory',
            'UnicaenAuth\Provider\Identity\Ldap'       => 'UnicaenAuth\Provider\Identity\LdapServiceFactory',
            'UnicaenAuth\Provider\Identity\Db'         => 'UnicaenAuth\Provider\Identity\DbServiceFactory',
            'UnicaenAuth\Provider\Role\Config'         => 'UnicaenAuth\Provider\Role\ConfigServiceFactory',
193
            'UnicaenAuth\Provider\Role\DbRole'         => 'UnicaenAuth\Provider\Role\DbRoleServiceFactory',
194
            'UnicaenAuth\Provider\Role\Username'       => 'UnicaenAuth\Provider\Role\UsernameServiceFactory',
Bertrand Gauthier's avatar
Bertrand Gauthier committed
195
        ),
196
197
198
        'initializers' => array(
            'UnicaenAuth\Service\UserAwareInitializer',
        ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
199
    ),
200
201
    'controllers' => array(
        'invokables' => array(
202
            'UnicaenAuth\Controller\Utilisateur' => 'UnicaenAuth\Controller\UtilisateurController',
203
204
        ),
    ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
205
    'view_manager' => array(
206
207
208
        'template_map' => array(
            'error/403' => __DIR__ . '/../view/error/403.phtml',
        ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
209
        'template_path_stack' => array(
210
            'unicaen-auth' => __DIR__ . '/../view',
Bertrand Gauthier's avatar
Bertrand Gauthier committed
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
        ),
    ),
    'translator' => array(
        'translation_file_patterns' => array(
            array(
                'type'     => 'gettext',
                'base_dir' => __DIR__ . '/../language',
                'pattern'  => '%s.mo',
            ),
        ),
    ),
    'router' => array(
        'routes' => array(
            'zfcuser' => array(
                'type' => 'Literal',
                'priority' => 1000,
                'options' => array(
Bertrand Gauthier's avatar
Bertrand Gauthier committed
228
                    'route' => '/auth',
Bertrand Gauthier's avatar
Bertrand Gauthier committed
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
                    'defaults' => array(
                        'controller' => 'zfcuser',
                        'action'     => 'index',
                    ),
                ),
                'may_terminate' => true,
                'child_routes' => array(
                    'login' => array(
                        'type' => 'Literal',
                        'options' => array(
                            'route' => '/connexion',
                            'defaults' => array(
                                'controller' => 'zfcuser',
                                'action'     => 'login',
                            ),
                        ),
                    ),
                    'logout' => array(
                        'type' => 'Literal',
                        'options' => array(
                            'route' => '/deconnexion',
                            'defaults' => array(
                                'controller' => 'zfcuser',
                                'action'     => 'logout',
                            ),
                        ),
                    ),
256
257
258
259
260
261
262
263
264
265
                    'register' => array(
                        'type' => 'Literal',
                        'options' => array(
                            'route' => '/creation-compte',
                            'defaults' => array(
                                'controller' => 'zfcuser',
                                'action'     => 'register',
                            ),
                        ),
                    ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
266
267
                ),
            ),
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
            'utilisateur' => array(
                'type'    => 'Literal',
                'options' => array(
                    'route'    => '/utilisateur',
                    'defaults' => array(
                        '__NAMESPACE__' => 'UnicaenAuth\Controller',
                        'controller'    => 'Utilisateur',
                        'action'        => 'index',
                    ),
                ),
                'may_terminate' => true,
                'child_routes' => array(
                    'default' => array(
                        'type'    => 'Segment',
                        'options' => array(
                            'route'    => '/:action[/:id]',
                            'constraints' => array(
                                'action' => '[a-zA-Z][a-zA-Z0-9_-]*',
                                'id'     => '[0-9]*',
                            ),
                            'defaults' => array(
                                'action' => 'index',
                            ),
                        ),
                    ),
                ),
            ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
295
296
297
298
299
300
301
302
303
304
        ),
    ),
    // All navigation-related configuration is collected in the 'navigation' key
    'navigation' => array(
        // The DefaultNavigationFactory we configured uses 'default' as the sitemap key
        'default' => array(
            // And finally, here is where we define our page hierarchy
            'home' => array(
                'pages' => array(
                    'login' => array(
305
                        'label'    => _("Connexion"),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
306
307
308
309
                        'route'    => 'zfcuser/login',
                        'visible'  => false,
                    ),
                    'register' => array(
310
                        'label'   => _("Enregistrement"),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
311
312
313
314
315
316
317
                        'route'   => 'zfcuser/register',
                        'visible' => false,
                    ),
                ),
            ),
        ),
    ),
318
);