Files
n8n-enterprise-unlocked/packages/nodes-base/credentials/MicrosoftEntraOAuth2Api.credentials.ts

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(' ') + '"}}',
},
];
}