mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 21:07:28 -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>
72 lines
1.8 KiB
TypeScript
72 lines
1.8 KiB
TypeScript
import {
|
|
ICredentialDataDecryptedObject,
|
|
ICredentialTestRequest,
|
|
ICredentialType,
|
|
IHttpRequestOptions,
|
|
INodeProperties,
|
|
} from 'n8n-workflow';
|
|
|
|
export class WooCommerceApi implements ICredentialType {
|
|
name = 'wooCommerceApi';
|
|
|
|
displayName = 'WooCommerce API';
|
|
|
|
documentationUrl = 'wooCommerce';
|
|
|
|
properties: INodeProperties[] = [
|
|
{
|
|
displayName: 'Consumer Key',
|
|
name: 'consumerKey',
|
|
type: 'string',
|
|
default: '',
|
|
},
|
|
{
|
|
displayName: 'Consumer Secret',
|
|
name: 'consumerSecret',
|
|
type: 'string',
|
|
default: '',
|
|
},
|
|
{
|
|
displayName: 'WooCommerce URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
default: '',
|
|
placeholder: 'https://example.com',
|
|
},
|
|
{
|
|
displayName: 'Include Credentials in Query',
|
|
name: 'includeCredentialsInQuery',
|
|
type: 'boolean',
|
|
default: false,
|
|
description:
|
|
'Whether credentials should be included in the query. Occasionally, some servers may not parse the Authorization header correctly (if you see a “Consumer key is missing” error when authenticating over SSL, you have a server issue). In this case, you may provide the consumer key/secret as query string parameters instead.',
|
|
},
|
|
];
|
|
|
|
async authenticate(
|
|
credentials: ICredentialDataDecryptedObject,
|
|
requestOptions: IHttpRequestOptions,
|
|
): Promise<IHttpRequestOptions> {
|
|
requestOptions.auth = {
|
|
// @ts-ignore
|
|
user: credentials.consumerKey as string,
|
|
password: credentials.consumerSecret as string,
|
|
};
|
|
if (credentials.includeCredentialsInQuery === true && requestOptions.qs) {
|
|
delete requestOptions.auth;
|
|
Object.assign(requestOptions.qs, {
|
|
consumer_key: credentials.consumerKey,
|
|
consumer_secret: credentials.consumerSecret,
|
|
});
|
|
}
|
|
return requestOptions;
|
|
}
|
|
|
|
test: ICredentialTestRequest = {
|
|
request: {
|
|
baseURL: '={{$credentials.url}}/wp-json/wc/v3',
|
|
url: '/products/categories',
|
|
},
|
|
};
|
|
}
|