Bicep 资源定义
可以使用目标操作部署 containerApps/authConfigs 资源类型:
有关每个 API 版本中已更改属性的列表,请参阅 更改日志。
若要创建 Microsoft.App/containerApps/authConfigs 资源,请将以下 Bicep 添加到模板。
resource symbolicname 'Microsoft.App/containerApps/authConfigs@2022-01-01-preview' = {
parent: resourceSymbolicName
name: 'string'
properties: {
globalValidation: {
excludedPaths: [
'string'
]
redirectToProvider: 'string'
unauthenticatedClientAction: 'string'
}
httpSettings: {
forwardProxy: {
convention: 'string'
customHostHeaderName: 'string'
customProtoHeaderName: 'string'
}
requireHttps: bool
routes: {
apiPrefix: 'string'
}
}
identityProviders: {
apple: {
enabled: bool
login: {
scopes: [
'string'
]
}
registration: {
clientId: 'string'
clientSecretSettingName: 'string'
}
}
azureActiveDirectory: {
enabled: bool
isAutoProvisioned: bool
login: {
disableWWWAuthenticate: bool
loginParameters: [
'string'
]
}
registration: {
clientId: 'string'
clientSecretCertificateIssuer: 'string'
clientSecretCertificateSubjectAlternativeName: 'string'
clientSecretCertificateThumbprint: 'string'
clientSecretSettingName: 'string'
openIdIssuer: 'string'
}
validation: {
allowedAudiences: [
'string'
]
defaultAuthorizationPolicy: {
allowedApplications: [
'string'
]
allowedPrincipals: {
groups: [
'string'
]
identities: [
'string'
]
}
}
jwtClaimChecks: {
allowedClientApplications: [
'string'
]
allowedGroups: [
'string'
]
}
}
}
azureStaticWebApps: {
enabled: bool
registration: {
clientId: 'string'
}
}
customOpenIdConnectProviders: {
{customized property}: {
enabled: bool
login: {
nameClaimType: 'string'
scopes: [
'string'
]
}
registration: {
clientCredential: {
clientSecretSettingName: 'string'
method: 'ClientSecretPost'
}
clientId: 'string'
openIdConnectConfiguration: {
authorizationEndpoint: 'string'
certificationUri: 'string'
issuer: 'string'
tokenEndpoint: 'string'
wellKnownOpenIdConfiguration: 'string'
}
}
}
}
facebook: {
enabled: bool
graphApiVersion: 'string'
login: {
scopes: [
'string'
]
}
registration: {
appId: 'string'
appSecretSettingName: 'string'
}
}
gitHub: {
enabled: bool
login: {
scopes: [
'string'
]
}
registration: {
clientId: 'string'
clientSecretSettingName: 'string'
}
}
google: {
enabled: bool
login: {
scopes: [
'string'
]
}
registration: {
clientId: 'string'
clientSecretSettingName: 'string'
}
validation: {
allowedAudiences: [
'string'
]
}
}
twitter: {
enabled: bool
registration: {
consumerKey: 'string'
consumerSecretSettingName: 'string'
}
}
}
login: {
allowedExternalRedirectUrls: [
'string'
]
cookieExpiration: {
convention: 'string'
timeToExpiration: 'string'
}
nonce: {
nonceExpirationInterval: 'string'
validateNonce: bool
}
preserveUrlFragmentsForLogins: bool
routes: {
logoutEndpoint: 'string'
}
}
platform: {
enabled: bool
runtimeVersion: 'string'
}
}
}
属性值
AllowedAudiencesValidation
名字 |
描述 |
价值 |
allowedAudiences |
要从中验证 JWT 令牌的允许访问群体列表的配置设置。 |
string[] |
AllowedPrincipals
名字 |
描述 |
价值 |
组 |
允许的组的列表。 |
string[] |
身份 |
允许的标识的列表。 |
string[] |
苹果
名字 |
描述 |
价值 |
启用 |
<代码>false</code> 如果不应启用 Apple 提供程序,尽管设置了注册;否则,<代码>true</code>。 |
bool |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
Apple 注册的配置设置。 |
AppleRegistration |
AppleRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
clientSecretSettingName |
包含客户端密码的应用设置名称。 |
字符串 |
AppRegistration
名字 |
描述 |
价值 |
appId |
用于登录的应用的应用 ID。 |
字符串 |
appSecretSettingName |
包含应用机密的应用设置名称。 |
字符串 |
AuthConfigProperties
名字 |
描述 |
价值 |
globalValidation |
使用服务身份验证/授权确定用户的验证流的配置设置。 |
GlobalValidation |
httpSettings |
针对 ContainerApp 服务身份验证/授权发出的身份验证和授权请求的 HTTP 请求的配置设置。 |
HttpSettings |
identityProviders |
用于配置 ContainerApp 服务身份验证/授权的每个标识提供者的配置设置。 |
IdentityProviders |
登录 |
使用 ContainerApp 服务身份验证/授权的用户登录流的配置设置。 |
登录名 |
平台 |
ContainerApp 服务身份验证/授权平台的配置设置。 |
AuthPlatform |
名字 |
描述 |
价值 |
启用 |
如果为当前应用启用了身份验证/授权功能,<代码>true</code>;否则,<代码>false</code>。 |
bool |
runtimeVersion |
用于当前应用的身份验证/授权功能的 RuntimeVersion。 此值中的设置可以控制身份验证/授权模块中某些功能的行为。 |
字符串 |
AzureActiveDirectory
AzureActiveDirectoryLogin
名字 |
描述 |
价值 |
disableWWWAuthenticate |
如果应从请求中省略 www-authenticate 提供程序,<代码>true</code>;否则,<代码>false</code>。 |
bool |
loginParameters |
在以下情况下发送到 OpenID Connect 授权终结点的登录参数 用户登录。 每个参数必须采用“key=value”格式。 |
string[] |
AzureActiveDirectoryRegistration
AzureActiveDirectoryValidation
AzureStaticWebApps
AzureStaticWebAppsRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
ClientRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
clientSecretSettingName |
包含客户端密码的应用设置名称。 |
字符串 |
CookieExpiration
名字 |
描述 |
价值 |
公约 |
确定会话 Cookie 过期时使用的约定。 |
“FixedTime” “IdentityProviderDerived” |
timeToExpiration |
发出请求后的时间,会话 Cookie 应过期。 |
字符串 |
CustomOpenIdConnectProvider
DefaultAuthorizationPolicy
名字 |
描述 |
价值 |
allowedApplications |
Azure Active Directory 允许的应用程序的配置设置。 |
string[] |
allowedPrincipals |
Azure Active Directory 允许的主体的配置设置。 |
AllowedPrincipals |
Facebook
名字 |
描述 |
价值 |
启用 |
<代码>false</code>,尽管设置了注册,但不应启用 Facebook 提供程序;否则,<代码>true</code>。 |
bool |
graphApiVersion |
登录时要使用的 Facebook API 版本。 |
字符串 |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
Facebook 提供程序的应用注册的配置设置。 |
AppRegistration |
ForwardProxy
名字 |
描述 |
价值 |
公约 |
用于确定所发出请求的 URL 的约定。 |
“Custom” “NoProxy” “Standard” |
customHostHeaderName |
包含请求主机的标头的名称。 |
字符串 |
customProtoHeaderName |
包含请求方案的标头的名称。 |
字符串 |
GitHub
名字 |
描述 |
价值 |
启用 |
<代码>false</code>,即使设置了注册,也不应启用 GitHub 提供程序;否则,<代码>true</code>。 |
bool |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
GitHub 提供程序的应用注册的配置设置。 |
ClientRegistration |
GlobalValidation
名字 |
描述 |
价值 |
excludedPaths |
未经身份验证的流不会重定向到登录页的路径。 |
string[] |
redirectToProvider |
配置多个提供程序时要使用的默认身份验证提供程序。 仅当配置了多个提供程序和未经身份验证的客户端时,才需要此设置 操作设置为“RedirectToLoginPage”。 |
字符串 |
unauthenticatedClientAction |
未经身份验证的客户端尝试访问应用时要执行的操作。 |
“AllowAnonymous” “RedirectToLoginPage” “Return401” “Return403” |
谷歌
HttpSettings
名字 |
描述 |
价值 |
forwardProxy |
用于发出请求的转发代理的配置设置。 |
ForwardProxy |
requireHttps |
如果允许身份验证/授权响应没有 HTTPS 方案,<代码>false</code>;否则,<代码>true</code>。 |
bool |
路线 |
路径 HTTP 请求的配置设置。 |
HttpSettingsRoutes |
HttpSettingsRoutes
名字 |
描述 |
价值 |
apiPrefix |
所有身份验证/授权路径前面的前缀。 |
字符串 |
IdentityProviders
IdentityProvidersCustomOpenIdConnectProviders
JwtClaimChecks
名字 |
描述 |
价值 |
allowedClientApplications |
允许的客户端应用程序列表。 |
string[] |
allowedGroups |
允许的组的列表。 |
string[] |
登录
名字 |
描述 |
价值 |
allowedExternalRedirectUrls |
作为登录或注销应用的一部分,可重定向到的外部 URL。 请注意,将忽略 URL 的查询字符串部分。 这是 Windows 应用商店应用程序后端通常需要的高级设置。 请注意,始终允许当前域中的 URL。 |
string[] |
cookieExpiration |
会话 Cookie 过期的配置设置。 |
CookieExpiration |
nonce |
登录流中使用的 nonce 的配置设置。 |
Nonce |
preserveUrlFragmentsForLogins |
如果发出登录请求后保留来自请求的片段,则 <代码>true</code>;否则,<代码>false</code>。 |
bool |
路线 |
指定用于登录和注销请求的终结点的路由。 |
LoginRoutes |
LoginRoutes
名字 |
描述 |
价值 |
logoutEndpoint |
应在其中发出注销请求的终结点。 |
字符串 |
LoginScopes
名字 |
描述 |
价值 |
范围 |
身份验证时应请求的范围列表。 |
string[] |
Microsoft.App/containerApps/authConfigs
Nonce
名字 |
描述 |
价值 |
nonceExpirationInterval |
发出请求后,nonce 应过期的时间。 |
字符串 |
validateNonce |
如果完成登录流时不应验证 nonce,则 <代码>false</code>;否则,<代码>true</code>。 |
bool |
OpenIdConnectClientCredential
名字 |
描述 |
价值 |
clientSecretSettingName |
包含自定义 Open ID Connect 提供程序的客户端密码的应用设置。 |
字符串 |
方法 |
应用于对用户进行身份验证的方法。 |
“ClientSecretPost” |
OpenIdConnectConfig
名字 |
描述 |
价值 |
authorizationEndpoint |
用于发出授权请求的终结点。 |
字符串 |
certificationUri |
提供验证令牌所需的密钥的终结点。 |
字符串 |
发行 |
颁发令牌的终结点。 |
字符串 |
tokenEndpoint |
用于请求令牌的终结点。 |
字符串 |
wellKnownOpenIdConfiguration |
包含提供程序的所有配置终结点的终结点。 |
字符串 |
OpenIdConnectLogin
名字 |
描述 |
价值 |
nameClaimType |
包含用户名称的声明的名称。 |
字符串 |
范围 |
身份验证时应请求的范围列表。 |
string[] |
OpenIdConnectRegistration
名字 |
描述 |
价值 |
启用 |
如果尽管设置了注册,但不应启用 Twitter 提供程序,<代码>false</code>;否则,<代码>true</code>。 |
bool |
注册 |
Twitter 提供程序的应用注册的配置设置。 |
TwitterRegistration |
名字 |
描述 |
价值 |
consumerKey |
用于登录的 Twitter 应用程序的 OAuth 1.0a 使用者密钥。 启用 Twitter 登录需要此设置。 Twitter Sign-In 文档:https://dev.twitter.com/web/sign-in |
字符串 |
consumerSecretSettingName |
包含 Twitter 的 OAuth 1.0a 使用者机密的应用设置名称 用于登录的应用程序。 |
字符串 |
ARM 模板资源定义
可以使用目标操作部署 containerApps/authConfigs 资源类型:
有关每个 API 版本中已更改属性的列表,请参阅 更改日志。
若要创建 Microsoft.App/containerApps/authConfigs 资源,请将以下 JSON 添加到模板。
{
"type": "Microsoft.App/containerApps/authConfigs",
"apiVersion": "2022-01-01-preview",
"name": "string",
"properties": {
"globalValidation": {
"excludedPaths": [ "string" ],
"redirectToProvider": "string",
"unauthenticatedClientAction": "string"
},
"httpSettings": {
"forwardProxy": {
"convention": "string",
"customHostHeaderName": "string",
"customProtoHeaderName": "string"
},
"requireHttps": "bool",
"routes": {
"apiPrefix": "string"
}
},
"identityProviders": {
"apple": {
"enabled": "bool",
"login": {
"scopes": [ "string" ]
},
"registration": {
"clientId": "string",
"clientSecretSettingName": "string"
}
},
"azureActiveDirectory": {
"enabled": "bool",
"isAutoProvisioned": "bool",
"login": {
"disableWWWAuthenticate": "bool",
"loginParameters": [ "string" ]
},
"registration": {
"clientId": "string",
"clientSecretCertificateIssuer": "string",
"clientSecretCertificateSubjectAlternativeName": "string",
"clientSecretCertificateThumbprint": "string",
"clientSecretSettingName": "string",
"openIdIssuer": "string"
},
"validation": {
"allowedAudiences": [ "string" ],
"defaultAuthorizationPolicy": {
"allowedApplications": [ "string" ],
"allowedPrincipals": {
"groups": [ "string" ],
"identities": [ "string" ]
}
},
"jwtClaimChecks": {
"allowedClientApplications": [ "string" ],
"allowedGroups": [ "string" ]
}
}
},
"azureStaticWebApps": {
"enabled": "bool",
"registration": {
"clientId": "string"
}
},
"customOpenIdConnectProviders": {
"{customized property}": {
"enabled": "bool",
"login": {
"nameClaimType": "string",
"scopes": [ "string" ]
},
"registration": {
"clientCredential": {
"clientSecretSettingName": "string",
"method": "ClientSecretPost"
},
"clientId": "string",
"openIdConnectConfiguration": {
"authorizationEndpoint": "string",
"certificationUri": "string",
"issuer": "string",
"tokenEndpoint": "string",
"wellKnownOpenIdConfiguration": "string"
}
}
}
},
"facebook": {
"enabled": "bool",
"graphApiVersion": "string",
"login": {
"scopes": [ "string" ]
},
"registration": {
"appId": "string",
"appSecretSettingName": "string"
}
},
"gitHub": {
"enabled": "bool",
"login": {
"scopes": [ "string" ]
},
"registration": {
"clientId": "string",
"clientSecretSettingName": "string"
}
},
"google": {
"enabled": "bool",
"login": {
"scopes": [ "string" ]
},
"registration": {
"clientId": "string",
"clientSecretSettingName": "string"
},
"validation": {
"allowedAudiences": [ "string" ]
}
},
"twitter": {
"enabled": "bool",
"registration": {
"consumerKey": "string",
"consumerSecretSettingName": "string"
}
}
},
"login": {
"allowedExternalRedirectUrls": [ "string" ],
"cookieExpiration": {
"convention": "string",
"timeToExpiration": "string"
},
"nonce": {
"nonceExpirationInterval": "string",
"validateNonce": "bool"
},
"preserveUrlFragmentsForLogins": "bool",
"routes": {
"logoutEndpoint": "string"
}
},
"platform": {
"enabled": "bool",
"runtimeVersion": "string"
}
}
}
属性值
AllowedAudiencesValidation
名字 |
描述 |
价值 |
allowedAudiences |
要从中验证 JWT 令牌的允许访问群体列表的配置设置。 |
string[] |
AllowedPrincipals
名字 |
描述 |
价值 |
组 |
允许的组的列表。 |
string[] |
身份 |
允许的标识的列表。 |
string[] |
苹果
名字 |
描述 |
价值 |
启用 |
<代码>false</code> 如果不应启用 Apple 提供程序,尽管设置了注册;否则,<代码>true</code>。 |
bool |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
Apple 注册的配置设置。 |
AppleRegistration |
AppleRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
clientSecretSettingName |
包含客户端密码的应用设置名称。 |
字符串 |
AppRegistration
名字 |
描述 |
价值 |
appId |
用于登录的应用的应用 ID。 |
字符串 |
appSecretSettingName |
包含应用机密的应用设置名称。 |
字符串 |
AuthConfigProperties
名字 |
描述 |
价值 |
globalValidation |
使用服务身份验证/授权确定用户的验证流的配置设置。 |
GlobalValidation |
httpSettings |
针对 ContainerApp 服务身份验证/授权发出的身份验证和授权请求的 HTTP 请求的配置设置。 |
HttpSettings |
identityProviders |
用于配置 ContainerApp 服务身份验证/授权的每个标识提供者的配置设置。 |
IdentityProviders |
登录 |
使用 ContainerApp 服务身份验证/授权的用户登录流的配置设置。 |
登录名 |
平台 |
ContainerApp 服务身份验证/授权平台的配置设置。 |
AuthPlatform |
名字 |
描述 |
价值 |
启用 |
如果为当前应用启用了身份验证/授权功能,<代码>true</code>;否则,<代码>false</code>。 |
bool |
runtimeVersion |
用于当前应用的身份验证/授权功能的 RuntimeVersion。 此值中的设置可以控制身份验证/授权模块中某些功能的行为。 |
字符串 |
AzureActiveDirectory
AzureActiveDirectoryLogin
名字 |
描述 |
价值 |
disableWWWAuthenticate |
如果应从请求中省略 www-authenticate 提供程序,<代码>true</code>;否则,<代码>false</code>。 |
bool |
loginParameters |
在以下情况下发送到 OpenID Connect 授权终结点的登录参数 用户登录。 每个参数必须采用“key=value”格式。 |
string[] |
AzureActiveDirectoryRegistration
AzureActiveDirectoryValidation
AzureStaticWebApps
AzureStaticWebAppsRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
ClientRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
clientSecretSettingName |
包含客户端密码的应用设置名称。 |
字符串 |
CookieExpiration
名字 |
描述 |
价值 |
公约 |
确定会话 Cookie 过期时使用的约定。 |
“FixedTime” “IdentityProviderDerived” |
timeToExpiration |
发出请求后的时间,会话 Cookie 应过期。 |
字符串 |
CustomOpenIdConnectProvider
DefaultAuthorizationPolicy
名字 |
描述 |
价值 |
allowedApplications |
Azure Active Directory 允许的应用程序的配置设置。 |
string[] |
allowedPrincipals |
Azure Active Directory 允许的主体的配置设置。 |
AllowedPrincipals |
Facebook
名字 |
描述 |
价值 |
启用 |
<代码>false</code>,尽管设置了注册,但不应启用 Facebook 提供程序;否则,<代码>true</code>。 |
bool |
graphApiVersion |
登录时要使用的 Facebook API 版本。 |
字符串 |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
Facebook 提供程序的应用注册的配置设置。 |
AppRegistration |
ForwardProxy
名字 |
描述 |
价值 |
公约 |
用于确定所发出请求的 URL 的约定。 |
“Custom” “NoProxy” “Standard” |
customHostHeaderName |
包含请求主机的标头的名称。 |
字符串 |
customProtoHeaderName |
包含请求方案的标头的名称。 |
字符串 |
GitHub
名字 |
描述 |
价值 |
启用 |
<代码>false</code>,即使设置了注册,也不应启用 GitHub 提供程序;否则,<代码>true</code>。 |
bool |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
GitHub 提供程序的应用注册的配置设置。 |
ClientRegistration |
GlobalValidation
名字 |
描述 |
价值 |
excludedPaths |
未经身份验证的流不会重定向到登录页的路径。 |
string[] |
redirectToProvider |
配置多个提供程序时要使用的默认身份验证提供程序。 仅当配置了多个提供程序和未经身份验证的客户端时,才需要此设置 操作设置为“RedirectToLoginPage”。 |
字符串 |
unauthenticatedClientAction |
未经身份验证的客户端尝试访问应用时要执行的操作。 |
“AllowAnonymous” “RedirectToLoginPage” “Return401” “Return403” |
谷歌
HttpSettings
名字 |
描述 |
价值 |
forwardProxy |
用于发出请求的转发代理的配置设置。 |
ForwardProxy |
requireHttps |
如果允许身份验证/授权响应没有 HTTPS 方案,<代码>false</code>;否则,<代码>true</code>。 |
bool |
路线 |
路径 HTTP 请求的配置设置。 |
HttpSettingsRoutes |
HttpSettingsRoutes
名字 |
描述 |
价值 |
apiPrefix |
所有身份验证/授权路径前面的前缀。 |
字符串 |
IdentityProviders
IdentityProvidersCustomOpenIdConnectProviders
JwtClaimChecks
名字 |
描述 |
价值 |
allowedClientApplications |
允许的客户端应用程序列表。 |
string[] |
allowedGroups |
允许的组的列表。 |
string[] |
登录
名字 |
描述 |
价值 |
allowedExternalRedirectUrls |
作为登录或注销应用的一部分,可重定向到的外部 URL。 请注意,将忽略 URL 的查询字符串部分。 这是 Windows 应用商店应用程序后端通常需要的高级设置。 请注意,始终允许当前域中的 URL。 |
string[] |
cookieExpiration |
会话 Cookie 过期的配置设置。 |
CookieExpiration |
nonce |
登录流中使用的 nonce 的配置设置。 |
Nonce |
preserveUrlFragmentsForLogins |
如果发出登录请求后保留来自请求的片段,则 <代码>true</code>;否则,<代码>false</code>。 |
bool |
路线 |
指定用于登录和注销请求的终结点的路由。 |
LoginRoutes |
LoginRoutes
名字 |
描述 |
价值 |
logoutEndpoint |
应在其中发出注销请求的终结点。 |
字符串 |
LoginScopes
名字 |
描述 |
价值 |
范围 |
身份验证时应请求的范围列表。 |
string[] |
Microsoft.App/containerApps/authConfigs
名字 |
描述 |
价值 |
apiVersion |
API 版本 |
'2022-01-01-preview' |
名字 |
资源名称 |
string (必需) |
性能 |
特定于 AuthConfig 资源的属性 |
AuthConfigProperties |
类型 |
资源类型 |
“Microsoft.App/containerApps/authConfigs” |
Nonce
名字 |
描述 |
价值 |
nonceExpirationInterval |
发出请求后,nonce 应过期的时间。 |
字符串 |
validateNonce |
如果完成登录流时不应验证 nonce,则 <代码>false</code>;否则,<代码>true</code>。 |
bool |
OpenIdConnectClientCredential
名字 |
描述 |
价值 |
clientSecretSettingName |
包含自定义 Open ID Connect 提供程序的客户端密码的应用设置。 |
字符串 |
方法 |
应用于对用户进行身份验证的方法。 |
“ClientSecretPost” |
OpenIdConnectConfig
名字 |
描述 |
价值 |
authorizationEndpoint |
用于发出授权请求的终结点。 |
字符串 |
certificationUri |
提供验证令牌所需的密钥的终结点。 |
字符串 |
发行 |
颁发令牌的终结点。 |
字符串 |
tokenEndpoint |
用于请求令牌的终结点。 |
字符串 |
wellKnownOpenIdConfiguration |
包含提供程序的所有配置终结点的终结点。 |
字符串 |
OpenIdConnectLogin
名字 |
描述 |
价值 |
nameClaimType |
包含用户名称的声明的名称。 |
字符串 |
范围 |
身份验证时应请求的范围列表。 |
string[] |
OpenIdConnectRegistration
名字 |
描述 |
价值 |
启用 |
如果尽管设置了注册,但不应启用 Twitter 提供程序,<代码>false</code>;否则,<代码>true</code>。 |
bool |
注册 |
Twitter 提供程序的应用注册的配置设置。 |
TwitterRegistration |
名字 |
描述 |
价值 |
consumerKey |
用于登录的 Twitter 应用程序的 OAuth 1.0a 使用者密钥。 启用 Twitter 登录需要此设置。 Twitter Sign-In 文档:https://dev.twitter.com/web/sign-in |
字符串 |
consumerSecretSettingName |
包含 Twitter 的 OAuth 1.0a 使用者机密的应用设置名称 用于登录的应用程序。 |
字符串 |
可以使用目标操作部署 containerApps/authConfigs 资源类型:
有关每个 API 版本中已更改属性的列表,请参阅 更改日志。
若要创建 Microsoft.App/containerApps/authConfigs 资源,请将以下 Terraform 添加到模板。
resource "azapi_resource" "symbolicname" {
type = "Microsoft.App/containerApps/authConfigs@2022-01-01-preview"
name = "string"
body = jsonencode({
properties = {
globalValidation = {
excludedPaths = [
"string"
]
redirectToProvider = "string"
unauthenticatedClientAction = "string"
}
httpSettings = {
forwardProxy = {
convention = "string"
customHostHeaderName = "string"
customProtoHeaderName = "string"
}
requireHttps = bool
routes = {
apiPrefix = "string"
}
}
identityProviders = {
apple = {
enabled = bool
login = {
scopes = [
"string"
]
}
registration = {
clientId = "string"
clientSecretSettingName = "string"
}
}
azureActiveDirectory = {
enabled = bool
isAutoProvisioned = bool
login = {
disableWWWAuthenticate = bool
loginParameters = [
"string"
]
}
registration = {
clientId = "string"
clientSecretCertificateIssuer = "string"
clientSecretCertificateSubjectAlternativeName = "string"
clientSecretCertificateThumbprint = "string"
clientSecretSettingName = "string"
openIdIssuer = "string"
}
validation = {
allowedAudiences = [
"string"
]
defaultAuthorizationPolicy = {
allowedApplications = [
"string"
]
allowedPrincipals = {
groups = [
"string"
]
identities = [
"string"
]
}
}
jwtClaimChecks = {
allowedClientApplications = [
"string"
]
allowedGroups = [
"string"
]
}
}
}
azureStaticWebApps = {
enabled = bool
registration = {
clientId = "string"
}
}
customOpenIdConnectProviders = {
{customized property} = {
enabled = bool
login = {
nameClaimType = "string"
scopes = [
"string"
]
}
registration = {
clientCredential = {
clientSecretSettingName = "string"
method = "ClientSecretPost"
}
clientId = "string"
openIdConnectConfiguration = {
authorizationEndpoint = "string"
certificationUri = "string"
issuer = "string"
tokenEndpoint = "string"
wellKnownOpenIdConfiguration = "string"
}
}
}
}
facebook = {
enabled = bool
graphApiVersion = "string"
login = {
scopes = [
"string"
]
}
registration = {
appId = "string"
appSecretSettingName = "string"
}
}
gitHub = {
enabled = bool
login = {
scopes = [
"string"
]
}
registration = {
clientId = "string"
clientSecretSettingName = "string"
}
}
google = {
enabled = bool
login = {
scopes = [
"string"
]
}
registration = {
clientId = "string"
clientSecretSettingName = "string"
}
validation = {
allowedAudiences = [
"string"
]
}
}
twitter = {
enabled = bool
registration = {
consumerKey = "string"
consumerSecretSettingName = "string"
}
}
}
login = {
allowedExternalRedirectUrls = [
"string"
]
cookieExpiration = {
convention = "string"
timeToExpiration = "string"
}
nonce = {
nonceExpirationInterval = "string"
validateNonce = bool
}
preserveUrlFragmentsForLogins = bool
routes = {
logoutEndpoint = "string"
}
}
platform = {
enabled = bool
runtimeVersion = "string"
}
}
})
}
属性值
AllowedAudiencesValidation
名字 |
描述 |
价值 |
allowedAudiences |
要从中验证 JWT 令牌的允许访问群体列表的配置设置。 |
string[] |
AllowedPrincipals
名字 |
描述 |
价值 |
组 |
允许的组的列表。 |
string[] |
身份 |
允许的标识的列表。 |
string[] |
苹果
名字 |
描述 |
价值 |
启用 |
<代码>false</code> 如果不应启用 Apple 提供程序,尽管设置了注册;否则,<代码>true</code>。 |
bool |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
Apple 注册的配置设置。 |
AppleRegistration |
AppleRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
clientSecretSettingName |
包含客户端密码的应用设置名称。 |
字符串 |
AppRegistration
名字 |
描述 |
价值 |
appId |
用于登录的应用的应用 ID。 |
字符串 |
appSecretSettingName |
包含应用机密的应用设置名称。 |
字符串 |
AuthConfigProperties
名字 |
描述 |
价值 |
globalValidation |
使用服务身份验证/授权确定用户的验证流的配置设置。 |
GlobalValidation |
httpSettings |
针对 ContainerApp 服务身份验证/授权发出的身份验证和授权请求的 HTTP 请求的配置设置。 |
HttpSettings |
identityProviders |
用于配置 ContainerApp 服务身份验证/授权的每个标识提供者的配置设置。 |
IdentityProviders |
登录 |
使用 ContainerApp 服务身份验证/授权的用户登录流的配置设置。 |
登录名 |
平台 |
ContainerApp 服务身份验证/授权平台的配置设置。 |
AuthPlatform |
名字 |
描述 |
价值 |
启用 |
如果为当前应用启用了身份验证/授权功能,<代码>true</code>;否则,<代码>false</code>。 |
bool |
runtimeVersion |
用于当前应用的身份验证/授权功能的 RuntimeVersion。 此值中的设置可以控制身份验证/授权模块中某些功能的行为。 |
字符串 |
AzureActiveDirectory
AzureActiveDirectoryLogin
名字 |
描述 |
价值 |
disableWWWAuthenticate |
如果应从请求中省略 www-authenticate 提供程序,<代码>true</code>;否则,<代码>false</code>。 |
bool |
loginParameters |
在以下情况下发送到 OpenID Connect 授权终结点的登录参数 用户登录。 每个参数必须采用“key=value”格式。 |
string[] |
AzureActiveDirectoryRegistration
AzureActiveDirectoryValidation
AzureStaticWebApps
AzureStaticWebAppsRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
ClientRegistration
名字 |
描述 |
价值 |
clientId |
用于登录的应用的客户端 ID。 |
字符串 |
clientSecretSettingName |
包含客户端密码的应用设置名称。 |
字符串 |
CookieExpiration
名字 |
描述 |
价值 |
公约 |
确定会话 Cookie 过期时使用的约定。 |
“FixedTime” “IdentityProviderDerived” |
timeToExpiration |
发出请求后的时间,会话 Cookie 应过期。 |
字符串 |
CustomOpenIdConnectProvider
DefaultAuthorizationPolicy
名字 |
描述 |
价值 |
allowedApplications |
Azure Active Directory 允许的应用程序的配置设置。 |
string[] |
allowedPrincipals |
Azure Active Directory 允许的主体的配置设置。 |
AllowedPrincipals |
Facebook
名字 |
描述 |
价值 |
启用 |
<代码>false</code>,尽管设置了注册,但不应启用 Facebook 提供程序;否则,<代码>true</code>。 |
bool |
graphApiVersion |
登录时要使用的 Facebook API 版本。 |
字符串 |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
Facebook 提供程序的应用注册的配置设置。 |
AppRegistration |
ForwardProxy
名字 |
描述 |
价值 |
公约 |
用于确定所发出请求的 URL 的约定。 |
“Custom” “NoProxy” “Standard” |
customHostHeaderName |
包含请求主机的标头的名称。 |
字符串 |
customProtoHeaderName |
包含请求方案的标头的名称。 |
字符串 |
GitHub
名字 |
描述 |
价值 |
启用 |
<代码>false</code>,即使设置了注册,也不应启用 GitHub 提供程序;否则,<代码>true</code>。 |
bool |
登录 |
登录流的配置设置。 |
LoginScopes |
注册 |
GitHub 提供程序的应用注册的配置设置。 |
ClientRegistration |
GlobalValidation
名字 |
描述 |
价值 |
excludedPaths |
未经身份验证的流不会重定向到登录页的路径。 |
string[] |
redirectToProvider |
配置多个提供程序时要使用的默认身份验证提供程序。 仅当配置了多个提供程序和未经身份验证的客户端时,才需要此设置 操作设置为“RedirectToLoginPage”。 |
字符串 |
unauthenticatedClientAction |
未经身份验证的客户端尝试访问应用时要执行的操作。 |
“AllowAnonymous” “RedirectToLoginPage” “Return401” “Return403” |
谷歌
HttpSettings
名字 |
描述 |
价值 |
forwardProxy |
用于发出请求的转发代理的配置设置。 |
ForwardProxy |
requireHttps |
如果允许身份验证/授权响应没有 HTTPS 方案,<代码>false</code>;否则,<代码>true</code>。 |
bool |
路线 |
路径 HTTP 请求的配置设置。 |
HttpSettingsRoutes |
HttpSettingsRoutes
名字 |
描述 |
价值 |
apiPrefix |
所有身份验证/授权路径前面的前缀。 |
字符串 |
IdentityProviders
IdentityProvidersCustomOpenIdConnectProviders
JwtClaimChecks
名字 |
描述 |
价值 |
allowedClientApplications |
允许的客户端应用程序列表。 |
string[] |
allowedGroups |
允许的组的列表。 |
string[] |
登录
名字 |
描述 |
价值 |
allowedExternalRedirectUrls |
作为登录或注销应用的一部分,可重定向到的外部 URL。 请注意,将忽略 URL 的查询字符串部分。 这是 Windows 应用商店应用程序后端通常需要的高级设置。 请注意,始终允许当前域中的 URL。 |
string[] |
cookieExpiration |
会话 Cookie 过期的配置设置。 |
CookieExpiration |
nonce |
登录流中使用的 nonce 的配置设置。 |
Nonce |
preserveUrlFragmentsForLogins |
如果发出登录请求后保留来自请求的片段,则 <代码>true</code>;否则,<代码>false</code>。 |
bool |
路线 |
指定用于登录和注销请求的终结点的路由。 |
LoginRoutes |
LoginRoutes
名字 |
描述 |
价值 |
logoutEndpoint |
应在其中发出注销请求的终结点。 |
字符串 |
LoginScopes
名字 |
描述 |
价值 |
范围 |
身份验证时应请求的范围列表。 |
string[] |
Microsoft.App/containerApps/authConfigs
名字 |
描述 |
价值 |
名字 |
资源名称 |
string (必需) |
parent_id |
此资源的父资源的 ID。 |
类型资源的 ID:containerApps |
性能 |
特定于 AuthConfig 资源的属性 |
AuthConfigProperties |
类型 |
资源类型 |
“Microsoft.App/containerApps/authConfigs@2022-01-01-preview” |
Nonce
名字 |
描述 |
价值 |
nonceExpirationInterval |
发出请求后,nonce 应过期的时间。 |
字符串 |
validateNonce |
如果完成登录流时不应验证 nonce,则 <代码>false</code>;否则,<代码>true</code>。 |
bool |
OpenIdConnectClientCredential
名字 |
描述 |
价值 |
clientSecretSettingName |
包含自定义 Open ID Connect 提供程序的客户端密码的应用设置。 |
字符串 |
方法 |
应用于对用户进行身份验证的方法。 |
“ClientSecretPost” |
OpenIdConnectConfig
名字 |
描述 |
价值 |
authorizationEndpoint |
用于发出授权请求的终结点。 |
字符串 |
certificationUri |
提供验证令牌所需的密钥的终结点。 |
字符串 |
发行 |
颁发令牌的终结点。 |
字符串 |
tokenEndpoint |
用于请求令牌的终结点。 |
字符串 |
wellKnownOpenIdConfiguration |
包含提供程序的所有配置终结点的终结点。 |
字符串 |
OpenIdConnectLogin
名字 |
描述 |
价值 |
nameClaimType |
包含用户名称的声明的名称。 |
字符串 |
范围 |
身份验证时应请求的范围列表。 |
string[] |
OpenIdConnectRegistration
名字 |
描述 |
价值 |
启用 |
如果尽管设置了注册,但不应启用 Twitter 提供程序,<代码>false</code>;否则,<代码>true</code>。 |
bool |
注册 |
Twitter 提供程序的应用注册的配置设置。 |
TwitterRegistration |
名字 |
描述 |
价值 |
consumerKey |
用于登录的 Twitter 应用程序的 OAuth 1.0a 使用者密钥。 启用 Twitter 登录需要此设置。 Twitter Sign-In 文档:https://dev.twitter.com/web/sign-in |
字符串 |
consumerSecretSettingName |
包含 Twitter 的 OAuth 1.0a 使用者机密的应用设置名称 用于登录的应用程序。 |
字符串 |