mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-09 20:07:31 -08:00
61e26804ba
* ⚡ enabled array-type * ⚡ await-thenable on * ⚡ ban-types on * ⚡ default-param-last on * ⚡ dot-notation on * ⚡ member-delimiter-style on * ⚡ no-duplicate-imports on * ⚡ no-empty-interface on * ⚡ no-floating-promises on * ⚡ no-for-in-array on * ⚡ no-invalid-void-type on * ⚡ no-loop-func on * ⚡ no-shadow on * ⚡ ban-ts-comment re enabled * ⚡ @typescript-eslint/lines-between-class-members on * address my own comment * @typescript-eslint/return-await on * @typescript-eslint/promise-function-async on * @typescript-eslint/no-unnecessary-boolean-literal-compare on * @typescript-eslint/no-unnecessary-type-assertion on * prefer-const on * @typescript-eslint/prefer-optional-chain on Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in>
58 lines
1.5 KiB
TypeScript
58 lines
1.5 KiB
TypeScript
import {
|
|
ICredentialDataDecryptedObject,
|
|
ICredentialTestRequest,
|
|
ICredentialType,
|
|
IHttpRequestOptions,
|
|
INodeProperties,
|
|
} from 'n8n-workflow';
|
|
|
|
export class CalendlyApi implements ICredentialType {
|
|
name = 'calendlyApi';
|
|
|
|
displayName = 'Calendly API';
|
|
|
|
documentationUrl = 'calendly';
|
|
|
|
properties: INodeProperties[] = [
|
|
// Change name to Personal Access Token once API Keys
|
|
// are deprecated
|
|
{
|
|
displayName: 'API Key or Personal Access Token',
|
|
name: 'apiKey',
|
|
type: 'string',
|
|
typeOptions: { password: true },
|
|
default: '',
|
|
},
|
|
];
|
|
|
|
async authenticate(
|
|
credentials: ICredentialDataDecryptedObject,
|
|
requestOptions: IHttpRequestOptions,
|
|
): Promise<IHttpRequestOptions> {
|
|
//check whether the token is an API Key or an access token
|
|
const { apiKey } = credentials as { apiKey: string };
|
|
const tokenType = getAuthenticationType(apiKey);
|
|
// remove condition once v1 is deprecated
|
|
// and only inject credentials as an access token
|
|
if (tokenType === 'accessToken') {
|
|
requestOptions.headers!.Authorization = `Bearer ${apiKey}`;
|
|
} else {
|
|
requestOptions.headers!['X-TOKEN'] = apiKey;
|
|
}
|
|
return requestOptions;
|
|
}
|
|
|
|
test: ICredentialTestRequest = {
|
|
request: {
|
|
baseURL: 'https://calendly.com',
|
|
url: '/api/v1/users/me',
|
|
},
|
|
};
|
|
}
|
|
|
|
const getAuthenticationType = (data: string): 'accessToken' | 'apiKey' => {
|
|
// The access token is a JWT, so it will always include dots to separate
|
|
// header, payoload and signature.
|
|
return data.includes('.') ? 'accessToken' : 'apiKey';
|
|
};
|