225 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			225 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| Configuration Options
 | |
| =====================
 | |
| 
 | |
| The module comes with a set of attributes to configure. The following is the list of all available options: 
 | |
| 
 | |
| #### enableTwoFactorAuthentication (type: `boolean`, default: `false`)
 | |
| 
 | |
| Setting this attribute will allow users to configure their login process with two-factor authentication. 
 | |
| 
 | |
| #### twoFactorAuthenticationCycles (type: `integer`, default: `1`)
 | |
| 
 | |
| By default, Google Authenticator App for two-factor authentication cycles in periods of 30 seconds. In order to allow 
 | |
| a bigger period so to avoid out of sync issues.
 | |
| 
 | |
| #### enableGdprCompliance (type: `boolean`, default: `false`)
 | |
| 
 | |
| Setting this attribute enables a serie of measures to comply with EU GDPR regulation, like data consent, right to be forgotten and data portability.
 | |
| 
 | |
| #### gdprPrivacyPolicyUrl (type: `array`, default: null)
 | |
| The link to privacy policy. This will be used on registration form as "read our pivacy policy". It must follow the same format as `yii\helpers\Url::to`
 | |
| 
 | |
| #### gdprExportProperties (type: `array`)
 | |
| 
 | |
| An array with the name of the user identity properties to be included when user request download of his data.
 | |
| Names can include relations like `profile.name`.
 | |
| 
 | |
| Defaults to:
 | |
| ```php
 | |
|       [
 | |
|         'email',
 | |
|         'username',
 | |
|         'profile.public_email',
 | |
|         'profile.name',
 | |
|         'profile.gravatar_email',
 | |
|         'profile.location',
 | |
|         'profile.website',
 | |
|         'profile.bio'
 | |
|       ]
 | |
| ```
 | |
| 
 | |
| 
 | |
| #### gdprAnonymizePrefix (type: `string`, default: `GDPR`)
 | |
| Prefix to be used as a replacement when user requeste deletion of his data
 | |
| 
 | |
| #### gdprConsentMessage (type: `string`)
 | |
| Use this to customize the message that will appear as hint in the give consent checkbox.
 | |
| If you leave it empty the next message will be used:
 | |
| 
 | |
| >I agree processing of my personal data and the use of cookies to facilitate the operation of this site. For more information read our privacy policy
 | |
| 
 | |
| #### GdprRequireConsentToAll (type `boolean`, default `false`)
 | |
| Whether require to already registered user give consent to process their data. According to GDPR this is mandatory.
 | |
| To forbid user access to any function, until it gives consent, use the AccessRuleFilter included with this module.
 | |
| 
 | |
| #### GdprConsentExcludedUrls (type `array`, default `['user/settings/*']`)
 | |
| List of urls that does not require explicit data processing consent to be accessed, like own profile, account... You can use wildcards like `route/to/*` .
 | |
| 
 | |
| #### enableRegistration (type: `boolean`, default: `true`)
 | |
| 
 | |
| Setting this attribute allows the registration process. If you set it to `false`, the module won't allow users to 
 | |
| register by throwing a `NotFoundHttpException` if the `RegistrationController::actionRegister()` is accessed. 
 | |
| 
 | |
| #### enableEmailConfirmation (type: `boolean`, default: `true`)
 | |
| 
 | |
| If `true`, the module will send an email with a confirmation link that user needs to click through to complete its 
 | |
| registration process.
 | |
| 
 | |
| #### enableFlashMessages (type: `boolean`, default: `true`)
 | |
| 
 | |
| If `true` views will display flash messages. Disable this if you want to handle messages display in your views.
 | |
| 
 | |
| #### enableSwitchIdentities (type: `boolean`, default: `true`)
 | |
|  
 | |
| If `true` allows switching identities for the admin user.
 | |
| 
 | |
| #### generatePasswords (type: `boolean`, default: `true`)
 | |
| 
 | |
| If `true` the password field will be hidden on the registration page and passwords will be generated automatically and 
 | |
| sent to the user via email.
 | |
| 
 | |
| #### allowUnconfirmedEmailLogin (type: `boolean`, default: `false`)
 | |
| 
 | |
| If `true` it will allow users to login with unconfirmed emails.
 | |
|   
 | |
| #### allowPasswordRecovery (type: `boolean`, default: `true`)
 | |
| 
 | |
| If `true` it will enable password recovery process.
 | |
| 
 | |
| #### allowAdminPasswordRecovery (type: `boolean`, default: `true`)
 | |
| 
 | |
| If `true` it will enable administrator to send a password recovery email to a user.
 | |
| 
 | |
| #### maxPasswordAge (type: `integer`, default: `null`)
 | |
| 
 | |
| If set to an integer value it will check user password age. If the days since last password change are greater than this configuration value
 | |
| user will be forced to change it. This enforcement is done only at login stage. In order to perform the check in every action you must configure
 | |
| a filter into your controller like this:
 | |
| ```
 | |
| use Da\User\Filter\PasswordAgeEnforceFilter;
 | |
| class SiteController extends Controller
 | |
| {
 | |
|     public function behaviors()
 | |
|     {
 | |
|         return [
 | |
|             [...]
 | |
|             'enforcePasswordAge' => [
 | |
|                 'class' => PasswordAgeEnforceFilter::className(),
 | |
|             ],
 | |
| ```
 | |
| This will redirect the user to their account page until the password has been updated.
 | |
| 
 | |
| #### allowAccountDelete (type: `boolean`, default: `false`)
 | |
| 
 | |
| If `true` users will be able to remove their own accounts. 
 | |
| 
 | |
| #### emailChangeStrategy (type: `integer`, default: `MailChangeStrategyInterface::TYPE_DEFAULT`)
 | |
| 
 | |
| Configures one of the three ways available to change user's password:
 | |
| 
 | |
| - **MailChangeStrategyInterface::TYPE_DEFAULT**: A confirmation message will be sent to the new user's email with a link 
 | |
|     that needs to be click through to confirm  it.
 | |
| - **MailChangeStrategyInterface::TYPE_INSECURE**: Email will be changed without any confirmation message. 
 | |
| - **MailChangeStrategyInterface::TYPE_SECURE**: A confirmation message will be sent to the previous and new user's email 
 | |
|     with a link that would require both to be click through to confirm the change.
 | |
|     
 | |
| #### rememberLoginLifespan (type: `integer`, default: `1209600`)
 | |
| 
 | |
| Configures the time length in seconds a user will be remembered without the need to login again. The default time is 2 
 | |
| weeks. 
 | |
| 
 | |
| #### tokenConfirmationLifespan (type: `integer`, default: `86400`)
 | |
| 
 | |
| Configures the time length in seconds a confirmation token is valid. The default time is 24 hours.
 | |
|   
 | |
| #### tokenRecoveryLifespan (type: `integer`, default: `21600`)
 | |
| 
 | |
| Configures the time length in seconds a recovery token is valid. The default time is 6 hours.
 | |
| 
 | |
| #### administrators (type: `array`, default: `[]`)
 | |
| 
 | |
| Configures the usernames of those users who are considered `admininistrators`. The administrators can be 
 | |
| configured here or throughout RBAC with a special permission name. The recommended way is throughout 
 | |
| `administratorPermissionName` as they can be set dynamically throughout the RBAC interface, but use this attribute for 
 | |
| simple backends with static administrators that won't change throughout time.   
 | |
| 
 | |
| #### administratorPermissionName (type: `string`, default: `null`)
 | |
| 
 | |
| Configures the permission name for `administrators`. See [AuthHelper](../../src/User/Helper/AuthHelper.php).
 | |
|  
 | |
| #### prefix (type: `string`, default: `user`) 
 | |
| 
 | |
| Configures the URL prefix for the module. 
 | |
| 
 | |
| 
 | |
| #### mailParams (type: `array`, default: `[]`)
 | |
| 
 | |
| Configures the parameter values used on [MailFactory](../../src/User/Factory/MailFactory.php). The default values are: 
 | |
| 
 | |
| ```php
 | |
| [
 | |
|     'fromEmail' => 'no-reply@example.com',
 | |
|     'welcomeMailSubject' => Yii::t('usuario', 'Welcome to {0}', $app->name),
 | |
|     'confirmationMailSubject' => Yii::t('usuario', 'Confirm account on {0}', $app->name),
 | |
|     'reconfirmationMailSubject' => Yii::t('usuario', 'Confirm email change on {0}', $app->name),
 | |
|     'recoveryMailSubject' => Yii::t('usuario', 'Complete password reset on {0}', $app->name),
 | |
| ]
 | |
| ```
 | |
| 
 | |
| #### blowfishCost (type: `integer`, default: `10`)
 | |
| 
 | |
| Is the cost parameter used by the Blowfish hash algorithm. The higher the value of cost, the longer it takes to generate 
 | |
| the hash and to verify a password against it. Higher cost therefore slows down a brute-force attack. For the best 
 | |
| protected against brute-force attacks, set it to the highest value that is tolerable on production servers. The time 
 | |
| taken to compute the hash doubles for every increment by one of `$blowfishCost`.
 | |
| 
 | |
| 
 | |
| #### consoleControllerNamespace (type: `string`, default: `Da\User\Command`)
 | |
| 
 | |
| Allows customization of the console application controller namespace for the module.
 | |
| 
 | |
| #### controllerNamespace (type: `string`, default: `Da\User\Controller`)
 | |
| 
 | |
| Allows customization of the web application controller namespace for the module.
 | |
| 
 | |
| #### classMap (type: `array`, default: `[]`)
 | |
| 
 | |
| Configures the definitions of the classes as they have to be override. For more information see 
 | |
| [Overriding Classes](../enhancing-and-overriding/overriding-classes.md). 
 | |
| 
 | |
| #### routes (type: `array`, default: `[]` )
 | |
| 
 | |
| The routes (url rules) of the module for the URL management. The default values are: 
 | |
| 
 | |
| ```php 
 | |
| [
 | |
|     '<id:\d+>' => 'profile/show',
 | |
|     '<action:(login|logout)>' => 'security/<action>',
 | |
|     '<action:(register|resend)>' => 'registration/<action>',
 | |
|     'confirm/<id:\d+>/<code:[A-Za-z0-9_-]+>' => 'registration/confirm',
 | |
|     'forgot' => 'recovery/request',
 | |
|     'recover/<id:\d+>/<code:[A-Za-z0-9_-]+>' => 'recovery/reset',
 | |
|     'settings/<action:\w+>' => 'settings/<action>',
 | |
| ]
 | |
| ```
 | |
| 
 | |
| #### viewPath (type: `string`, default: `@Da/User/resources/views`)
 | |
| 
 | |
| Configures the root directory of the view files. See [overriding views](../enhancing-and-overriding/overriding-views.md).
 | |
| 
 | |
| #### switchIdentitySessionKey (type: `string`, default: `yuik_usuario`) 
 | |
| 
 | |
| Configures the name of the session key that will be used to hold the original admin identifier.
 | |
| 
 | |
| #### restrictUserPermissionAssignment (type: `boolean`, default: `false`)
 | |
| 
 | |
| If `false`, allow the assignment of both roles and permissions to users.
 | |
| Set to `true` to restrict user assignments to roles only.
 | |
| 
 | |
| #### disableIpLogging (type: `boolean`, default: `false`)
 | |
| 
 | |
| If `true` registration and last login IPs are not logged into users table, instead a dummy 127.0.0.1 is used
 | |
| 
 | |
| 
 | |
| © [2amigos](http://www.2amigos.us/) 2013-2019
 |