mirror of
https://github.com/n8n-io/n8n.git
synced 2025-02-21 02:56:40 -08:00
Merge branch 'ajmeredith1200-master'
This commit is contained in:
commit
9bbe88f462
|
@ -1,4 +1,6 @@
|
||||||
import {
|
import {
|
||||||
|
IAuthenticateHeaderAuth,
|
||||||
|
ICredentialTestRequest,
|
||||||
ICredentialType,
|
ICredentialType,
|
||||||
INodeProperties,
|
INodeProperties,
|
||||||
} from 'n8n-workflow';
|
} from 'n8n-workflow';
|
||||||
|
@ -28,4 +30,18 @@ export class GithubApi implements ICredentialType {
|
||||||
default: '',
|
default: '',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
authenticate: IAuthenticateHeaderAuth = {
|
||||||
|
type: 'headerAuth',
|
||||||
|
properties: {
|
||||||
|
name: 'Authorization',
|
||||||
|
value: '=token {{$credentials?.accessToken}}',
|
||||||
|
},
|
||||||
|
};
|
||||||
|
test: ICredentialTestRequest = {
|
||||||
|
request: {
|
||||||
|
baseURL: '={{$credentials?.server}}',
|
||||||
|
url: '/user',
|
||||||
|
method: 'GET',
|
||||||
|
},
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,23 +37,23 @@ export async function githubApiRequest(this: IHookFunctions | IExecuteFunctions,
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const authenticationMethod = this.getNodeParameter('authentication', 0, 'accessToken') as string;
|
const authenticationMethod = this.getNodeParameter('authentication', 0, 'accessToken') as string;
|
||||||
|
let credentialType = '';
|
||||||
|
|
||||||
if (authenticationMethod === 'accessToken') {
|
if (authenticationMethod === 'accessToken') {
|
||||||
const credentials = await this.getCredentials('githubApi');
|
const credentials = await this.getCredentials('githubApi');
|
||||||
|
credentialType = 'githubApi';
|
||||||
|
|
||||||
const baseUrl = credentials!.server || 'https://api.github.com';
|
const baseUrl = credentials!.server || 'https://api.github.com';
|
||||||
options.uri = `${baseUrl}${endpoint}`;
|
options.uri = `${baseUrl}${endpoint}`;
|
||||||
|
|
||||||
options.headers!.Authorization = `token ${credentials.accessToken}`;
|
|
||||||
return await this.helpers.request(options);
|
|
||||||
} else {
|
} else {
|
||||||
const credentials = await this.getCredentials('githubOAuth2Api');
|
const credentials = await this.getCredentials('githubOAuth2Api');
|
||||||
|
credentialType = 'githubOAuth2Api';
|
||||||
|
|
||||||
const baseUrl = credentials.server || 'https://api.github.com';
|
const baseUrl = credentials.server || 'https://api.github.com';
|
||||||
options.uri = `${baseUrl}${endpoint}`;
|
options.uri = `${baseUrl}${endpoint}`;
|
||||||
//@ts-ignore
|
|
||||||
return await this.helpers.requestOAuth2.call(this, 'githubOAuth2Api', options);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return await this.helpers.requestWithAuthentication.call(this, credentialType, options);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
throw new NodeApiError(this.getNode(), error);
|
throw new NodeApiError(this.getNode(), error);
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue