* feat: introducing admin module, resolvers and service files as a module * feat: adding admin module in the app module * feat: introducing admin guard and decorator for allowing admin operations * feat: invited user model * chore: added user invitation mail description to mailer service * chore: added admin and user related error * feat: added invited users as a new model in prisma * chore: added admin related topics to pubsub * chore: added service method to fetch all users from user table * chore: added user deletion base implementation * Revert "chore: added user deletion base implementation" This reverts commit d1615ad83db2bae946e2d366a903d2f95051dabb. * feat: adding team related operations to admin * chore: adding admin related service methods to teams module service * chore: adding admin related service methods to team coll invitations requests envs * chore: added more module error messages * chore: added admin check service method * chore: added find individual user by UID in admin * HBE-106 feat: introduced code to handle first time admin login setup (#23) * test: wrote test cases for verifyAdmin route service method * chore: added comments to verifyAdmin service method * chore: deleted the prisma migration file * chore: added find admin users * feat: added user deletion into admin module * chore: admin user related errors * chore: fixed registry pattern in the shortcodes and teams to handle user deletion * chore: add subscription topic for user deletion * chore: updated user type in data handler * feat: implement and fix user deletion * feat: added make user admin mutation * chore: added unit tests for admin specific service methods in admin module * chore: added invitation not found error * chore: added admin specific operation test cases in specific modules * chore: added tests related to user deletion and admin related operation in user module * chore: updated to error constant when invitations not found * chore: fix rebase overwritten methods * feat: implement remove user as admin * chore: add new line * feat: introducing basic metrics into the self-hosted admin module (HBE-104) (#43) * feat: introducing admin module, resolvers and service files as a module * feat: adding admin module in the app module * feat: introducing admin guard and decorator for allowing admin operations * feat: invited user model * chore: added user invitation mail description to mailer service * chore: added admin and user related error * feat: added invited users as a new model in prisma * chore: added admin related topics to pubsub * chore: added service method to fetch all users from user table * chore: added user deletion base implementation * Revert "chore: added user deletion base implementation" This reverts commit d1615ad83db2bae946e2d366a903d2f95051dabb. * feat: adding team related operations to admin * chore: adding admin related service methods to teams module service * chore: adding admin related service methods to team coll invitations requests envs * chore: added more module error messages * chore: added admin check service method * chore: added find individual user by UID in admin * HBE-106 feat: introduced code to handle first time admin login setup (#23) * test: wrote test cases for verifyAdmin route service method * chore: added comments to verifyAdmin service method * chore: deleted the prisma migration file * chore: added find admin users * feat: added user deletion into admin module * chore: admin user related errors * chore: fixed registry pattern in the shortcodes and teams to handle user deletion * chore: add subscription topic for user deletion * chore: updated user type in data handler * feat: implement and fix user deletion * feat: added make user admin mutation * chore: added unit tests for admin specific service methods in admin module * chore: added invitation not found error * chore: added admin specific operation test cases in specific modules * chore: added tests related to user deletion and admin related operation in user module * chore: updated to error constant when invitations not found * chore: fix rebase overwritten methods * feat: implement remove user as admin * chore: add new line * chore: created new GQL return type for admin module * chore: created resolver and service method for method to fetch org metrics * chore: removed all entities relevant to seperate query for fetching admin metrics * chore: created all resolvers for metrics * feat: completed adding field resolves to query org metrics * test: wrote tests for all metrics related methods in admin module * test: added test cases for get count functions in multiple modules * chore: removed prisma migration folder * Delete backend-schema.gql * chore: resolved merge conflicts in team test file --------- Co-authored-by: ankitsridhar16 <ankit.sridhar16@gmail.com> * refactor: update mailer service to stop using postmark (#38) * refactor: update mailer service to stop using postmark * chore: remove postmark as a dep and move out postmark code * chore: remove postmark variables from .env.example * chore: add formal errors for mailer initialization errors * chore: add and update jsdoc comments in mailer service methods * chore: added user invitation mail description to mailer service * chore: updated with review changes requested for admin module * feat: adding admin resolver to gql schema * feat: adding input args for admin resolvers * chore: invited user renamed * chore: updated mailer service to be compatible with new mailer * chore: updated team service with review changes * chore: updated team collection service with review changes * chore: updated team environments service with review changes * chore: updated team requests service with review changes * chore: updated user service with review changes * refactor: invited user model * chore: review changes implemented * chore: implemented the review changes for admin, user and teams module * chore: removed error handling and implemented review changes * refactor: naming change for IsAdmin --------- Co-authored-by: Balu Babu <balub997@gmail.com> Co-authored-by: Andrew Bastin <andrewbastin.k@gmail.com>
249 lines
6.5 KiB
TypeScript
249 lines
6.5 KiB
TypeScript
import { Injectable } from '@nestjs/common';
|
|
import { pipe } from 'fp-ts/function';
|
|
import * as T from 'fp-ts/Task';
|
|
import * as TO from 'fp-ts/TaskOption';
|
|
import * as TE from 'fp-ts/TaskEither';
|
|
import * as A from 'fp-ts/Array';
|
|
import { Prisma } from '@prisma/client';
|
|
import { PrismaService } from 'src/prisma/prisma.service';
|
|
import { PubSubService } from 'src/pubsub/pubsub.service';
|
|
import { TeamEnvironment } from './team-environments.model';
|
|
import { TEAM_ENVIRONMENT_NOT_FOUND } from 'src/errors';
|
|
|
|
@Injectable()
|
|
export class TeamEnvironmentsService {
|
|
constructor(
|
|
private readonly prisma: PrismaService,
|
|
private readonly pubsub: PubSubService,
|
|
) {}
|
|
|
|
getTeamEnvironment(id: string) {
|
|
return TO.tryCatch(() =>
|
|
this.prisma.teamEnvironment.findFirst({
|
|
where: { id },
|
|
rejectOnNotFound: true,
|
|
}),
|
|
);
|
|
}
|
|
|
|
createTeamEnvironment(name: string, teamID: string, variables: string) {
|
|
return pipe(
|
|
() =>
|
|
this.prisma.teamEnvironment.create({
|
|
data: {
|
|
name: name,
|
|
teamID: teamID,
|
|
variables: JSON.parse(variables),
|
|
},
|
|
}),
|
|
T.chainFirst(
|
|
(environment) => () =>
|
|
this.pubsub.publish(
|
|
`team_environment/${environment.teamID}/created`,
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
),
|
|
T.map((data) => {
|
|
return <TeamEnvironment>{
|
|
id: data.id,
|
|
name: data.name,
|
|
teamID: data.teamID,
|
|
variables: JSON.stringify(data.variables),
|
|
};
|
|
}),
|
|
);
|
|
}
|
|
|
|
deleteTeamEnvironment(id: string) {
|
|
return pipe(
|
|
TE.tryCatch(
|
|
() =>
|
|
this.prisma.teamEnvironment.delete({
|
|
where: {
|
|
id: id,
|
|
},
|
|
}),
|
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
|
),
|
|
TE.chainFirst((environment) =>
|
|
TE.fromTask(() =>
|
|
this.pubsub.publish(
|
|
`team_environment/${environment.teamID}/deleted`,
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
),
|
|
),
|
|
TE.map((data) => true),
|
|
);
|
|
}
|
|
|
|
updateTeamEnvironment(id: string, name: string, variables: string) {
|
|
return pipe(
|
|
TE.tryCatch(
|
|
() =>
|
|
this.prisma.teamEnvironment.update({
|
|
where: { id: id },
|
|
data: {
|
|
name,
|
|
variables: JSON.parse(variables),
|
|
},
|
|
}),
|
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
|
),
|
|
TE.chainFirst((environment) =>
|
|
TE.fromTask(() =>
|
|
this.pubsub.publish(
|
|
`team_environment/${environment.teamID}/updated`,
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
),
|
|
),
|
|
TE.map(
|
|
(environment) =>
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
);
|
|
}
|
|
|
|
deleteAllVariablesFromTeamEnvironment(id: string) {
|
|
return pipe(
|
|
TE.tryCatch(
|
|
() =>
|
|
this.prisma.teamEnvironment.update({
|
|
where: { id: id },
|
|
data: {
|
|
variables: [],
|
|
},
|
|
}),
|
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
|
),
|
|
TE.chainFirst((environment) =>
|
|
TE.fromTask(() =>
|
|
this.pubsub.publish(
|
|
`team_environment/${environment.teamID}/updated`,
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
),
|
|
),
|
|
TE.map(
|
|
(environment) =>
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
);
|
|
}
|
|
|
|
createDuplicateEnvironment(id: string) {
|
|
return pipe(
|
|
TE.tryCatch(
|
|
() =>
|
|
this.prisma.teamEnvironment.findFirst({
|
|
where: {
|
|
id: id,
|
|
},
|
|
rejectOnNotFound: true,
|
|
}),
|
|
() => TEAM_ENVIRONMENT_NOT_FOUND,
|
|
),
|
|
TE.chain((environment) =>
|
|
TE.fromTask(() =>
|
|
this.prisma.teamEnvironment.create({
|
|
data: {
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: environment.variables as Prisma.JsonArray,
|
|
},
|
|
}),
|
|
),
|
|
),
|
|
TE.chainFirst((environment) =>
|
|
TE.fromTask(() =>
|
|
this.pubsub.publish(
|
|
`team_environment/${environment.teamID}/created`,
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
),
|
|
),
|
|
TE.map(
|
|
(environment) =>
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
);
|
|
}
|
|
|
|
fetchAllTeamEnvironments(teamID: string) {
|
|
return pipe(
|
|
() =>
|
|
this.prisma.teamEnvironment.findMany({
|
|
where: {
|
|
teamID: teamID,
|
|
},
|
|
}),
|
|
T.map(
|
|
A.map(
|
|
(environment) =>
|
|
<TeamEnvironment>{
|
|
id: environment.id,
|
|
name: environment.name,
|
|
teamID: environment.teamID,
|
|
variables: JSON.stringify(environment.variables),
|
|
},
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Fetch the count of environments for a given team.
|
|
* @param teamID team id
|
|
* @returns a count of team envs
|
|
*/
|
|
async totalEnvsInTeam(teamID: string) {
|
|
const envCount = await this.prisma.teamEnvironment.count({
|
|
where: {
|
|
teamID: teamID,
|
|
},
|
|
});
|
|
return envCount;
|
|
}
|
|
}
|