* 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>
24 lines
524 B
TypeScript
24 lines
524 B
TypeScript
import isEmpty from 'lodash.isempty';
|
|
|
|
export const convertFieldsToGraphQL = (
|
|
fields: any,
|
|
fieldAliases: Record<string, string>,
|
|
acc = '',
|
|
) => {
|
|
for (const [key, value] of Object.entries(fields)) {
|
|
if (value && !isEmpty(value)) {
|
|
acc += `${key} {\n`;
|
|
acc = convertFieldsToGraphQL(value, fieldAliases, acc);
|
|
acc += `}\n`;
|
|
} else {
|
|
if (fieldAliases[key]) {
|
|
acc += `${key}: ${fieldAliases[key]}\n`;
|
|
} else {
|
|
acc += `${key}\n`;
|
|
}
|
|
}
|
|
}
|
|
|
|
return acc;
|
|
};
|