mirror of
https://github.com/n8n-io/n8n.git
synced 2025-02-21 02:56:40 -08:00
⚡ Add parameter to include credentials in querystring (Woocommerce) (#1756)
This commit is contained in:
parent
7bc79c879d
commit
c632f7982f
|
@ -27,5 +27,14 @@ export class WooCommerceApi implements ICredentialType {
|
|||
default: '',
|
||||
placeholder: 'https://example.com',
|
||||
},
|
||||
{
|
||||
displayName: 'Include Credentials in Query',
|
||||
name: 'includeCredentialsInQuery',
|
||||
type: 'boolean' as NodePropertyTypes,
|
||||
default: false,
|
||||
description: `Occasionally, some servers may not parse the Authorization header correctly</br>
|
||||
(if you see a “Consumer key is missing” error when authenticating over SSL, you have a server issue).</br>
|
||||
In this case, you may provide the consumer key/secret as query string parameters instead.`,
|
||||
},
|
||||
];
|
||||
}
|
||||
|
|
|
@ -9,6 +9,7 @@ import {
|
|||
ILoadOptionsFunctions,
|
||||
IWebhookFunctions,
|
||||
} from 'n8n-core';
|
||||
|
||||
import {
|
||||
ICredentialDataDecryptedObject,
|
||||
IDataObject,
|
||||
|
@ -36,6 +37,7 @@ export async function woocommerceApiRequest(this: IHookFunctions | IExecuteFunct
|
|||
if (credentials === undefined) {
|
||||
throw new NodeOperationError(this.getNode(), 'No credentials got returned!');
|
||||
}
|
||||
|
||||
let options: OptionsWithUri = {
|
||||
auth: {
|
||||
user: credentials.consumerKey as string,
|
||||
|
@ -47,11 +49,16 @@ export async function woocommerceApiRequest(this: IHookFunctions | IExecuteFunct
|
|||
uri: uri || `${credentials.url}/wp-json/wc/v3${resource}`,
|
||||
json: true,
|
||||
};
|
||||
|
||||
if (credentials.includeCredentialsInQuery === true) {
|
||||
delete options.auth;
|
||||
Object.assign(qs, { consumer_key: credentials.consumerKey, consumer_secret: credentials.consumerSecret });
|
||||
}
|
||||
|
||||
if (!Object.keys(body).length) {
|
||||
delete options.form;
|
||||
}
|
||||
options = Object.assign({}, options, option);
|
||||
|
||||
try {
|
||||
return await this.helpers.request!(options);
|
||||
} catch (error) {
|
||||
|
|
Loading…
Reference in a new issue