module.config.php 12.3 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
94
95
96
97
98
99
100
101
        /**
         * 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(
            'guest' => array('name' => "Non authentifié(e)", 'children' => array(
                'user' => array('name' => "Authentifié(e)")
            )),
        ),
        /**
         * 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
138
139
        ),
    ),
);
Bertrand Gauthier's avatar
Bertrand Gauthier committed
140
141
142

return array(
    'zfcuser' => $zfcuserSettings,
143
    'bjyauthorize' => $bjyauthorize,
Bertrand Gauthier's avatar
Bertrand Gauthier committed
144
    'unicaen-auth' => $settings,
145
    'doctrine' => array(
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
        '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'
                )
            ),
168
169
        ),
    ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
170
    'service_manager' => array(
171
172
173
174
        'aliases' => array(
            'Zend\Authentication\AuthenticationService' => 'zfcuser_auth_service',
        ),
        'invokables' => array(
175
176
177
            'unicaen-auth_user_service'               => 'UnicaenAuth\Service\User',
            'UnicaenAuth\Authentication\Storage\Db'   => 'UnicaenAuth\Authentication\Storage\Db',
            'UnicaenAuth\Authentication\Storage\Ldap' => 'UnicaenAuth\Authentication\Storage\Ldap',
178
            'UnicaenAuth\View\RedirectionStrategy'    => 'UnicaenAuth\View\RedirectionStrategy',
179
        ),
180
181
182
        'abstract_factories' => array(
            'UnicaenAuth\Authentication\Adapter\AbstractFactory',
        ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
183
        'factories' => array(
184
185
            'unicaen-auth_module_options'              => 'UnicaenAuth\Options\ModuleOptionsFactory',
            'zfcuser_auth_service'                     => 'UnicaenAuth\Authentication\AuthenticationServiceFactory',
186
187
188
189
190
            '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',
191
            'UnicaenAuth\Provider\Role\DbRole'         => 'UnicaenAuth\Provider\Role\DbRoleServiceFactory',
192
            'UnicaenAuth\Provider\Role\Username'       => 'UnicaenAuth\Provider\Role\UsernameServiceFactory',
Bertrand Gauthier's avatar
Bertrand Gauthier committed
193
        ),
194
195
196
        'initializers' => array(
            'UnicaenAuth\Service\UserAwareInitializer',
        ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
197
    ),
198
199
    'controllers' => array(
        'invokables' => array(
200
            
201
202
        ),
    ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
203
    'view_manager' => array(
204
205
206
        'template_map' => array(
            'error/403' => __DIR__ . '/../view/error/403.phtml',
        ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
207
        'template_path_stack' => array(
208
            'unicaen-auth' => __DIR__ . '/../view',
Bertrand Gauthier's avatar
Bertrand Gauthier committed
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
        ),
    ),
    '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
226
                    'route' => '/auth',
Bertrand Gauthier's avatar
Bertrand Gauthier committed
227
228
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
                    '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',
                            ),
                        ),
                    ),
254
255
256
257
258
259
260
261
262
263
                    'register' => array(
                        'type' => 'Literal',
                        'options' => array(
                            'route' => '/creation-compte',
                            'defaults' => array(
                                'controller' => 'zfcuser',
                                'action'     => 'register',
                            ),
                        ),
                    ),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
264
265
266
267
268
269
270
271
272
273
274
275
                ),
            ),
        ),
    ),
    // 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(
276
                        'label'    => _("Se connecter"),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
277
278
279
280
                        'route'    => 'zfcuser/login',
                        'visible'  => false,
                    ),
                    'register' => array(
281
                        'label'   => _("S'enregistrer"),
Bertrand Gauthier's avatar
Bertrand Gauthier committed
282
283
284
285
286
287
288
                        'route'   => 'zfcuser/register',
                        'visible' => false,
                    ),
                ),
            ),
        ),
    ),
289
);