feat: dynamic graphQL schema generation based on user workspace (#1725)
* wip: refacto and start creating custom resolver * feat: findMany & findUnique of a custom entity * feat: wip pagination * feat: initial metadata migration * feat: universal findAll with pagination * fix: clean small stuff in pagination * fix: test * fix: miss file * feat: rename custom into universal * feat: create metadata schema in default database * Multi-tenant db schemas POC fix tests and use query builders remove synchronize restore updatedAt remove unnecessary import use queryRunner fix camelcase add migrations for standard objects Multi-tenant db schemas POC fix tests and use query builders remove synchronize restore updatedAt remove unnecessary import use queryRunner fix camelcase add migrations for standard objects poc: conditional schema at runtime wip: try to create resolver in Nest.JS context fix * feat: wip add pg_graphql * feat: setup pg_graphql during database init * wip: dynamic resolver * poc: dynamic resolver and query using pg_graphql * feat: pg_graphql use ARG in Dockerfile * feat: clean findMany & findOne dynamic resolver * feat: get correct schema based on access token * fix: remove old file * fix: tests * fix: better comment * fix: e2e test not working, error format change due to yoga * remove typeorm entity generation + fix jwt + fix search_path + remove anon * fix conflict --------- Co-authored-by: Charles Bochet <charles@twenty.com> Co-authored-by: corentin <corentin@twenty.com>
This commit is contained in:
@ -160,8 +160,7 @@ describe('CompanyResolver (e2e)', () => {
|
||||
const error = errors?.[0];
|
||||
|
||||
expect(error).toBeDefined();
|
||||
expect(error.extensions.code).toBe('FORBIDDEN');
|
||||
expect(error.extensions.originalError.statusCode).toBe(403);
|
||||
expect(error.message).toBe('Forbidden resource');
|
||||
});
|
||||
});
|
||||
|
||||
@ -235,8 +234,7 @@ describe('CompanyResolver (e2e)', () => {
|
||||
const error = errors?.[0];
|
||||
|
||||
expect(error).toBeDefined();
|
||||
expect(error.extensions.code).toBe('FORBIDDEN');
|
||||
expect(error.extensions.originalError.statusCode).toBe(403);
|
||||
expect(error.message).toBe('Forbidden resource');
|
||||
});
|
||||
});
|
||||
|
||||
@ -291,8 +289,7 @@ describe('CompanyResolver (e2e)', () => {
|
||||
const error = errors?.[0];
|
||||
|
||||
expect(error).toBeDefined();
|
||||
expect(error.extensions.code).toBe('FORBIDDEN');
|
||||
expect(error.extensions.originalError.statusCode).toBe(403);
|
||||
expect(error.message).toBe('Forbidden resource');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user