mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 01:56:46 +00:00
feat: Allow custom scopes for Entra credential (#13796)
This commit is contained in:
@@ -1,5 +1,19 @@
|
|||||||
import type { ICredentialType, INodeProperties } from 'n8n-workflow';
|
import type { ICredentialType, INodeProperties } from 'n8n-workflow';
|
||||||
|
|
||||||
|
const defaultScopes = [
|
||||||
|
'openid',
|
||||||
|
'offline_access',
|
||||||
|
'AccessReview.ReadWrite.All',
|
||||||
|
'Directory.ReadWrite.All',
|
||||||
|
'NetworkAccessPolicy.ReadWrite.All',
|
||||||
|
'DelegatedAdminRelationship.ReadWrite.All',
|
||||||
|
'EntitlementManagement.ReadWrite.All',
|
||||||
|
'User.ReadWrite.All',
|
||||||
|
'Directory.AccessAsUser.All',
|
||||||
|
'Sites.FullControl.All',
|
||||||
|
'GroupMember.ReadWrite.All',
|
||||||
|
];
|
||||||
|
|
||||||
export class MicrosoftEntraOAuth2Api implements ICredentialType {
|
export class MicrosoftEntraOAuth2Api implements ICredentialType {
|
||||||
name = 'microsoftEntraOAuth2Api';
|
name = 'microsoftEntraOAuth2Api';
|
||||||
|
|
||||||
@@ -10,13 +24,44 @@ export class MicrosoftEntraOAuth2Api implements ICredentialType {
|
|||||||
documentationUrl = 'microsoftentra';
|
documentationUrl = 'microsoftentra';
|
||||||
|
|
||||||
properties: INodeProperties[] = [
|
properties: INodeProperties[] = [
|
||||||
|
{
|
||||||
|
displayName: 'Custom Scopes',
|
||||||
|
name: 'customScopes',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'Define custom scopes',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName:
|
||||||
|
'The default scopes needed for the node to work are already set, If you change these the node may not function correctly.',
|
||||||
|
name: 'customScopesNotice',
|
||||||
|
type: 'notice',
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
customScopes: [true],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Enabled Scopes',
|
||||||
|
name: 'enabledScopes',
|
||||||
|
type: 'string',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
customScopes: [true],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: defaultScopes.join(' '),
|
||||||
|
description: 'Scopes that should be enabled',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
displayName: 'Scope',
|
displayName: 'Scope',
|
||||||
name: 'scope',
|
name: 'scope',
|
||||||
type: 'hidden',
|
type: 'hidden',
|
||||||
// Sites.FullControl.All required to update user specific properties https://github.com/microsoftgraph/msgraph-sdk-dotnet/issues/1316
|
// Sites.FullControl.All required to update user specific properties https://github.com/microsoftgraph/msgraph-sdk-dotnet/issues/1316
|
||||||
default:
|
default:
|
||||||
'openid offline_access AccessReview.ReadWrite.All Directory.ReadWrite.All NetworkAccessPolicy.ReadWrite.All DelegatedAdminRelationship.ReadWrite.All EntitlementManagement.ReadWrite.All User.ReadWrite.All Directory.AccessAsUser.All Sites.FullControl.All GroupMember.ReadWrite.All',
|
'={{$self["customScopes"] ? $self["enabledScopes"] : "' + defaultScopes.join(' ') + '"}}',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user