feat: Allow custom scopes for Entra credential (#13796)

This commit is contained in:
Jon
2025-03-18 09:12:41 +00:00
committed by GitHub
parent eb91111ddf
commit 7e1036187f

View File

@@ -1,5 +1,19 @@
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 {
name = 'microsoftEntraOAuth2Api';
@@ -10,13 +24,44 @@ export class MicrosoftEntraOAuth2Api implements ICredentialType {
documentationUrl = 'microsoftentra';
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',
name: 'scope',
type: 'hidden',
// Sites.FullControl.All required to update user specific properties https://github.com/microsoftgraph/msgraph-sdk-dotnet/issues/1316
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(' ') + '"}}',
},
];
}