mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-16 17:46:45 +00:00
68 lines
1.7 KiB
TypeScript
68 lines
1.7 KiB
TypeScript
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';
|
|
|
|
displayName = 'Microsoft Entra ID (Azure Active Directory) API';
|
|
|
|
extends = ['microsoftOAuth2Api'];
|
|
|
|
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:
|
|
'={{$self["customScopes"] ? $self["enabledScopes"] : "' + defaultScopes.join(' ') + '"}}',
|
|
},
|
|
];
|
|
}
|