-
Notifications
You must be signed in to change notification settings - Fork 120
Azure AD Authentication
jmah8 edited this page Apr 1, 2022
·
5 revisions
How to setup:
- Add an App Registration in Azure Active Directory, eg. AuthAPP
- From App Registration copy Application (client) ID.
- In Certificates & secrets Add a new client secret (password).
- In Azure SQL make sure your app has the right permission
CREATE USER [AuthAPP] FROM EXTERNAL PROVIDER
EXEC sp_addrolemember 'dbmanager', 'AuthAPP'
- In project settings.py, add
Authentication=ActiveDirectoryServicePrincipal
toextra_params
DATABASES = {
"default": {
"ENGINE": "mssql",
"NAME": "default",
"USER": "Application (client) ID",
"PASSWORD": "Client secret",
"HOST": "example.database.windows.net",
"PORT": "1433",
"OPTIONS": {
"driver": "ODBC Driver 17 for SQL Server",
"extra_params": "Authentication=ActiveDirectoryServicePrincipal",
},
},
}
How to setup:
(Interactive authentication only work on Windows, recommend using the latest version of ODBC 17 driver, some older versions may not be supported)
- In project settings.py, add
Authentication=ActiveDirectoryInteractive
toextra_params
- After running the Django project, a window will pop up asking the user to enter a password
DATABASES = {
"default": {
"ENGINE": "mssql",
"NAME": "default",
"USER": "user@email.com",
"HOST": "example.database.windows.net",
"PORT": "1433",
"OPTIONS": {
"driver": "ODBC Driver 17 for SQL Server",
"extra_params": "Authentication=ActiveDirectoryInteractive",
},
},
}
To use managed identity, add Authentication=ActiveDirectoryMsi
to extra_params
.
DATABASES = {
"default": {
"ENGINE": "mssql",
"NAME": "your_db",
"HOST": "database.windows.net",
"PORT": "1433",
"OPTIONS": {
"driver": "ODBC Driver 17 for SQL Server",
"extra_params": "Authentication=ActiveDirectoryMsi",
},
},
}
If you want to run unit test then the test database must be manually created and you need to pass in the --keepdb
argument.
If you are getting a VIEW ANY COLUMN MASTER KEY DEFINITION permission denied in database
error run EXEC sp_addrolemember N'db_owner', N'<Name>'
, replacing <Name>
with the name of the VM in system-assigned managed identity or the name of the managed identity in user-assigned managed identity.