mirror of
https://github.com/n8n-io/n8n.git
synced 2025-02-21 02:56:40 -08:00
* First node set up. * Progress: all Resources and Operations updated * Upsates to all resources. * Updated tooltip for Tweet > Search > Tweet fields. * Upodate to resource locator items in User > Search. * Added e.g. to placeholders and minor copy tweaks. * Fixed Operations sorting. * Added a couple of operations back. * Removed 'Authorized API Call'. * Remove authorization header when empty * Import pkce * Add OAuth2 with new grant type to Twitter * Add pkce logic auto assign authorization code if pkce not defined * Add pkce to ui and interfaces * Fix scopes for Oauth2 twitter * Deubg + pass it through header * Add debug console, add airtable cred * Remove all console.logs, make PKCE in th body only when it exists * Remove invalid character ~ * Remove more console.logs * remove body inside query * Remove useless grantype check * Hide oauth2 twitter waiting for overhaul * Remove redundant header removal * Remove more console.logs * Add V2 twitter * Add V1 * Fix description V1, V2 * Fix description for V1 * Add Oauth2 request * Add user lookup * Add search username by ID * Search tweet feat * Wip create tweet * Generic function for returning ID * Add like and retweet feat * Add delete tweet feat * Fix Location tweets * Fix type * Feat List add members * Add scopes for dm and list * Add direct message feature * Improve response data * Fix regex * Add unit test to Twitter v2 * Fix unit test * Remove console.logs * Remove more console.logs * Handle @ in username * Minor copy tweaks. * Add return all logic * Add error for api permission error * Update message api error * Add error for date error * Add notice for TwitterOAuth2 api link * Fix display names location * fix List RLC * Fix like endpoint * Fix error message check * fix(core): Fix OAuth2 callback for grantType=clientCredentials * Improve fix for callback * update pnpm * Fix iso time for end time * sync oauth2Credential * remove unused codeVerifer in Server.ts * Add location and attachments notice * Add notice to oauth1 * Improve notice for twitter * moved credentials notice to TwitterOAuth1Api.credentials.ts --------- Co-authored-by: agobrech <ael.gobrecht@gmail.com> Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in> Co-authored-by: Marcus <marcus@n8n.io>
52 lines
1.4 KiB
TypeScript
52 lines
1.4 KiB
TypeScript
import type { ClientOAuth2, ClientOAuth2Options } from './ClientOAuth2';
|
|
import type { ClientOAuth2Token, ClientOAuth2TokenData } from './ClientOAuth2Token';
|
|
import { DEFAULT_HEADERS } from './constants';
|
|
import { auth, expects, getRequestOptions } from './utils';
|
|
|
|
interface CredentialsFlowBody {
|
|
grant_type: 'client_credentials';
|
|
scope?: string;
|
|
}
|
|
|
|
/**
|
|
* Support client credentials OAuth 2.0 grant.
|
|
*
|
|
* Reference: http://tools.ietf.org/html/rfc6749#section-4.4
|
|
*/
|
|
export class CredentialsFlow {
|
|
constructor(private client: ClientOAuth2) {}
|
|
|
|
/**
|
|
* Request an access token using the client credentials.
|
|
*/
|
|
async getToken(opts?: Partial<ClientOAuth2Options>): Promise<ClientOAuth2Token> {
|
|
const options = { ...this.client.options, ...opts };
|
|
expects(options, 'clientId', 'clientSecret', 'accessTokenUri');
|
|
|
|
const body: CredentialsFlowBody = {
|
|
grant_type: 'client_credentials',
|
|
};
|
|
|
|
if (options.scopes !== undefined) {
|
|
body.scope = options.scopes.join(options.scopesSeparator ?? ' ');
|
|
}
|
|
|
|
const requestOptions = getRequestOptions(
|
|
{
|
|
url: options.accessTokenUri,
|
|
method: 'POST',
|
|
headers: {
|
|
...DEFAULT_HEADERS,
|
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
Authorization: auth(options.clientId, options.clientSecret),
|
|
},
|
|
body,
|
|
},
|
|
options,
|
|
);
|
|
|
|
const responseData = await this.client.request<ClientOAuth2TokenData>(requestOptions);
|
|
return this.client.createToken(responseData);
|
|
}
|
|
}
|