OAuth2: generic functions, credentials, UI

This commit is contained in:
Rupenieks 2020-06-10 11:49:48 +02:00
parent 516a56ea32
commit c52765b21a
4 changed files with 114 additions and 8 deletions

View file

@ -0,0 +1,60 @@
import {
ICredentialType,
NodePropertyTypes,
} from 'n8n-workflow';
export class ClearbitOAuth2Api implements ICredentialType {
name = 'clearbitOAuth2Api';
extends = [
'oAuth2Api',
];
displayName = 'Clearbit OAuth2 API';
properties = [
{
displayName: 'Authorization URL',
name: 'authUrl',
type: 'hidden' as NodePropertyTypes,
default: 'https://clearbit.com/oauth/authorize',
required: true,
},
{
displayName: 'Access Token URL',
name: 'accessTokenUrl',
type: 'hidden' as NodePropertyTypes,
default: 'https://clearbit.com/oauth/access_token',
required: true,
},
{
displayName: 'Scope',
name: 'scope',
type: 'hidden' as NodePropertyTypes,
default: '',
},
{
displayName: 'Auth URI Query Parameters',
name: 'authQueryParameters',
type: 'hidden' as NodePropertyTypes,
default: '',
},
{
displayName: 'Authentication',
name: 'authentication',
type: 'options' as NodePropertyTypes,
options: [
{
name: 'Body',
value: 'body',
description: 'Send credentials in body',
},
{
name: 'Header',
value: 'header',
description: 'Send credentials as Basic Auth header',
},
],
default: 'header',
description: 'Resource to consume.',
},
];
}

View file

@ -38,9 +38,44 @@ export class Clearbit implements INodeType {
{ {
name: 'clearbitApi', name: 'clearbitApi',
required: true, required: true,
} displayOptions: {
show: {
authentication: [
'accessToken',
],
},
},
},
{
name: 'clearbitOAuth2Api',
required: true,
displayOptions: {
show: {
authentication: [
'oAuth2',
],
},
},
},
], ],
properties: [ properties: [
{
displayName: 'Authentication',
name: 'authentication',
type: 'options',
options: [
{
name: 'Access Token',
value: 'accessToken',
},
{
name: 'OAuth2',
value: 'oAuth2',
},
],
default: 'accessToken',
description: 'The resource to operate on.',
},
{ {
displayName: 'Resource', displayName: 'Resource',
name: 'resource', name: 'resource',

View file

@ -8,12 +8,10 @@ import {
import { IDataObject } from 'n8n-workflow'; import { IDataObject } from 'n8n-workflow';
export async function clearbitApiRequest(this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions, method: string, api: string, resource: string, body: any = {}, qs: IDataObject = {}, uri?: string, option: IDataObject = {}): Promise<any> { // tslint:disable-line:no-any export async function clearbitApiRequest(this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions, method: string, api: string, resource: string, body: any = {}, qs: IDataObject = {}, uri?: string, option: IDataObject = {}): Promise<any> { // tslint:disable-line:no-any
const credentials = this.getCredentials('clearbitApi'); const authenticationMethod = this.getNodeParameter('authentication', 0);
if (credentials === undefined) {
throw new Error('No credentials got returned!');
}
let options: OptionsWithUri = { let options: OptionsWithUri = {
headers: { Authorization: `Bearer ${credentials.apiKey}`}, headers: {},
method, method,
qs, qs,
body, body,
@ -24,9 +22,21 @@ export async function clearbitApiRequest(this: IHookFunctions | IExecuteFunction
if (Object.keys(options.body).length === 0) { if (Object.keys(options.body).length === 0) {
delete options.body; delete options.body;
} }
try { try {
return await this.helpers.request!(options); if (authenticationMethod === 'accessToken') {
} catch (error) { const credentials = this.getCredentials('clearbitApi');
if (credentials === undefined) {
throw new Error('No credentials got returned!');
}
//@ts-ignore
options.headers['Authorization'] = `Bearer ${credentials.apiKey}`;
// @ts-ignore
return await this.helpers.request(options);
} else {
return await this.helpers.requestOAuth2?.call(this, 'clearbitOAuth2Api', options);
}
} catch(error) {
if (error.statusCode === 401) { if (error.statusCode === 401) {
// Return a clear error // Return a clear error
throw new Error('The Clearbit credentials are not valid!'); throw new Error('The Clearbit credentials are not valid!');

View file

@ -39,6 +39,7 @@
"dist/credentials/BitlyApi.credentials.js", "dist/credentials/BitlyApi.credentials.js",
"dist/credentials/ChargebeeApi.credentials.js", "dist/credentials/ChargebeeApi.credentials.js",
"dist/credentials/ClearbitApi.credentials.js", "dist/credentials/ClearbitApi.credentials.js",
"dist/credentials/ClearbitOAuth2Api.credentials.js",
"dist/credentials/ClickUpApi.credentials.js", "dist/credentials/ClickUpApi.credentials.js",
"dist/credentials/ClockifyApi.credentials.js", "dist/credentials/ClockifyApi.credentials.js",
"dist/credentials/CockpitApi.credentials.js", "dist/credentials/CockpitApi.credentials.js",