-
Notifications
You must be signed in to change notification settings - Fork 54
06 Data Storage
During the initial configuration of the component, there is a very important configuration parameter to take into account : How to store users metadata ? You can decide whether to store users' MFA metadata in ADDS attributes or to use SQLServer as a repository. Below are a few items that can help you choose. The default is to use ADDS as repository
You also have the possibility of implementing your own component allowing to store the information of the users according to your wishes.
The first thing to come to mind is not to use SQL-Server, whose license cost is significant (even under Linux ...), therefore new types of databases, Web services or a security appliance.
For this, you must develop a custom component that you can integrate into the configuration of MFA.
This component must be deployed by you on each adfs server on your farm.
This component should derive from the class provided: DataRepositoryService, as well as from the IWebAuthNDataRepositoryService interface.
The easiest way is to take inspiration from the standard code (ADDS, SQL) or the example provided InMemoryDataRepositoryService, and InMemoryKeys2RepositoryService
Servers | ADDS | ADDS Comments | SQL | SQL Comments |
---|---|---|---|---|
Single ADFS Server |
Yes |
Pro - Most simple configuration - No need of external platform. - Data is replicated against All DCs - Can work with any ADDS Schema version Cons - Data replication can take some time - Not a good practice to write on AD 😃 - Default config require ADDS Schema 2012 |
Maybe |
Pro - Easy to share data with other applications - No replication of data needed - Must be used with “AdfsLocalClaimsProviderTrust” and “AdfsLdapServerConnection” Adfs 2016 Cons - Need of additional platform (SQL-Server). - No replication of data, need backup strategy or Always On replication. - Management is let to DBAs, not to security admins. |
Multiple ADFS Servers |
Yes |
Pro - Most simple configuration - No need of external platform. - Data is replicated against All DCs - Can work with any ADDS Schema version Cons - Data replication can take some time - Not a good practice to write on AD 😃 - Default config require ADDS Schema 2012 |
Yes |
Pro - Easy to share data with other applications - No replication of data needed - Must be used with “AdfsLocalClaimsProviderTrust” and “AdfsLdapServerConnection” Adfs 2016 Cons - Need of additional platform (SQL-Server). - No replication of data, need backup strategy. - Management is let to DBAs, not to security admins. - Depending of your network configuration (DMZ or other) access to SQL instance must be granted and secured. |
I want to use RSA/AES security options |
Yes |
Pro It's a feature |
Yes |
Pro It's a feature |
I want to use RSA security certificates per user |
Yes |
Pro It's a feature |
Yes |
Pro It's a feature |
Can I use Local Claim Providers Trust to authenticate users stored in LDAP server and use MFA ADFS 2016+ |
No | ADFS requirements by design. We cannot store users metadata in external LDAP server. |
Yes | LDAP users can be registered with MFA when using SQL Mode |
If you have choose to use ADDS, you must verify or modify your ADDS configuration.
To view your configuration you must use PowerShell applets or the MMC.
- Log on the a primary Adfs server as administrator
- Launch a new PowerShell session as administrator
- type get-help Get-MFAStore –detailed to get information.
- type get-help Set-MFAStore –detailed to get information.
- Enter your command
Get-MFAStore -Store ADDS$c = Get-MFAStore -Store ADDS ... Set-MFAStore -Store ADDS -Config $c
Property | Default Value | Comments |
---|---|---|
Active | True | True if ADDS mode is enabled |
KeyAttribute | msDS-cloudExtensionAttribute10 | Attribute used to store the user key (RNG, RSA) |
MailAttribute | msDS-cloudExtensionAttribute11 | Attribute used to store personal email address Can be a multivalued property |
PhoneAttribute | msDS-cloudExtensionAttribute12 | Attribute used to store mobile phone number Can be a multivalued property |
MethodAttribute | msDS-cloudExtensionAttribute13 | Attribute used to store user’s method for MFA (Code, Mail, SMS, Azure, Choose) |
OverrideMethodAttribute | msDS-cloudExtensionAttribute14 | Attribute used to store user’s specific method for MFA (Code, Mail, SMS, Azure, Choose) |
PinAttribute | msDS-cloudExtensionAttribute15 | Pin code for user |
PublicKeyCredentialAttribute | otherMailbox | Attribute used to store biometric Public Key Descriptors MUST be a multivalued user attribute |
ClientCertificateAttribute | msDS-cloudExtensionAttribute16 | Attribute used to store Client Certificate (future feature) |
RSACertificateAttribute | msDS-cloudExtensionAttribute17 | Attribute used to store RSA Certificate when using RSA per user |
EnabledAttribute | msDS-cloudExtensionAttribute18 | Boolean, specify if the user account for MFA is enabled. Access would be allowed depending of the Policy Template you choose. |
MaxRows | 10000 | Maximum rows per LDAP query |
UseSSL | False | By default, LDAP requests pass in clear on the network, but the authentication phase is secure, the identification informations (credentials) are encrypted (challenge). You can, if you deploy the appropriate SSL certificates on your domain controllers, the use of LDAPS (port 636) to secure all of the LDAP streams. However port 389 cannot be disabled, this is required for the initialization of the secure connection. |
- Log on the a primary Adfs server as administrator
- Launch a new PowerShell session as administrator
- Enter these commands
$c = Get-MFAStore -Store ADDS $c.MailAttribute = "otherMailbox" Set-MFAStore -Store ADDS -Config $c
We support three Templates for attributes description, you change these values according to your needs and respecting the prerequisites. Using the MFA schema does not depend on the schema level of your ADDS forests, You can have different forests levels. Remember that a schema modification is irreversible, however the auxiliary class can be deactivated.
- Log on the a primary Adfs server as administrator
- Launch a new PowerShell session as administrator
- type get-help Set-MFAActiveDirectoryTemplate –detailed to get information.
- Enter your command
Set-MFAActiveDirectoryTemplate -Kind SchemaAll or Set-MFAActiveDirectoryTemplate -Kind Schema2016 or Set-MFAActiveDirectoryTemplate -Kind SchemaMFA
First ! Backup or take snapshot of your domain controllers !!!
Locate the 2 LDF files in C:\Program Files\MFA\ADDSTools
Choose between the confidential version or the standard version (the only difference is the searchFlags set to 0x80 or 0)Edit selected LDF and replace each occurrence of ",DC=X" with the distinguished name of your domain -> ",DC=mydomain,DC=com"
Copy the modified LDF file on your domain controller Deploy the schema extension as domain administrator.
LDIFDE -i -u -f MFA.MODIFIED.SCHEMA.LDF
- Log on the a primary Adfs server as administrator
- Launch MMC snappin
If you have choose to use SQL, you must verify or modify your SQL configuration.
To view your configuration you must use PowerShell applets or the MMC. To Use SQL Mode, you must create a SQL Database on a full SQL Server instance (standard or Enterprise)
- Log on the a primary Adfs server as administrator
- Launch a new PowerShell session as administrator
- type get-help Get-MFAStore –detailed to get information.
- type get-help Set-MFAStore –detailed to get information.
- type get-help New-MFADatabase -detailed to get information
- Enter your commands
Get-MFAStore -Store SQL$c = Get-MFAStore -Store SQL ... Set-MFAStore -Store SQL -Config $c
Property | Default Value | Comments |
---|---|---|
Active | False | True if SQL Mode is Enabled |
ConnectionString | empty (required) | SQL Server connection string used to connect to the MFA Database created with New-MFADatabase You can use any instance and SQL version must be 2008r2 and Up |
MaxRows | 10000 | Maximum rows per SQL query |
Property | Default Value | Comments |
---|---|---|
IsAlwaysEncrypted | False | Database columns (SecretKey, Email, Phone number, PIN) are encrypted by SQL Server |
CertificateValidity | 5 | Certificate duration valididy (default 5 years) |
ThumbPrint | specific | Certificate thumprint (Must be Deployed on all Adfs servers) |
CertReuse | False | Used if you reuse an existing certificate for SQL Encryption |
KeyName | adfsmfa | Encryption KeyName (default: adfsmfa) |
$c = Get-MFAStore -Store SQL $c.Active = $True $c.ConnectionString = "Persist Security Info=False;Integrated Security=SSPI; Initial Catalog=MFADatabase;Data Source=sqlserver\instance" Set-MFAConfigSQL -Store SQL -Config $c
- Log on the a primary Adfs server as administrator
- Launch MMC snappin
The account under witch you run New-MFADatabase Cmdlet must have the SQLServer dbcreator role.
- Log on the a primary Adfs server as administrator
- Launch a new PowerShell session as administrator
- type get-help New-MFADatabase -detailed to get information
- Enter your commands
# Using an SQL account for connecting to the MFA Database New-MFADatabase -ServerName SQLServer\Instance -DatabaseName MFADatabase -UserName sqlaccount -Password pwd# Using a domain account for connection to the MFA Database New-MFADatabase -ServerName SQLServer\Instance -DatabaseName MFADatabase -UserName Domain\ADFSaccount# Using ADFS managed account for connecting to the new MFA Database New-MFADatabase -ServerName SQLServer\Instance -DatabaseName MFADatabase -UserName Domain\ADFSManagedAccount$Creating a MFA Database with Always Encrypted Columns (SQLServer 2016+)
# Using an SQL account for connecting to the MFA Database New-MFADatabase -ServerName SQLServer\Instance -DatabaseName MFADatabase -UserName sqlaccount -Password pwd -Encrypted# Using a domain account for connection to the MFA Database New-MFADatabase -ServerName SQLServer\Instance -DatabaseName MFADatabase -UserName Domain\ADFSaccount -Encrypted# Using ADFS managed account for connecting to the new MFA Database New-MFADatabase -ServerName SQLServer\Instance -DatabaseName MFADatabase -UserName Domain\ADFSManagedAccount$ -Encrypted
After creating a MFA Database with encryption, you must export the new certificate with the private key (.pfx), password is blank And you must deploy this cert on all others ADFS servers To be sure that the ADFS Service Account can access the private key of the new created certificate on others ADFS Servers You must run the PowerShell cmdlet
Update-MFACertificatesAccessControlList
If you have choose to use CUSTOM Storage, you must verify or modify your config.
To view your configuration you must use PowerShell applets or the MMC.
To Use Custom Mode, you must create a .Net component and deploy it on each adfs server (not proxies)
One component must derive form DataRepositoryService, and implement the IWebAuthNDataRepositoryService interface.
And another component must derive from KeysRepositoryService for Keys storage
Log on the a primary Adfs server as administrator
- Launch a new PowerShell session as administrator
- type get-help Get-MFAStore –detailed to get information.
- type get-help Set-MFAStore –detailed to get information.
- Enter your commands
Get-MFAStore -Store CUSTOM$c = Get-MFAStore -Store CUSTOM ... Set-MFAStore -Store CUSTOM -Config $c
Property | Default Value | Comments |
---|---|---|
Active | False | True if Custom Mode is Enabled |
ConnectionString | empty (required) | Connection string used to connect to your repository |
MaxRows | 10000 | Maximum rows per SQL query |
DataRepositoryFullyQualifiedImplementation | string | Fully Qualified Class implementation for DataRepositoryService |
KeysRepositoryFullyQualifiedImplementation | string | Fully Qualified Class implementation for KeysRepositoryService |
Parameters | string | Your custom parameters |
- Log on the a primary Adfs server as administrator
- Launch MMC snappin