import { Container } from 'typedi'; import { CredentialsEntity } from '@db/entities/CredentialsEntity'; import type { User } from '@db/entities/User'; import { CredentialsRepository } from '@db/repositories/credentials.repository'; import { SharedCredentialsRepository } from '@db/repositories/sharedCredentials.repository'; import type { CredentialSharingRole } from '@db/entities/SharedCredentials'; import type { ICredentialsDb } from '@/Interfaces'; import type { CredentialPayload } from '../types'; import { ProjectRepository } from '@/databases/repositories/project.repository'; import type { Project } from '@/databases/entities/Project'; export async function encryptCredentialData( credential: CredentialsEntity, ): Promise { const { createCredentialsFromCredentialsEntity } = await import('@/CredentialsHelper'); const coreCredential = createCredentialsFromCredentialsEntity(credential, true); // @ts-ignore coreCredential.setData(credential.data); return Object.assign(credential, coreCredential.getDataToSave()); } const emptyAttributes = { name: 'test', type: 'test', data: '', }; export async function createManyCredentials( amount: number, attributes: Partial = emptyAttributes, ) { return await Promise.all( Array(amount) .fill(0) .map(async () => await createCredentials(attributes)), ); } export async function createCredentials( attributes: Partial = emptyAttributes, project?: Project, ) { const credentialsRepository = Container.get(CredentialsRepository); const credentials = await credentialsRepository.save(credentialsRepository.create(attributes)); if (project) { await Container.get(SharedCredentialsRepository).save( Container.get(SharedCredentialsRepository).create({ project, credentials, role: 'credential:owner', }), ); } return credentials; } /** * Save a credential to the test DB, sharing it with a user. */ export async function saveCredential( credentialPayload: CredentialPayload, options: | { user: User; role: CredentialSharingRole } | { project: Project; role: CredentialSharingRole; }, ) { const role = options.role; const newCredential = new CredentialsEntity(); Object.assign(newCredential, credentialPayload); await encryptCredentialData(newCredential); const savedCredential = await Container.get(CredentialsRepository).save(newCredential); savedCredential.data = newCredential.data; if ('user' in options) { const user = options.user; const personalProject = await Container.get(ProjectRepository).getPersonalProjectForUserOrFail( user.id, ); await Container.get(SharedCredentialsRepository).save({ user, credentials: savedCredential, role, project: personalProject, }); } else { const project = options.project; await Container.get(SharedCredentialsRepository).save({ credentials: savedCredential, role, project, }); } return savedCredential; } export async function shareCredentialWithUsers(credential: CredentialsEntity, users: User[]) { const newSharedCredentials = await Promise.all( users.map(async (user) => { const personalProject = await Container.get( ProjectRepository, ).getPersonalProjectForUserOrFail(user.id); return Container.get(SharedCredentialsRepository).create({ credentialsId: credential.id, role: 'credential:user', projectId: personalProject.id, }); }), ); return await Container.get(SharedCredentialsRepository).save(newSharedCredentials); } export async function shareCredentialWithProjects( credential: CredentialsEntity, projects: Project[], ) { const newSharedCredentials = await Promise.all( projects.map(async (project) => { return Container.get(SharedCredentialsRepository).create({ credentialsId: credential.id, role: 'credential:user', projectId: project.id, }); }), ); return await Container.get(SharedCredentialsRepository).save(newSharedCredentials); } export function affixRoleToSaveCredential(role: CredentialSharingRole) { return async ( credentialPayload: CredentialPayload, options: { user: User } | { project: Project }, ) => await saveCredential(credentialPayload, { ...options, role }); } export async function getAllCredentials() { return await Container.get(CredentialsRepository).find(); } export const getCredentialById = async (id: string) => await Container.get(CredentialsRepository).findOneBy({ id }); export async function getAllSharedCredentials() { return await Container.get(SharedCredentialsRepository).find(); } export async function getCredentialSharings(credential: CredentialsEntity) { return await Container.get(SharedCredentialsRepository).findBy({ credentialsId: credential.id, }); }