feat: create ViewField model (#961)

* feat: create ViewField model

- Created ViewField prisma model
- Added ViewField server resolvers for findMany/updateOne
- Added getViewFields/updateViewField graphql queries

Closes #849

* chore: update node version in .nvmrc files
This commit is contained in:
Thaïs
2023-07-27 18:12:26 +02:00
committed by GitHub
parent e90f44bbfb
commit 9027406fdf
17 changed files with 512 additions and 3 deletions

View File

@ -11,6 +11,7 @@ import { AnalyticsModule } from './analytics/analytics.module';
import { FileModule } from './file/file.module';
import { ClientConfigModule } from './client-config/client-config.module';
import { AttachmentModule } from './attachment/attachment.module';
import { ViewModule } from './view/view.module';
@Module({
imports: [
@ -25,6 +26,7 @@ import { AttachmentModule } from './attachment/attachment.module';
FileModule,
ClientConfigModule,
AttachmentModule,
ViewModule,
],
exports: [
AuthModule,

View File

@ -0,0 +1,32 @@
import { Test, TestingModule } from '@nestjs/testing';
import { ViewFieldService } from 'src/core/view/services/view-field.service';
import { ViewFieldResolver } from './view-field.resolver';
import { AbilityFactory } from 'src/ability/ability.factory';
describe('ViewFieldResolver', () => {
let resolver: ViewFieldResolver;
beforeEach(async () => {
const module: TestingModule = await Test.createTestingModule({
providers: [
ViewFieldResolver,
{
provide: ViewFieldService,
useValue: {},
},
{
provide: AbilityFactory,
useValue: {},
},
],
}).compile();
resolver = module.get<ViewFieldResolver>(ViewFieldResolver);
});
it('should be defined', () => {
expect(resolver).toBeDefined();
});
});

View File

@ -0,0 +1,68 @@
import { UseGuards } from '@nestjs/common';
import { Args, Mutation, Query, Resolver } from '@nestjs/graphql';
import { accessibleBy } from '@casl/prisma';
import { Prisma } from '@prisma/client';
import { AppAbility } from 'src/ability/ability.factory';
import {
ReadViewFieldAbilityHandler,
UpdateViewFieldAbilityHandler,
} from 'src/ability/handlers/view-field.ability-handler';
import { FindManyViewFieldArgs } from 'src/core/@generated/view-field/find-many-view-field.args';
import { UpdateOneViewFieldArgs } from 'src/core/@generated/view-field/update-one-view-field.args';
import { ViewField } from 'src/core/@generated/view-field/view-field.model';
import { ViewFieldService } from 'src/core/view/services/view-field.service';
import { CheckAbilities } from 'src/decorators/check-abilities.decorator';
import {
PrismaSelect,
PrismaSelector,
} from 'src/decorators/prisma-select.decorator';
import { UserAbility } from 'src/decorators/user-ability.decorator';
import { AbilityGuard } from 'src/guards/ability.guard';
import { JwtAuthGuard } from 'src/guards/jwt.auth.guard';
@UseGuards(JwtAuthGuard)
@Resolver(() => ViewField)
export class ViewFieldResolver {
constructor(private readonly viewFieldService: ViewFieldService) {}
@Query(() => [ViewField])
@UseGuards(AbilityGuard)
@CheckAbilities(ReadViewFieldAbilityHandler)
async findManyViewField(
@Args() args: FindManyViewFieldArgs,
@UserAbility() ability: AppAbility,
@PrismaSelector({ modelName: 'ViewField' })
prismaSelect: PrismaSelect<'ViewField'>,
): Promise<Partial<ViewField>[]> {
return this.viewFieldService.findMany({
where: args.where
? {
AND: [args.where, accessibleBy(ability).ViewField],
}
: accessibleBy(ability).ViewField,
orderBy: args.orderBy,
cursor: args.cursor,
take: args.take,
skip: args.skip,
distinct: args.distinct,
select: prismaSelect.value,
});
}
@Mutation(() => ViewField)
@UseGuards(AbilityGuard)
@CheckAbilities(UpdateViewFieldAbilityHandler)
async updateOneViewField(
@Args() args: UpdateOneViewFieldArgs,
@PrismaSelector({ modelName: 'ViewField' })
prismaSelect: PrismaSelect<'ViewField'>,
) {
return this.viewFieldService.update({
where: args.where,
data: args.data,
select: prismaSelect.value,
} as Prisma.ViewFieldUpdateArgs);
}
}

View File

@ -0,0 +1,28 @@
import { Test, TestingModule } from '@nestjs/testing';
import { PrismaService } from 'src/database/prisma.service';
import { prismaMock } from 'src/database/client-mock/jest-prisma-singleton';
import { ViewFieldService } from './view-field.service';
describe('ViewFieldService', () => {
let service: ViewFieldService;
beforeEach(async () => {
const module: TestingModule = await Test.createTestingModule({
providers: [
ViewFieldService,
{
provide: PrismaService,
useValue: prismaMock,
},
],
}).compile();
service = module.get<ViewFieldService>(ViewFieldService);
});
it('should be defined', () => {
expect(service).toBeDefined();
});
});

View File

@ -0,0 +1,39 @@
import { Injectable } from '@nestjs/common';
import { PrismaService } from 'src/database/prisma.service';
@Injectable()
export class ViewFieldService {
constructor(private readonly prismaService: PrismaService) {}
// Find
findFirst = this.prismaService.client.viewField.findFirst;
findFirstOrThrow = this.prismaService.client.viewField.findFirstOrThrow;
findUnique = this.prismaService.client.viewField.findUnique;
findUniqueOrThrow = this.prismaService.client.viewField.findUniqueOrThrow;
findMany = this.prismaService.client.viewField.findMany;
// Create
create = this.prismaService.client.viewField.create;
createMany = this.prismaService.client.viewField.createMany;
// Update
update = this.prismaService.client.viewField.update;
upsert = this.prismaService.client.viewField.upsert;
updateMany = this.prismaService.client.viewField.updateMany;
// Delete
delete = this.prismaService.client.viewField.delete;
deleteMany = this.prismaService.client.viewField.deleteMany;
// Aggregate
aggregate = this.prismaService.client.viewField.aggregate;
// Count
count = this.prismaService.client.viewField.count;
// GroupBy
groupBy = this.prismaService.client.viewField.groupBy;
}

View File

@ -0,0 +1,9 @@
import { Module } from '@nestjs/common';
import { ViewFieldService } from './services/view-field.service';
import { ViewFieldResolver } from './resolvers/view-field.resolver';
@Module({
providers: [ViewFieldService, ViewFieldResolver],
})
export class ViewModule {}