schema-generator.ts 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import { GraphQLTypesLoader } from '@nestjs/graphql';
  2. import {
  3. getConfig,
  4. getFinalVendureSchema,
  5. resetConfig,
  6. runPluginConfigurations,
  7. setConfig,
  8. VENDURE_ADMIN_API_TYPE_PATHS,
  9. VendureConfig,
  10. } from '@vendure/core';
  11. import { buildSchema, GraphQLSchema } from 'graphql';
  12. let schemaPromise: Promise<GraphQLSchema> | undefined;
  13. /**
  14. * @description
  15. * This function generates a GraphQL schema from the Vendure config.
  16. * It is used to generate the schema for the dashboard.
  17. */
  18. export async function generateSchema({
  19. vendureConfig,
  20. }: {
  21. vendureConfig: VendureConfig;
  22. }): Promise<GraphQLSchema> {
  23. if (!schemaPromise) {
  24. /* eslint-disable-next-line @typescript-eslint/no-misused-promises */
  25. schemaPromise = new Promise(async (resolve, reject) => {
  26. resetConfig();
  27. try {
  28. await setConfig(vendureConfig ?? {});
  29. const runtimeConfig = await runPluginConfigurations(getConfig() as any);
  30. const typesLoader = new GraphQLTypesLoader();
  31. const finalSchema = await getFinalVendureSchema({
  32. config: runtimeConfig,
  33. typePaths: VENDURE_ADMIN_API_TYPE_PATHS,
  34. typesLoader,
  35. apiType: 'admin',
  36. output: 'sdl',
  37. });
  38. const safeSchema = buildSchema(finalSchema);
  39. resolve(safeSchema);
  40. } catch (e) {
  41. reject(e);
  42. }
  43. });
  44. }
  45. return schemaPromise;
  46. }