n8n
Version:
n8n Workflow Automation Tool
87 lines (86 loc) • 4.95 kB
TypeScript
import type { ICredentialDataDecryptedObject, ICredentialsDecrypted } from 'n8n-workflow';
import { type EntityManager, type FindOptionsRelations } from '@n8n/typeorm';
import type { Scope } from '@n8n/permissions';
import type { ICredentialsDb } from '../Interfaces';
import { CredentialsEntity } from '../databases/entities/CredentialsEntity';
import { SharedCredentials } from '../databases/entities/SharedCredentials';
import { ExternalHooks } from '../ExternalHooks';
import type { User } from '../databases/entities/User';
import type { CredentialRequest, ListQuery } from '../requests';
import { CredentialTypes } from '../CredentialTypes';
import { OwnershipService } from '../services/ownership.service';
import { Logger } from '../Logger';
import { CredentialsRepository } from '../databases/repositories/credentials.repository';
import { SharedCredentialsRepository } from '../databases/repositories/sharedCredentials.repository';
import { CredentialsTester } from '../services/credentials-tester.service';
import { ProjectRepository } from '../databases/repositories/project.repository';
import { ProjectService } from '../services/project.service';
import { RoleService } from '../services/role.service';
import { UserRepository } from '../databases/repositories/user.repository';
export type CredentialsGetSharedOptions = {
allowGlobalScope: true;
globalScope: Scope;
} | {
allowGlobalScope: false;
};
export declare class CredentialsService {
private readonly credentialsRepository;
private readonly sharedCredentialsRepository;
private readonly ownershipService;
private readonly logger;
private readonly credentialsTester;
private readonly externalHooks;
private readonly credentialTypes;
private readonly projectRepository;
private readonly projectService;
private readonly roleService;
private readonly userRepository;
constructor(credentialsRepository: CredentialsRepository, sharedCredentialsRepository: SharedCredentialsRepository, ownershipService: OwnershipService, logger: Logger, credentialsTester: CredentialsTester, externalHooks: ExternalHooks, credentialTypes: CredentialTypes, projectRepository: ProjectRepository, projectService: ProjectService, roleService: RoleService, userRepository: UserRepository);
getMany(user: User, options?: {
listQueryOptions?: ListQuery.Options;
includeScopes?: string;
}): Promise<CredentialsEntity[]>;
getCredentialsAUserCanUseInAWorkflow(user: User, options: {
workflowId: string;
} | {
projectId: string;
}): Promise<{
id: string;
name: string;
type: string;
scopes: Scope[];
}[]>;
findAllCredentialIdsForWorkflow(workflowId: string): Promise<CredentialsEntity[]>;
findAllCredentialIdsForProject(projectId: string): Promise<CredentialsEntity[]>;
getSharing(user: User, credentialId: string, globalScopes: Scope[], relations?: FindOptionsRelations<SharedCredentials>): Promise<SharedCredentials | null>;
prepareCreateData(data: CredentialRequest.CredentialProperties): Promise<CredentialsEntity>;
prepareUpdateData(data: CredentialRequest.CredentialProperties, decryptedData: ICredentialDataDecryptedObject): Promise<CredentialsEntity>;
createEncryptedData(credentialId: string | null, data: CredentialsEntity): ICredentialsDb;
decrypt(credential: CredentialsEntity): ICredentialDataDecryptedObject;
update(credentialId: string, newCredentialData: ICredentialsDb): Promise<CredentialsEntity | null>;
save(credential: CredentialsEntity, encryptedData: ICredentialsDb, user: User, projectId?: string): Promise<CredentialsEntity>;
delete(credentials: CredentialsEntity): Promise<void>;
test(user: User, credentials: ICredentialsDecrypted): Promise<import("n8n-workflow").INodeCredentialTestResult>;
redact(data: ICredentialDataDecryptedObject, credential: CredentialsEntity): ICredentialDataDecryptedObject;
private unredactRestoreValues;
unredact(redactedData: ICredentialDataDecryptedObject, savedData: ICredentialDataDecryptedObject): ICredentialDataDecryptedObject;
getOne(user: User, credentialId: string, includeDecryptedData: boolean): Promise<{
name: string;
type: string;
shared: SharedCredentials[];
id: string;
createdAt: Date;
updatedAt: Date;
data: ICredentialDataDecryptedObject;
} | {
name: string;
type: string;
shared: SharedCredentials[];
id: string;
createdAt: Date;
updatedAt: Date;
}>;
getCredentialScopes(user: User, credentialId: string): Promise<Scope[]>;
transferAll(fromProjectId: string, toProjectId: string, trx?: EntityManager): Promise<void>;
replaceCredentialContentsForSharee(user: User, credential: CredentialsEntity, decryptedData: ICredentialDataDecryptedObject, mergedCredentials: ICredentialsDecrypted): Promise<void>;
}