mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-09 20:07:31 -08:00
d9b98fc8be
* ✨ Create rule `no-unneeded-backticks` * 👕 Enable rule * ⚡ Run rule on `cli` * ⚡ Run rule on `core` * ⚡ Run rule on `workflow` * ⚡ Rule rule on `design-system` * ⚡ Run rule on `node-dev` * ⚡ Run rule on `editor-ui` * ⚡ Run rule on `nodes-base`
60 lines
1.2 KiB
TypeScript
60 lines
1.2 KiB
TypeScript
import {
|
|
ICredentialDataDecryptedObject,
|
|
ICredentialTestRequest,
|
|
ICredentialType,
|
|
IHttpRequestOptions,
|
|
INodeProperties,
|
|
} from 'n8n-workflow';
|
|
|
|
import jwt from 'jsonwebtoken';
|
|
export class GhostAdminApi implements ICredentialType {
|
|
name = 'ghostAdminApi';
|
|
|
|
displayName = 'Ghost Admin API';
|
|
|
|
documentationUrl = 'ghost';
|
|
|
|
properties: INodeProperties[] = [
|
|
{
|
|
displayName: 'URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
default: '',
|
|
placeholder: 'http://localhost:3001',
|
|
},
|
|
{
|
|
displayName: 'API Key',
|
|
name: 'apiKey',
|
|
type: 'string',
|
|
typeOptions: { password: true },
|
|
default: '',
|
|
},
|
|
];
|
|
|
|
async authenticate(
|
|
credentials: ICredentialDataDecryptedObject,
|
|
requestOptions: IHttpRequestOptions,
|
|
): Promise<IHttpRequestOptions> {
|
|
const [id, secret] = (credentials.apiKey as string).split(':');
|
|
const token = jwt.sign({}, Buffer.from(secret, 'hex'), {
|
|
keyid: id,
|
|
algorithm: 'HS256',
|
|
expiresIn: '5m',
|
|
audience: '/v2/admin/',
|
|
});
|
|
|
|
requestOptions.headers = {
|
|
...requestOptions.headers,
|
|
Authorization: `Ghost ${token}`,
|
|
};
|
|
return requestOptions;
|
|
}
|
|
|
|
test: ICredentialTestRequest = {
|
|
request: {
|
|
baseURL: '={{$credentials.url}}',
|
|
url: '/ghost/api/v2/admin/pages/',
|
|
},
|
|
};
|
|
}
|