@exogee/graphweaver-mikroorm 2.0.7 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -50,18 +50,29 @@ class IntrospectionError extends Error {
50
50
  }
51
51
  const hasErrorMessage = (error) => error.message;
52
52
  const generateBidirectionalRelations = (metadata) => {
53
+ const nonPrimaryKeyReferenceErrors = [];
53
54
  for (const meta of metadata.filter((m) => !m.pivotTable)) {
54
55
  for (const prop of meta.relations) {
55
56
  if (!prop.name.includes("Inverse")) {
56
57
  const targetMeta = metadata.find((m) => m.className === prop.type);
58
+ const referencedTablePrimaryKeys = import_core.Utils.flatten(
59
+ (targetMeta?.getPrimaryProps() ?? []).map((pk) => pk.fieldNames)
60
+ );
61
+ if (prop.fieldNames?.length) {
62
+ for (const referencedColumn of prop.referencedColumnNames) {
63
+ if (!referencedTablePrimaryKeys.includes(referencedColumn)) {
64
+ nonPrimaryKeyReferenceErrors.push(
65
+ ` - Relationship between ${meta.className}.${prop.fieldNames.join(", ")} and ${targetMeta?.className}.${referencedColumn} is not supported.`
66
+ );
67
+ }
68
+ }
69
+ }
57
70
  const newProp = {
58
71
  name: prop.name + "Inverse",
59
72
  type: meta.className,
60
73
  joinColumns: prop.fieldNames,
61
74
  referencedTableName: meta.tableName,
62
- referencedColumnNames: import_core.Utils.flatten(
63
- (targetMeta?.getPrimaryProps() ?? []).map((pk) => pk.fieldNames)
64
- ),
75
+ referencedColumnNames: referencedTablePrimaryKeys,
65
76
  mappedBy: prop.name
66
77
  };
67
78
  const inverseMeta = metadata.find((m) => m.className === meta.className);
@@ -85,6 +96,15 @@ const generateBidirectionalRelations = (metadata) => {
85
96
  }
86
97
  }
87
98
  }
99
+ if (nonPrimaryKeyReferenceErrors.length) {
100
+ throw new IntrospectionError(
101
+ `Unsupported Relationship${nonPrimaryKeyReferenceErrors.length === 1 ? "" : "s"} Detected`,
102
+ `
103
+ ${nonPrimaryKeyReferenceErrors.join("\n")}
104
+
105
+ Foreign keys in Graphweaver currently need to reference the primary key of the other table.`
106
+ );
107
+ }
88
108
  };
89
109
  const detectManyToManyRelations = (metadata) => {
90
110
  for (const meta of metadata) {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/introspection/generate.ts"],
4
- "sourcesContent": ["import { DatabaseSchema, AbstractSqlPlatform, DatabaseTable } from '@mikro-orm/knex';\nimport {\n\tEntityMetadata,\n\tEntityProperty,\n\tNamingStrategy,\n\tReferenceKind,\n\tUtils,\n} from '@mikro-orm/core';\nimport pluralize from 'pluralize';\n\nimport { ConnectionManager, ConnectionOptions, DatabaseType } from '../database';\nimport {\n\tDataEntityFile,\n\tDataEntityIndexFile,\n\tDataSourceIndexFile,\n\tSchemaEntityFile,\n\tSchemaIndexFile,\n\tDatabaseFile,\n} from './files';\nimport { pascalToCamelCaseString } from './utils';\n\nconst CONNECTION_MANAGER_ID = 'generate';\n\nexport class IntrospectionError extends Error {\n\tprotected type: string;\n\tconstructor(\n\t\tprotected title = '',\n\t\tmessage = ''\n\t) {\n\t\tsuper(message);\n\t\tthis.type = 'IntrospectionError';\n\t\tthis.title = title;\n\t\tthis.message = message;\n\t}\n}\n\nconst hasErrorMessage = (error: any): error is { message: string } => error.message;\n\nconst generateBidirectionalRelations = (metadata: EntityMetadata[]): void => {\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tfor (const prop of meta.relations) {\n\t\t\tif (!prop.name.includes('Inverse')) {\n\t\t\t\tconst targetMeta = metadata.find((m) => m.className === prop.type);\n\t\t\t\tconst newProp = {\n\t\t\t\t\tname: prop.name + 'Inverse',\n\t\t\t\t\ttype: meta.className,\n\t\t\t\t\tjoinColumns: prop.fieldNames,\n\t\t\t\t\treferencedTableName: meta.tableName,\n\t\t\t\t\treferencedColumnNames: Utils.flatten(\n\t\t\t\t\t\t(targetMeta?.getPrimaryProps() ?? []).map((pk) => pk.fieldNames)\n\t\t\t\t\t),\n\t\t\t\t\tmappedBy: prop.name,\n\t\t\t\t} as EntityProperty;\n\n\t\t\t\t// Add reference to the inverse entity\n\t\t\t\tconst inverseMeta = metadata.find((m) => m.className === meta.className);\n\t\t\t\tconst inverseProp = inverseMeta?.props.find((p) => p.name === newProp.mappedBy);\n\t\t\t\tif (inverseProp) inverseProp.inversedBy = newProp.name;\n\n\t\t\t\tif (prop.kind === ReferenceKind.MANY_TO_ONE) {\n\t\t\t\t\tconst name = pascalToCamelCaseString(meta.className);\n\t\t\t\t\tnewProp.name = pluralize(name);\n\t\t\t\t\tnewProp.kind = ReferenceKind.ONE_TO_MANY;\n\t\t\t\t} else if (prop.kind === ReferenceKind.ONE_TO_ONE && !prop.mappedBy) {\n\t\t\t\t\tnewProp.kind = ReferenceKind.ONE_TO_ONE;\n\t\t\t\t\tnewProp.nullable = true;\n\t\t\t\t} else if (prop.kind === ReferenceKind.MANY_TO_MANY && !prop.mappedBy) {\n\t\t\t\t\tconst name = pascalToCamelCaseString(meta.className);\n\t\t\t\t\tnewProp.name = pluralize(name);\n\t\t\t\t\tnewProp.kind = ReferenceKind.MANY_TO_MANY;\n\t\t\t\t} else {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\ttargetMeta?.addProperty(newProp);\n\t\t\t}\n\t\t}\n\t}\n};\n\nconst detectManyToManyRelations = (metadata: EntityMetadata[]) => {\n\tfor (const meta of metadata) {\n\t\tif (\n\t\t\tmeta.compositePK && // needs to have composite PK\n\t\t\tmeta.primaryKeys.length === meta.relations.length && // all relations are PKs\n\t\t\tmeta.relations.length === 2 && // there are exactly two relation properties\n\t\t\tmeta.relations.length === meta.props.length && // all properties are relations\n\t\t\tmeta.relations.every((prop) => prop.kind === ReferenceKind.MANY_TO_ONE) // all relations are m:1\n\t\t) {\n\t\t\tmeta.pivotTable = true;\n\t\t\tconst owner = metadata.find((m) => m.className === meta.relations[0].type);\n\t\t\tif (!owner) throw new Error('No Owner');\n\t\t\tconst name = pascalToCamelCaseString(meta.relations?.[1]?.type);\n\t\t\towner.addProperty({\n\t\t\t\tname: pluralize(name),\n\t\t\t\tkind: ReferenceKind.MANY_TO_MANY,\n\t\t\t\tpivotTable: meta.tableName,\n\t\t\t\ttype: meta.relations[1].type,\n\t\t\t\tjoinColumns: meta.relations[0].fieldNames,\n\t\t\t\tinverseJoinColumns: meta.relations[1].fieldNames,\n\t\t\t} as EntityProperty);\n\t\t}\n\t}\n};\n\nconst generateIdentifiedReferences = (metadata: EntityMetadata[]): void => {\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tfor (const prop of meta.relations) {\n\t\t\tif ([ReferenceKind.MANY_TO_ONE, ReferenceKind.ONE_TO_ONE].includes(prop.kind)) {\n\t\t\t\tconst name = pascalToCamelCaseString(prop.type);\n\t\t\t\tprop.name = pluralize.singular(name);\n\t\t\t\tprop.ref = true;\n\t\t\t}\n\t\t}\n\t}\n};\n\nconst generateSingularTypeReferences = (metadata: EntityMetadata[]): void => {\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tmeta.className = pluralize.singular(meta.className);\n\t\tfor (const prop of meta.relations) {\n\t\t\tprop.type = pluralize.singular(prop.type);\n\t\t}\n\t}\n};\n\n// Convert properties like FirstName to firstName\nconst convertToCamelCasePropertyNames = (metadata: EntityMetadata[]): void => {\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tconst props = Object.values(meta.properties);\n\t\tprops.forEach((prop) => {\n\t\t\tprop.name = pascalToCamelCaseString(prop.name);\n\t\t});\n\t}\n};\n\nconst assertUniqueForeignKeys = (table: DatabaseTable): void => {\n\tconst uniqueForeignKeys = new Set();\n\tconst definedForeignKeys = Object.values(table.getForeignKeys());\n\n\tfor (const foreignKey of definedForeignKeys) {\n\t\tconst { localTableName, referencedTableName, columnNames, referencedColumnNames } = foreignKey;\n\t\tconst serializedValue = JSON.stringify({\n\t\t\tlocalTableName,\n\t\t\tcolumnNames: columnNames.sort(),\n\t\t\treferencedTableName,\n\t\t\treferencedColumnNames: referencedColumnNames.sort(),\n\t\t});\n\n\t\tif (uniqueForeignKeys.has(serializedValue)) {\n\t\t\tthrow new Error(\n\t\t\t\t`\\n\\nImport Failed: Duplicate foreign keys detected on column/s (${columnNames.toString()}) in table \"${\n\t\t\t\t\ttable.name\n\t\t\t\t}\".`\n\t\t\t);\n\t\t}\n\n\t\tuniqueForeignKeys.add(serializedValue);\n\t}\n};\n\nconst convertSchemaToMetadata = async (\n\tschema: DatabaseSchema,\n\tplatform: AbstractSqlPlatform,\n\tnamingStrategy: NamingStrategy\n) => {\n\tconst helper = platform.getSchemaHelper();\n\n\tif (!helper) throw new Error('cannot connect to database');\n\n\tconst metadata = schema\n\t\t.getTables()\n\t\t.sort((a, b) => a.name.localeCompare(b.name))\n\t\t.map((table) => {\n\t\t\tassertUniqueForeignKeys(table);\n\t\t\treturn table.getEntityDeclaration(namingStrategy, helper, 'never');\n\t\t});\n\n\tif (metadata.length === 0) {\n\t\tthrow new IntrospectionError(\n\t\t\t`Warning: No tables found, this database is empty.`,\n\t\t\t`Make sure you have tables in this database and then try again.`\n\t\t);\n\t}\n\n\tconvertToCamelCasePropertyNames(metadata);\n\tdetectManyToManyRelations(metadata);\n\tgenerateIdentifiedReferences(metadata);\n\tgenerateBidirectionalRelations(metadata);\n\tgenerateSingularTypeReferences(metadata);\n\n\treturn metadata;\n};\n\nconst openConnection = async (type: DatabaseType, options: ConnectionOptions) => {\n\t// eslint-disable-next-line @typescript-eslint/no-var-requires\n\tconst module = require(`@mikro-orm/${type}`);\n\tconst PLATFORMS = {\n\t\tmysql: 'MySqlDriver',\n\t\tpostgresql: 'PostgreSqlDriver',\n\t\tsqlite: 'SqliteDriver',\n\t};\n\tawait ConnectionManager.connect(CONNECTION_MANAGER_ID, {\n\t\tmikroOrmConfig: {\n\t\t\tdriver: module[PLATFORMS[type]],\n\t\t\t...options.mikroOrmConfig,\n\t\t},\n\t});\n};\n\nconst closeConnection = async () => {\n\tconsole.log('Closing database connection...');\n\tawait ConnectionManager.close(CONNECTION_MANAGER_ID);\n\tconsole.log('Database connection closed.');\n};\n\ntype File =\n\t| DataEntityFile\n\t| SchemaEntityFile\n\t| SchemaIndexFile\n\t| DataEntityIndexFile\n\t| DataSourceIndexFile\n\t| DatabaseFile;\n\nexport const generate = async (databaseType: DatabaseType, options: ConnectionOptions) => {\n\ttry {\n\t\tawait openConnection(databaseType, options);\n\n\t\tconst database = ConnectionManager.database(CONNECTION_MANAGER_ID);\n\t\tif (!database)\n\t\t\tthrow new IntrospectionError(\n\t\t\t\t`Warning: Unable to connect to database.`,\n\t\t\t\t'Please check the connection settings and try again'\n\t\t\t);\n\n\t\tconst config = database.em.config;\n\t\tconst driver = database.em.getDriver();\n\t\tconst platform = driver.getPlatform();\n\t\tconst namingStrategy = config.getNamingStrategy();\n\t\tconst connection = driver.getConnection();\n\n\t\tconsole.log('Fetching database schema...');\n\t\tconst schema = await DatabaseSchema.create(connection, platform, config);\n\t\tconsole.log('Building metadata...');\n\t\tconst metadata = await convertSchemaToMetadata(schema, platform, namingStrategy);\n\n\t\t// Build a lookup for efficient cross-referencing later.\n\t\tconst entityLookup = new Map<string, EntityMetadata<any>>();\n\t\tfor (const meta of metadata) {\n\t\t\tentityLookup.set(meta.className, meta);\n\t\t}\n\n\t\tconst source: File[] = [];\n\n\t\tconst summaryOfEntities: { name: string; entityFilePath: string; schemaFilePath: string }[] =\n\t\t\t[];\n\n\t\tfor (const meta of metadata) {\n\t\t\tif (!meta.pivotTable) {\n\t\t\t\tconst dataEntityFile = new DataEntityFile(meta, namingStrategy, platform, databaseType);\n\t\t\t\tconst schemaEntityFile = new SchemaEntityFile(meta, namingStrategy, platform, entityLookup);\n\t\t\t\tsource.push(dataEntityFile, schemaEntityFile);\n\t\t\t\tsummaryOfEntities.push({\n\t\t\t\t\tname: meta.className,\n\t\t\t\t\tentityFilePath: `${dataEntityFile.getBasePath()}${dataEntityFile.getBaseName()}`,\n\t\t\t\t\tschemaFilePath: `${schemaEntityFile.getBasePath()}${schemaEntityFile.getBaseName()}`,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\t// Export all the entities from the data source directory\n\t\tsource.push(new DataEntityIndexFile(metadata, databaseType));\n\t\t// Export the data source from the entities directory\n\t\tsource.push(new DataSourceIndexFile(databaseType));\n\t\t// Export the data source from the entities directory\n\t\tsource.push(new SchemaIndexFile(metadata));\n\t\t// Export the database connection to its own file\n\t\tsource.push(new DatabaseFile(databaseType, options));\n\n\t\tconst files = source.map((file) => {\n\t\t\treturn {\n\t\t\t\tpath: file.getBasePath(),\n\t\t\t\tname: file.getBaseName(),\n\t\t\t\tcontents: file.generate(),\n\t\t\t\tneedOverwriteWarning: !![DatabaseFile, SchemaIndexFile].some((cls) => file instanceof cls),\n\t\t\t};\n\t\t});\n\n\t\tawait closeConnection();\n\n\t\tconsole.log('\\nImport Summary:');\n\t\tconsole.table(summaryOfEntities);\n\t\tconsole.log(\n\t\t\t`\\nImported ${summaryOfEntities.length} entities, creating the above files in your Graphweaver project. \\n`\n\t\t);\n\n\t\treturn files;\n\t} catch (err) {\n\t\tif (err instanceof IntrospectionError) throw err;\n\n\t\tconsole.error('Got error during introspection:');\n\t\tconsole.error(err);\n\n\t\tthrow new IntrospectionError(\n\t\t\t`Warning: Unable to connect to database.`,\n\t\t\thasErrorMessage(err) ? err.message : 'Please check the connection settings and try again'\n\t\t);\n\t}\n};\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { DatabaseSchema, AbstractSqlPlatform, DatabaseTable } from '@mikro-orm/knex';\nimport {\n\tEntityMetadata,\n\tEntityProperty,\n\tNamingStrategy,\n\tReferenceKind,\n\tUtils,\n} from '@mikro-orm/core';\nimport pluralize from 'pluralize';\n\nimport { ConnectionManager, ConnectionOptions, DatabaseType } from '../database';\nimport {\n\tDataEntityFile,\n\tDataEntityIndexFile,\n\tDataSourceIndexFile,\n\tSchemaEntityFile,\n\tSchemaIndexFile,\n\tDatabaseFile,\n} from './files';\nimport { pascalToCamelCaseString } from './utils';\n\nconst CONNECTION_MANAGER_ID = 'generate';\n\nexport class IntrospectionError extends Error {\n\tprotected type: string;\n\tconstructor(\n\t\tprotected title = '',\n\t\tmessage = ''\n\t) {\n\t\tsuper(message);\n\t\tthis.type = 'IntrospectionError';\n\t\tthis.title = title;\n\t\tthis.message = message;\n\t}\n}\n\nconst hasErrorMessage = (error: any): error is { message: string } => error.message;\n\nconst generateBidirectionalRelations = (metadata: EntityMetadata[]): void => {\n\tconst nonPrimaryKeyReferenceErrors: string[] = [];\n\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tfor (const prop of meta.relations) {\n\t\t\tif (!prop.name.includes('Inverse')) {\n\t\t\t\tconst targetMeta = metadata.find((m) => m.className === prop.type);\n\t\t\t\tconst referencedTablePrimaryKeys = Utils.flatten(\n\t\t\t\t\t(targetMeta?.getPrimaryProps() ?? []).map((pk) => pk.fieldNames)\n\t\t\t\t);\n\n\t\t\t\t// Check any props that actually have fields in the database to store keys in for references to non-primary keys.\n\t\t\t\tif (prop.fieldNames?.length) {\n\t\t\t\t\tfor (const referencedColumn of prop.referencedColumnNames) {\n\t\t\t\t\t\tif (!referencedTablePrimaryKeys.includes(referencedColumn)) {\n\t\t\t\t\t\t\tnonPrimaryKeyReferenceErrors.push(\n\t\t\t\t\t\t\t\t` - Relationship between ${meta.className}.${prop.fieldNames.join(', ')} and ${targetMeta?.className}.${referencedColumn} is not supported.`\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst newProp = {\n\t\t\t\t\tname: prop.name + 'Inverse',\n\t\t\t\t\ttype: meta.className,\n\t\t\t\t\tjoinColumns: prop.fieldNames,\n\t\t\t\t\treferencedTableName: meta.tableName,\n\t\t\t\t\treferencedColumnNames: referencedTablePrimaryKeys,\n\t\t\t\t\tmappedBy: prop.name,\n\t\t\t\t} as EntityProperty;\n\n\t\t\t\t// Add reference to the inverse entity\n\t\t\t\tconst inverseMeta = metadata.find((m) => m.className === meta.className);\n\t\t\t\tconst inverseProp = inverseMeta?.props.find((p) => p.name === newProp.mappedBy);\n\t\t\t\tif (inverseProp) inverseProp.inversedBy = newProp.name;\n\n\t\t\t\tif (prop.kind === ReferenceKind.MANY_TO_ONE) {\n\t\t\t\t\tconst name = pascalToCamelCaseString(meta.className);\n\t\t\t\t\tnewProp.name = pluralize(name);\n\t\t\t\t\tnewProp.kind = ReferenceKind.ONE_TO_MANY;\n\t\t\t\t} else if (prop.kind === ReferenceKind.ONE_TO_ONE && !prop.mappedBy) {\n\t\t\t\t\tnewProp.kind = ReferenceKind.ONE_TO_ONE;\n\t\t\t\t\tnewProp.nullable = true;\n\t\t\t\t} else if (prop.kind === ReferenceKind.MANY_TO_MANY && !prop.mappedBy) {\n\t\t\t\t\tconst name = pascalToCamelCaseString(meta.className);\n\t\t\t\t\tnewProp.name = pluralize(name);\n\t\t\t\t\tnewProp.kind = ReferenceKind.MANY_TO_MANY;\n\t\t\t\t} else {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\ttargetMeta?.addProperty(newProp);\n\t\t\t}\n\t\t}\n\t}\n\n\tif (nonPrimaryKeyReferenceErrors.length) {\n\t\tthrow new IntrospectionError(\n\t\t\t`Unsupported Relationship${nonPrimaryKeyReferenceErrors.length === 1 ? '' : 's'} Detected`,\n\t\t\t`\\n${nonPrimaryKeyReferenceErrors.join('\\n')}\\n\\nForeign keys in Graphweaver currently need to reference the primary key of the other table.`\n\t\t);\n\t}\n};\n\nconst detectManyToManyRelations = (metadata: EntityMetadata[]) => {\n\tfor (const meta of metadata) {\n\t\tif (\n\t\t\tmeta.compositePK && // needs to have composite PK\n\t\t\tmeta.primaryKeys.length === meta.relations.length && // all relations are PKs\n\t\t\tmeta.relations.length === 2 && // there are exactly two relation properties\n\t\t\tmeta.relations.length === meta.props.length && // all properties are relations\n\t\t\tmeta.relations.every((prop) => prop.kind === ReferenceKind.MANY_TO_ONE) // all relations are m:1\n\t\t) {\n\t\t\tmeta.pivotTable = true;\n\t\t\tconst owner = metadata.find((m) => m.className === meta.relations[0].type);\n\t\t\tif (!owner) throw new Error('No Owner');\n\t\t\tconst name = pascalToCamelCaseString(meta.relations?.[1]?.type);\n\t\t\towner.addProperty({\n\t\t\t\tname: pluralize(name),\n\t\t\t\tkind: ReferenceKind.MANY_TO_MANY,\n\t\t\t\tpivotTable: meta.tableName,\n\t\t\t\ttype: meta.relations[1].type,\n\t\t\t\tjoinColumns: meta.relations[0].fieldNames,\n\t\t\t\tinverseJoinColumns: meta.relations[1].fieldNames,\n\t\t\t} as EntityProperty);\n\t\t}\n\t}\n};\n\nconst generateIdentifiedReferences = (metadata: EntityMetadata[]): void => {\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tfor (const prop of meta.relations) {\n\t\t\tif ([ReferenceKind.MANY_TO_ONE, ReferenceKind.ONE_TO_ONE].includes(prop.kind)) {\n\t\t\t\tconst name = pascalToCamelCaseString(prop.type);\n\t\t\t\tprop.name = pluralize.singular(name);\n\t\t\t\tprop.ref = true;\n\t\t\t}\n\t\t}\n\t}\n};\n\nconst generateSingularTypeReferences = (metadata: EntityMetadata[]): void => {\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tmeta.className = pluralize.singular(meta.className);\n\t\tfor (const prop of meta.relations) {\n\t\t\tprop.type = pluralize.singular(prop.type);\n\t\t}\n\t}\n};\n\n// Convert properties like FirstName to firstName\nconst convertToCamelCasePropertyNames = (metadata: EntityMetadata[]): void => {\n\tfor (const meta of metadata.filter((m) => !m.pivotTable)) {\n\t\tconst props = Object.values(meta.properties);\n\t\tprops.forEach((prop) => {\n\t\t\tprop.name = pascalToCamelCaseString(prop.name);\n\t\t});\n\t}\n};\n\nconst assertUniqueForeignKeys = (table: DatabaseTable): void => {\n\tconst uniqueForeignKeys = new Set();\n\tconst definedForeignKeys = Object.values(table.getForeignKeys());\n\n\tfor (const foreignKey of definedForeignKeys) {\n\t\tconst { localTableName, referencedTableName, columnNames, referencedColumnNames } = foreignKey;\n\t\tconst serializedValue = JSON.stringify({\n\t\t\tlocalTableName,\n\t\t\tcolumnNames: columnNames.sort(),\n\t\t\treferencedTableName,\n\t\t\treferencedColumnNames: referencedColumnNames.sort(),\n\t\t});\n\n\t\tif (uniqueForeignKeys.has(serializedValue)) {\n\t\t\tthrow new Error(\n\t\t\t\t`\\n\\nImport Failed: Duplicate foreign keys detected on column/s (${columnNames.toString()}) in table \"${\n\t\t\t\t\ttable.name\n\t\t\t\t}\".`\n\t\t\t);\n\t\t}\n\n\t\tuniqueForeignKeys.add(serializedValue);\n\t}\n};\n\nconst convertSchemaToMetadata = async (\n\tschema: DatabaseSchema,\n\tplatform: AbstractSqlPlatform,\n\tnamingStrategy: NamingStrategy\n) => {\n\tconst helper = platform.getSchemaHelper();\n\n\tif (!helper) throw new Error('cannot connect to database');\n\n\tconst metadata = schema\n\t\t.getTables()\n\t\t.sort((a, b) => a.name.localeCompare(b.name))\n\t\t.map((table) => {\n\t\t\tassertUniqueForeignKeys(table);\n\t\t\treturn table.getEntityDeclaration(namingStrategy, helper, 'never');\n\t\t});\n\n\tif (metadata.length === 0) {\n\t\tthrow new IntrospectionError(\n\t\t\t`Warning: No tables found, this database is empty.`,\n\t\t\t`Make sure you have tables in this database and then try again.`\n\t\t);\n\t}\n\n\tconvertToCamelCasePropertyNames(metadata);\n\tdetectManyToManyRelations(metadata);\n\tgenerateIdentifiedReferences(metadata);\n\tgenerateBidirectionalRelations(metadata);\n\tgenerateSingularTypeReferences(metadata);\n\n\treturn metadata;\n};\n\nconst openConnection = async (type: DatabaseType, options: ConnectionOptions) => {\n\t// eslint-disable-next-line @typescript-eslint/no-var-requires\n\tconst module = require(`@mikro-orm/${type}`);\n\tconst PLATFORMS = {\n\t\tmysql: 'MySqlDriver',\n\t\tpostgresql: 'PostgreSqlDriver',\n\t\tsqlite: 'SqliteDriver',\n\t};\n\tawait ConnectionManager.connect(CONNECTION_MANAGER_ID, {\n\t\tmikroOrmConfig: {\n\t\t\tdriver: module[PLATFORMS[type]],\n\t\t\t...options.mikroOrmConfig,\n\t\t},\n\t});\n};\n\nconst closeConnection = async () => {\n\tconsole.log('Closing database connection...');\n\tawait ConnectionManager.close(CONNECTION_MANAGER_ID);\n\tconsole.log('Database connection closed.');\n};\n\ntype File =\n\t| DataEntityFile\n\t| SchemaEntityFile\n\t| SchemaIndexFile\n\t| DataEntityIndexFile\n\t| DataSourceIndexFile\n\t| DatabaseFile;\n\nexport const generate = async (databaseType: DatabaseType, options: ConnectionOptions) => {\n\ttry {\n\t\tawait openConnection(databaseType, options);\n\n\t\tconst database = ConnectionManager.database(CONNECTION_MANAGER_ID);\n\t\tif (!database)\n\t\t\tthrow new IntrospectionError(\n\t\t\t\t`Warning: Unable to connect to database.`,\n\t\t\t\t'Please check the connection settings and try again'\n\t\t\t);\n\n\t\tconst config = database.em.config;\n\t\tconst driver = database.em.getDriver();\n\t\tconst platform = driver.getPlatform();\n\t\tconst namingStrategy = config.getNamingStrategy();\n\t\tconst connection = driver.getConnection();\n\n\t\tconsole.log('Fetching database schema...');\n\t\tconst schema = await DatabaseSchema.create(connection, platform, config);\n\t\tconsole.log('Building metadata...');\n\t\tconst metadata = await convertSchemaToMetadata(schema, platform, namingStrategy);\n\n\t\t// Build a lookup for efficient cross-referencing later.\n\t\tconst entityLookup = new Map<string, EntityMetadata<any>>();\n\t\tfor (const meta of metadata) {\n\t\t\tentityLookup.set(meta.className, meta);\n\t\t}\n\n\t\tconst source: File[] = [];\n\n\t\tconst summaryOfEntities: { name: string; entityFilePath: string; schemaFilePath: string }[] =\n\t\t\t[];\n\n\t\tfor (const meta of metadata) {\n\t\t\tif (!meta.pivotTable) {\n\t\t\t\tconst dataEntityFile = new DataEntityFile(meta, namingStrategy, platform, databaseType);\n\t\t\t\tconst schemaEntityFile = new SchemaEntityFile(meta, namingStrategy, platform, entityLookup);\n\t\t\t\tsource.push(dataEntityFile, schemaEntityFile);\n\t\t\t\tsummaryOfEntities.push({\n\t\t\t\t\tname: meta.className,\n\t\t\t\t\tentityFilePath: `${dataEntityFile.getBasePath()}${dataEntityFile.getBaseName()}`,\n\t\t\t\t\tschemaFilePath: `${schemaEntityFile.getBasePath()}${schemaEntityFile.getBaseName()}`,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\t// Export all the entities from the data source directory\n\t\tsource.push(new DataEntityIndexFile(metadata, databaseType));\n\t\t// Export the data source from the entities directory\n\t\tsource.push(new DataSourceIndexFile(databaseType));\n\t\t// Export the data source from the entities directory\n\t\tsource.push(new SchemaIndexFile(metadata));\n\t\t// Export the database connection to its own file\n\t\tsource.push(new DatabaseFile(databaseType, options));\n\n\t\tconst files = source.map((file) => {\n\t\t\treturn {\n\t\t\t\tpath: file.getBasePath(),\n\t\t\t\tname: file.getBaseName(),\n\t\t\t\tcontents: file.generate(),\n\t\t\t\tneedOverwriteWarning: !![DatabaseFile, SchemaIndexFile].some((cls) => file instanceof cls),\n\t\t\t};\n\t\t});\n\n\t\tawait closeConnection();\n\n\t\tconsole.log('\\nImport Summary:');\n\t\tconsole.table(summaryOfEntities);\n\t\tconsole.log(\n\t\t\t`\\nImported ${summaryOfEntities.length} entities, creating the above files in your Graphweaver project. \\n`\n\t\t);\n\n\t\treturn files;\n\t} catch (err) {\n\t\tif (err instanceof IntrospectionError) throw err;\n\n\t\tconsole.error('Got error during introspection:');\n\t\tconsole.error(err);\n\n\t\tthrow new IntrospectionError(\n\t\t\t`Warning: Unable to connect to database.`,\n\t\t\thasErrorMessage(err) ? err.message : 'Please check the connection settings and try again'\n\t\t);\n\t}\n};\n"],
5
+ "mappings": "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",
6
6
  "names": ["pluralize", "module"]
7
7
  }
@@ -1,4 +1,4 @@
1
- import { BackendProvider, PaginationOptions, Filter, BackendProviderConfig, FieldMetadata, AggregationResult, AggregationType, TraceOptions } from '@exogee/graphweaver';
1
+ import { BackendProvider, PaginationOptions, Filter, BackendProviderConfig, FieldMetadata, AggregationResult, AggregationType, TraceOptions, EntityMetadata } from '@exogee/graphweaver';
2
2
  import { IsolationLevel, ConnectionOptions } from '..';
3
3
  export declare const gqlToMikro: (filter: any) => any;
4
4
  export declare class MikroBackendProvider<D> implements BackendProvider<D> {
@@ -21,7 +21,7 @@ export declare class MikroBackendProvider<D> implements BackendProvider<D> {
21
21
  private applyExternalIdFields;
22
22
  visitPathForPopulate: (entityName: string, updateArgBranch: any, populateBranch?: string) => Set<string>;
23
23
  find(filter: Filter<D>, pagination?: PaginationOptions, trace?: TraceOptions): Promise<D[]>;
24
- findOne(filter: Filter<D>, trace?: TraceOptions): Promise<D | null>;
24
+ findOne(filter: Filter<D>, entityMetadata?: EntityMetadata, trace?: TraceOptions): Promise<D | null>;
25
25
  findByRelatedId(entity: any, relatedField: string, relatedFieldIds: string[], filter?: any, trace?: TraceOptions): Promise<D[]>;
26
26
  updateOne(id: string | number, updateArgs: Partial<D & {
27
27
  version?: number;
@@ -244,17 +244,21 @@ class MikroBackendProvider {
244
244
  }
245
245
  }
246
246
  }
247
- async findOne(filter, trace) {
247
+ async findOne(filter, entityMetadata, trace) {
248
248
  trace?.span.updateName(`Mikro-Orm - FindOne ${this.entityType.name}`);
249
249
  import_logger.logger.trace(`Running findOne ${this.entityType.name} with filter ${filter}`);
250
250
  const metadata = this.em.getMetadata().get(this.entityType.name);
251
- if (metadata.primaryKeys.length !== 1) {
251
+ let primaryKeyField = metadata.primaryKeys[0];
252
+ if (!primaryKeyField && entityMetadata) {
253
+ primaryKeyField = import_graphweaver.graphweaverMetadata.primaryKeyFieldForEntity(entityMetadata);
254
+ }
255
+ if (!primaryKeyField || metadata.primaryKeys.length > 1) {
252
256
  throw new Error(
253
257
  `Entity ${this.entityType.name} has ${metadata.primaryKeys.length} primary keys. We only support entities with a single primary key at this stage.`
254
258
  );
255
259
  }
256
260
  const [result] = await this.find(filter, {
257
- orderBy: { [metadata.primaryKeys[0]]: import_graphweaver.Sort.DESC },
261
+ orderBy: { [primaryKeyField]: import_graphweaver.Sort.DESC },
258
262
  offset: 0,
259
263
  limit: 1
260
264
  });
@@ -455,7 +459,6 @@ class MikroBackendProvider {
455
459
  const where = filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : void 0;
456
460
  const whereWithAppliedExternalIdFields = where ? this.applyExternalIdFields(this.entityType, where) : {};
457
461
  const query = this.em.createQueryBuilder(this.entityType);
458
- query.setFlag(import__.QueryFlag.DISTINCT);
459
462
  if (Object.keys(whereWithAppliedExternalIdFields).length > 0) {
460
463
  query.andWhere(whereWithAppliedExternalIdFields);
461
464
  }
@@ -463,7 +466,12 @@ class MikroBackendProvider {
463
466
  try {
464
467
  if (requestedAggregations.has(import_graphweaver.AggregationType.COUNT)) {
465
468
  const meta = this.database.em.getMetadata().get(this.entityType.name);
466
- result.count = await query.getCount(meta.primaryKeys);
469
+ if (meta.primaryKeys.length) {
470
+ result.count = await query.getCount(meta.primaryKeys, true);
471
+ } else {
472
+ const [firstRow] = await query.select(import_core.sql`count(*)`.as("count")).execute();
473
+ result.count = firstRow.count;
474
+ }
467
475
  }
468
476
  } catch (err) {
469
477
  import_logger.logger.error(`find ${this.entityType.name} error: ${JSON.stringify(err)}`);
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/provider/provider.ts"],
4
- "sourcesContent": ["import {\n\tBackendProvider,\n\tPaginationOptions,\n\tSort,\n\tFilter,\n\tBackendProviderConfig,\n\tFieldMetadata,\n\tAggregationResult,\n\tAggregationType,\n\tTraceMethod,\n\tTraceOptions,\n\ttraceSync,\n\ttrace as startTrace,\n\tGraphweaverRequestEvent,\n\tGraphweaverPluginNextFunction,\n} from '@exogee/graphweaver';\nimport { logger } from '@exogee/logger';\nimport { Reference, RequestContext } from '@mikro-orm/core';\nimport { AutoPath, PopulateHint } from '@mikro-orm/postgresql';\nimport { pluginManager, apolloPluginManager } from '@exogee/graphweaver-server';\n\nimport {\n\tLockMode,\n\tQueryFlag,\n\tReferenceKind,\n\tConnectionManager,\n\texternalIdFieldMap,\n\tAnyEntity,\n\tIsolationLevel,\n\tConnectionOptions,\n\tconnectToDatabase,\n} from '..';\n\nimport { OptimisticLockError } from '../utils/errors';\nimport { assign } from './assign';\n\ntype PostgresError = {\n\tcode: string;\n\troutine: string;\n};\n\nconst objectOperations = new Set(['_and', '_or', '_not']);\nconst mikroObjectOperations = new Set(['$and', '$or', '$not']);\n\nconst appendPath = (path: string, newPath: string) =>\n\tpath.length ? `${path}.${newPath}` : newPath;\n\nexport const gqlToMikro: (filter: any) => any = (filter: any) => {\n\tif (Array.isArray(filter)) {\n\t\treturn filter.map((element) => gqlToMikro(element));\n\t} else if (typeof filter === 'object') {\n\t\tfor (const key of Object.keys(filter)) {\n\t\t\t// A null here is a user-specified value and is valid to filter on\n\t\t\tif (filter[key] === null) continue;\n\n\t\t\tif (objectOperations.has(key)) {\n\t\t\t\t// { _not: '1' } => { $not: '1' }\n\t\t\t\tfilter[key.replace('_', '$')] = gqlToMikro(filter[key]);\n\t\t\t\tdelete filter[key];\n\t\t\t} else if (typeof filter[key] === 'object' && !Array.isArray(filter[key])) {\n\t\t\t\t// Recurse over nested filters only (arrays are an argument to a filter, not a nested filter)\n\t\t\t\tfilter[key] = gqlToMikro(filter[key]);\n\t\t\t} else if (key.indexOf('_') >= 0) {\n\t\t\t\t// { firstName_in: ['k', 'b'] } => { firstName: { $in: ['k', 'b'] } }\n\t\t\t\tconst [newKey, operator] = key.split('_');\n\t\t\t\tconst newValue = { [`$${operator}`]: gqlToMikro(filter[key]) };\n\n\t\t\t\t// They can construct multiple filters for the same key. In that case we need\n\t\t\t\t// to append them all into an object.\n\t\t\t\tif (typeof filter[newKey] !== 'undefined') {\n\t\t\t\t\tfilter[newKey] = { ...filter[newKey], ...newValue };\n\t\t\t\t} else {\n\t\t\t\t\tfilter[newKey] = newValue;\n\t\t\t\t}\n\n\t\t\t\tdelete filter[key];\n\t\t\t}\n\t\t}\n\t}\n\treturn filter;\n};\n\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport class MikroBackendProvider<D> implements BackendProvider<D> {\n\tprivate _backendId: string;\n\n\tprivate connection: ConnectionOptions;\n\n\tpublic entityType: new () => D;\n\tpublic connectionManagerId?: string;\n\tprivate transactionIsolationLevel!: IsolationLevel;\n\n\tpublic readonly supportsInFilter = true;\n\n\t// Default backend provider config\n\tpublic readonly backendProviderConfig: BackendProviderConfig = {\n\t\tfilter: true,\n\t\tpagination: false,\n\t\torderBy: false,\n\t\tsort: false,\n\t\tsupportedAggregationTypes: new Set<AggregationType>([AggregationType.COUNT]),\n\t};\n\n\tget backendId() {\n\t\treturn this._backendId;\n\t}\n\n\tprivate get database() {\n\t\t// If we have a connection manager ID then use that else fallback to the Database\n\t\tif (!this.connectionManagerId) return ConnectionManager.default;\n\t\treturn ConnectionManager.database(this.connectionManagerId) || ConnectionManager.default;\n\t}\n\n\t// This is exposed for use in the RLS package\n\tpublic get transactional() {\n\t\treturn this.database.transactional;\n\t}\n\n\tpublic async withTransaction<T>(callback: () => Promise<T>) {\n\t\treturn this.database.transactional<T>(callback, this.transactionIsolationLevel);\n\t}\n\n\t// This is exposed for use in the RLS package\n\tpublic get em() {\n\t\treturn this.database.em;\n\t}\n\n\tpublic constructor(\n\t\tmikroType: new () => D,\n\t\tconnection: ConnectionOptions,\n\t\ttransactionIsolationLevel: IsolationLevel = IsolationLevel.REPEATABLE_READ\n\t) {\n\t\tthis.entityType = mikroType;\n\t\tthis.connectionManagerId = connection.connectionManagerId;\n\t\tthis._backendId = `mikro-orm-${connection.connectionManagerId || ''}`;\n\t\tthis.transactionIsolationLevel = transactionIsolationLevel;\n\t\tthis.connection = connection;\n\t\tthis.addRequestContext();\n\t\tthis.connectToDatabase();\n\t}\n\n\tprivate connectToDatabase = async () => {\n\t\tconst connectionManagerId = this.connectionManagerId;\n\t\tif (!connectionManagerId) {\n\t\t\tthrow new Error('Expected connectionManagerId to be defined when calling addRequestContext.');\n\t\t}\n\n\t\tapolloPluginManager.addPlugin(connectionManagerId, connectToDatabase(this.connection));\n\t};\n\n\tprivate addRequestContext = () => {\n\t\tconst connectionManagerId = this.connectionManagerId;\n\t\tif (!connectionManagerId) {\n\t\t\tthrow new Error('Expected connectionManagerId to be defined when calling addRequestContext.');\n\t\t}\n\n\t\tconst connectionPlugin = {\n\t\t\tname: connectionManagerId,\n\t\t\tevent: GraphweaverRequestEvent.OnRequest,\n\t\t\tnext: (_: GraphweaverRequestEvent, _next: GraphweaverPluginNextFunction) => {\n\t\t\t\tlogger.trace(`Graphweaver OnRequest plugin called`);\n\n\t\t\t\tconst connection = ConnectionManager.database(connectionManagerId);\n\t\t\t\tif (!connection) throw new Error('No database connection found');\n\n\t\t\t\treturn RequestContext.create(connection.orm.em, _next, {});\n\t\t\t},\n\t\t};\n\t\tpluginManager.addPlugin(connectionPlugin);\n\t};\n\n\tprivate mapAndAssignKeys = (result: D, entityType: new () => D, inputArgs: Partial<D>) => {\n\t\t// Clean the input and remove any GraphQL classes from the object\n\t\tconst assignmentObj = this.applyExternalIdFields(entityType, inputArgs);\n\t\treturn assign(result, assignmentObj, undefined, undefined, this.database.em);\n\t};\n\n\tprivate applyExternalIdFields = (target: AnyEntity | string, values: any) => {\n\t\tconst targetName = typeof target === 'string' ? target : target.name;\n\t\tconst map = externalIdFieldMap.get(targetName);\n\n\t\tconst mapFieldNames = (partialFilterObj: any) => {\n\t\t\tfor (const [from, to] of Object.entries(map || {})) {\n\t\t\t\tif (partialFilterObj[from] && typeof partialFilterObj[from].id !== 'undefined') {\n\t\t\t\t\tif (Object.keys(partialFilterObj[from]).length > 1) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`Expected precisely 1 key called 'id' in queryObj.${from} on ${target}, got ${JSON.stringify(\n\t\t\t\t\t\t\t\tpartialFilterObj[from],\n\t\t\t\t\t\t\t\tnull,\n\t\t\t\t\t\t\t\t4\n\t\t\t\t\t\t\t)}`\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tpartialFilterObj[to] = partialFilterObj[from].id;\n\t\t\t\t\tdelete partialFilterObj[from];\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\t// Check for and/or/etc at the root level and handle correctly\n\t\tfor (const rootLevelKey of Object.keys(values)) {\n\t\t\tif (mikroObjectOperations.has(rootLevelKey)) {\n\t\t\t\tfor (const field of values[rootLevelKey]) {\n\t\t\t\t\tmapFieldNames(field);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t// Map the rest of the field names as well\n\t\tmapFieldNames(values);\n\n\t\t// Traverse the nested entities\n\t\tconst { properties } = this.database.em.getMetadata().get(targetName);\n\t\tObject.values(properties)\n\t\t\t.filter((property) => typeof property.entity !== 'undefined' && values[property.name])\n\t\t\t.forEach((property) => {\n\t\t\t\tif (Array.isArray(values[property.name])) {\n\t\t\t\t\tvalues[property.name].forEach((value: any) =>\n\t\t\t\t\t\tthis.applyExternalIdFields(property.type, value)\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tvalues[property.name] = this.applyExternalIdFields(property.type, values[property.name]);\n\t\t\t\t}\n\t\t\t});\n\n\t\treturn values;\n\t};\n\n\t// Check if we have any keys that are a collection of entities\n\tpublic visitPathForPopulate = (entityName: string, updateArgBranch: any, populateBranch = '') => {\n\t\tconst { properties } = this.database.em.getMetadata().get(entityName);\n\t\tconst collectedPaths = populateBranch ? new Set<string>([populateBranch]) : new Set<string>([]);\n\n\t\tfor (const [key, value] of Object.entries(updateArgBranch ?? {})) {\n\t\t\tif (\n\t\t\t\t// If it's a relationship, go ahead and and '.' it in, recurse.\n\t\t\t\tproperties[key]?.kind === ReferenceKind.ONE_TO_ONE ||\n\t\t\t\tproperties[key]?.kind === ReferenceKind.ONE_TO_MANY ||\n\t\t\t\tproperties[key]?.kind === ReferenceKind.MANY_TO_ONE ||\n\t\t\t\tproperties[key]?.kind === ReferenceKind.MANY_TO_MANY\n\t\t\t) {\n\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t// In the case where the array is empty we also need to make sure we load the collection.\n\t\t\t\t\tcollectedPaths.add(appendPath(populateBranch, key));\n\n\t\t\t\t\tfor (const entry of value) {\n\t\t\t\t\t\t// Recurse\n\t\t\t\t\t\tconst newPaths = this.visitPathForPopulate(\n\t\t\t\t\t\t\tproperties[key].type,\n\t\t\t\t\t\t\tentry,\n\t\t\t\t\t\t\tappendPath(populateBranch, key)\n\t\t\t\t\t\t);\n\t\t\t\t\t\tnewPaths.forEach((path) => collectedPaths.add(path));\n\t\t\t\t\t}\n\t\t\t\t} else if (typeof value === 'object') {\n\t\t\t\t\t// Recurse\n\t\t\t\t\tconst newPaths = this.visitPathForPopulate(\n\t\t\t\t\t\tproperties[key].type,\n\t\t\t\t\t\tvalue,\n\t\t\t\t\t\tappendPath(populateBranch, key)\n\t\t\t\t\t);\n\t\t\t\t\tnewPaths.forEach((path) => collectedPaths.add(path));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn collectedPaths;\n\t};\n\n\t@TraceMethod()\n\tpublic async find(\n\t\tfilter: Filter<D>,\n\t\tpagination?: PaginationOptions,\n\t\ttrace?: TraceOptions\n\t): Promise<D[]> {\n\t\t// If we have a span, update the name\n\t\ttrace?.span.updateName(`Mikro-Orm - Find ${this.entityType.name}`);\n\n\t\tlogger.trace(`Running find ${this.entityType.name} with filter`, {\n\t\t\tfilter: JSON.stringify(filter),\n\t\t});\n\n\t\t// Strip custom types out of the equation.\n\t\t// This query only works if we JSON.parse(JSON.stringify(filter)):\n\t\t//\n\t\t// query {\n\t\t// drivers (filter: { region: { name: \"North Shore\" }}) {\n\t\t// id\n\t\t// }\n\t\t// }\n\t\tconst where = traceSync((trace?: TraceOptions) => {\n\t\t\ttrace?.span.updateName('Convert filter to Mikro-Orm format');\n\t\t\treturn filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\t\t})();\n\n\t\t// Convert from: { account: {id: '6' }}\n\t\t// to { accountId: '6' }\n\t\t// This conversion only works on root level objects\n\t\tconst whereWithAppliedExternalIdFields = where\n\t\t\t? this.applyExternalIdFields(this.entityType, where)\n\t\t\t: {};\n\n\t\t// Regions need some fancy handling with Query Builder. Process the where further\n\t\t// and return a Query Builder instance.\n\t\tconst query = this.em.createQueryBuilder(this.entityType);\n\t\tif (Object.keys(whereWithAppliedExternalIdFields).length > 0) {\n\t\t\tquery.andWhere(whereWithAppliedExternalIdFields);\n\t\t}\n\n\t\t// If we have specified a limit, offset or order then update the query\n\t\tpagination?.limit && query.limit(pagination.limit);\n\t\tpagination?.offset && query.offset(pagination.offset);\n\t\tpagination?.orderBy && query.orderBy({ ...pagination.orderBy });\n\n\t\t// Certain query filters can result in duplicate records once all joins are resolved\n\t\t// These duplicates can be discarded as related entities are returned to the\n\t\t// API consumer via field resolvers\n\t\tquery.setFlag(QueryFlag.DISTINCT);\n\n\t\t// 1:1 relations that aren't on the owning side need to get populated so the references get set.\n\t\t// This method is protected, but we need to use it from here, hence the `as any`.\n\t\tconst driver = this.database.em.getDriver();\n\t\tconst meta = this.database.em.getMetadata().get(this.entityType.name);\n\t\tquery.populate((driver as any).autoJoinOneToOneOwner(meta, []));\n\n\t\ttry {\n\t\t\tconst result = await startTrace(async (trace?: TraceOptions) => {\n\t\t\t\ttrace?.span.updateName('Mikro-Orm - Fetch Data');\n\t\t\t\treturn query.getResult();\n\t\t\t})();\n\n\t\t\tlogger.trace(`find ${this.entityType.name} result: ${result.length} rows`);\n\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tlogger.error(`find ${this.entityType.name} error: ${JSON.stringify(err)}`);\n\n\t\t\tif ((err as PostgresError)?.routine === 'InitializeSessionUserId') {\n\t\t\t\t// Throw if the user credentials are incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct user credentials for the database.'\n\t\t\t\t);\n\t\t\t} else if ((err as PostgresError)?.code === 'ECONNREFUSED') {\n\t\t\t\t// Throw if the database address or port is incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct address and port for the database.'\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\t}\n\n\t@TraceMethod()\n\tpublic async findOne(filter: Filter<D>, trace?: TraceOptions): Promise<D | null> {\n\t\ttrace?.span.updateName(`Mikro-Orm - FindOne ${this.entityType.name}`);\n\t\tlogger.trace(`Running findOne ${this.entityType.name} with filter ${filter}`);\n\n\t\tconst metadata = this.em.getMetadata().get(this.entityType.name);\n\t\tif (metadata.primaryKeys.length !== 1) {\n\t\t\tthrow new Error(\n\t\t\t\t`Entity ${this.entityType.name} has ${metadata.primaryKeys.length} primary keys. We only support entities with a single primary key at this stage.`\n\t\t\t);\n\t\t}\n\n\t\tconst [result] = await this.find(filter, {\n\t\t\torderBy: { [metadata.primaryKeys[0]]: Sort.DESC },\n\t\t\toffset: 0,\n\t\t\tlimit: 1,\n\t\t});\n\n\t\tlogger.trace(`findOne ${this.entityType.name} result`, { result });\n\n\t\treturn result;\n\t}\n\n\t@TraceMethod()\n\tpublic async findByRelatedId(\n\t\tentity: any,\n\t\trelatedField: string,\n\t\trelatedFieldIds: string[],\n\t\tfilter?: any,\n\t\ttrace?: TraceOptions\n\t): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - findByRelatedId ${this.entityType.name}`);\n\t\tconst queryFilter = {\n\t\t\t$and: [{ [relatedField]: { $in: relatedFieldIds } }, ...[gqlToMikro(filter) ?? []]],\n\t\t};\n\n\t\tconst populate = [relatedField as AutoPath<typeof entity, PopulateHint>];\n\t\tconst result = await this.database.em.find(entity, queryFilter, {\n\t\t\tpopulate,\n\t\t});\n\n\t\treturn result as D[];\n\t}\n\n\t@TraceMethod()\n\tpublic async updateOne(\n\t\tid: string | number,\n\t\tupdateArgs: Partial<D & { version?: number }>,\n\t\ttrace?: TraceOptions\n\t): Promise<D> {\n\t\ttrace?.span.updateName(`Mikro-Orm - updateOne ${this.entityType.name}`);\n\n\t\tlogger.trace(`Running update ${this.entityType.name} with args`, {\n\t\t\tid,\n\t\t\tupdateArgs: JSON.stringify(updateArgs),\n\t\t});\n\n\t\tconst entity = await this.database.em.findOne(this.entityType, id, {\n\t\t\t// This is an optimisation so that assign() doesn't have to go fetch everything one at a time.\n\t\t\tpopulate: [...this.visitPathForPopulate(this.entityType.name, updateArgs)] as `${string}.`[],\n\t\t});\n\n\t\tif (entity === null) {\n\t\t\tthrow new Error(`Unable to locate ${this.entityType.name} with ID: '${id}' for updating.`);\n\t\t}\n\n\t\tconst { version, ...updateArgsWithoutVersion } = updateArgs;\n\n\t\t// If a version has been sent, let's check it\n\t\tif (version) {\n\t\t\ttry {\n\t\t\t\tawait this.database.em.lock(entity, LockMode.OPTIMISTIC, version);\n\t\t\t} catch (err) {\n\t\t\t\tthrow new OptimisticLockError((err as Error)?.message, { entity });\n\t\t\t}\n\t\t}\n\n\t\tawait this.mapAndAssignKeys(entity, this.entityType, updateArgsWithoutVersion as Partial<D>);\n\t\tawait this.database.em.persistAndFlush(entity);\n\n\t\tlogger.trace(`update ${this.entityType.name} entity`, entity);\n\n\t\treturn entity;\n\t}\n\n\t@TraceMethod()\n\tpublic async updateMany(\n\t\tupdateItems: (Partial<D> & { id: string })[],\n\t\ttrace?: TraceOptions\n\t): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - updateMany ${this.entityType.name}`);\n\t\tlogger.trace(`Running update many ${this.entityType.name} with args`, {\n\t\t\tupdateItems: JSON.stringify(updateItems),\n\t\t});\n\n\t\tconst entities = await this.database.transactional<D[]>(async () => {\n\t\t\treturn Promise.all<D>(\n\t\t\t\tupdateItems.map(async (item) => {\n\t\t\t\t\tif (!item?.id) throw new Error('You must pass an ID for this entity to update it.');\n\n\t\t\t\t\t// Find the entity in the database\n\t\t\t\t\tconst entity = await this.database.em.findOneOrFail(this.entityType, item.id, {\n\t\t\t\t\t\tpopulate: [...this.visitPathForPopulate(this.entityType.name, item)] as `${string}.`[],\n\t\t\t\t\t});\n\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\tthis.database.em.persist(entity);\n\t\t\t\t\treturn entity;\n\t\t\t\t})\n\t\t\t);\n\t\t});\n\n\t\tlogger.trace(`updated ${this.entityType.name} items `, entities);\n\n\t\treturn entities;\n\t}\n\n\t@TraceMethod()\n\tpublic async createOrUpdateMany(items: Partial<D>[], trace?: TraceOptions): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - createOrUpdateMany ${this.entityType.name}`);\n\t\tlogger.trace(`Running create or update many for ${this.entityType.name} with args`, {\n\t\t\titems: JSON.stringify(items),\n\t\t});\n\n\t\tconst entities = await this.database.transactional<D[]>(async () => {\n\t\t\treturn Promise.all<D>(\n\t\t\t\titems.map(async (item) => {\n\t\t\t\t\tlet entity;\n\t\t\t\t\tconst { id } = item as any;\n\t\t\t\t\tif (id) {\n\t\t\t\t\t\tentity = await this.database.em.findOneOrFail(this.entityType, id, {\n\t\t\t\t\t\t\tpopulate: [\n\t\t\t\t\t\t\t\t...this.visitPathForPopulate(this.entityType.name, item),\n\t\t\t\t\t\t\t] as `${string}.`[],\n\t\t\t\t\t\t});\n\t\t\t\t\t\tlogger.trace(`Running update on ${this.entityType.name} with item`, {\n\t\t\t\t\t\t\titem: JSON.stringify(item),\n\t\t\t\t\t\t});\n\t\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tentity = new this.entityType();\n\t\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\t\tlogger.trace(`Running create on ${this.entityType.name} with item`, {\n\t\t\t\t\t\t\titem: JSON.stringify(item),\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t\tthis.database.em.persist(entity);\n\t\t\t\t\treturn entity;\n\t\t\t\t})\n\t\t\t);\n\t\t});\n\n\t\tlogger.trace(`created or updated ${this.entityType.name} items `, entities);\n\n\t\treturn entities;\n\t}\n\n\t@TraceMethod()\n\tpublic async createOne(createArgs: Partial<D>, trace?: TraceOptions): Promise<D> {\n\t\ttrace?.span.updateName(`Mikro-Orm - createOne ${this.entityType.name}`);\n\t\tlogger.trace(`Running create ${this.entityType.name} with args`, {\n\t\t\tcreateArgs: JSON.stringify(createArgs),\n\t\t});\n\n\t\tconst entity = new this.entityType();\n\t\tawait this.mapAndAssignKeys(entity, this.entityType, createArgs);\n\t\tawait this.database.em.persistAndFlush(entity as Partial<D>);\n\n\t\tlogger.trace(`create ${this.entityType.name} result`, entity);\n\n\t\treturn entity;\n\t}\n\n\t@TraceMethod()\n\tpublic async createMany(createItems: Partial<D>[], trace?: TraceOptions): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - createMany ${this.entityType.name}`);\n\t\treturn this._createMany(createItems);\n\t}\n\n\tpublic async createTraces(createItems: Partial<D>[]): Promise<D[]> {\n\t\treturn this._createMany(createItems);\n\t}\n\n\tprivate async _createMany(createItems: Partial<D>[]) {\n\t\tlogger.trace(`Running create ${this.entityType.name} with args`, {\n\t\t\tcreateArgs: JSON.stringify(createItems),\n\t\t});\n\n\t\tconst entities = await this.database.transactional<D[]>(async () => {\n\t\t\treturn Promise.all<D>(\n\t\t\t\tcreateItems.map(async (item) => {\n\t\t\t\t\tconst entity = new this.entityType();\n\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\tthis.database.em.persist(entity as Partial<D>);\n\t\t\t\t\treturn entity;\n\t\t\t\t})\n\t\t\t);\n\t\t});\n\n\t\tlogger.trace(`created ${this.entityType.name} items `, entities);\n\n\t\treturn entities;\n\t}\n\n\t@TraceMethod()\n\tpublic async deleteOne(filter: Filter<D>, trace?: TraceOptions): Promise<boolean> {\n\t\ttrace?.span.updateName(`Mikro-Orm - deleteOne ${this.entityType.name}`);\n\t\tlogger.trace(filter, `Running delete ${this.entityType.name} with filter.`);\n\t\tconst where = filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\t\tconst whereWithAppliedExternalIdFields =\n\t\t\twhere && this.applyExternalIdFields(this.entityType, where);\n\n\t\tconst deletedRows = await this.database.em.nativeDelete(\n\t\t\tthis.entityType,\n\t\t\twhereWithAppliedExternalIdFields\n\t\t);\n\n\t\tif (deletedRows > 1) {\n\t\t\tthrow new Error('Multiple deleted rows');\n\t\t}\n\n\t\tlogger.trace(`delete ${this.entityType.name} result: deleted ${deletedRows} row(s)`);\n\n\t\treturn deletedRows === 1;\n\t}\n\n\t@TraceMethod()\n\tpublic async deleteMany(filter: Filter<D>, trace?: TraceOptions): Promise<boolean> {\n\t\ttrace?.span.updateName(`Mikro-Orm - deleteMany ${this.entityType.name}`);\n\t\tlogger.trace(`Running delete ${this.entityType.name}`);\n\n\t\tconst deletedRows = await this.database.transactional<number>(async () => {\n\t\t\tconst where = filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\t\t\tconst whereWithAppliedExternalIdFields =\n\t\t\t\twhere && this.applyExternalIdFields(this.entityType, where);\n\n\t\t\tconst toDelete = await this.database.em.count(\n\t\t\t\tthis.entityType,\n\t\t\t\twhereWithAppliedExternalIdFields\n\t\t\t);\n\t\t\tconst deletedCount = await this.database.em.nativeDelete(\n\t\t\t\tthis.entityType,\n\t\t\t\twhereWithAppliedExternalIdFields\n\t\t\t);\n\n\t\t\tif (deletedCount !== toDelete) {\n\t\t\t\tthrow new Error('We did not delete any rows, rolling back.');\n\t\t\t}\n\n\t\t\treturn deletedCount;\n\t\t});\n\n\t\tlogger.trace(`delete ${this.entityType.name} result: deleted ${deletedRows} row(s)`);\n\n\t\treturn true;\n\t}\n\n\tpublic foreignKeyForRelationshipField?(field: FieldMetadata, dataEntity: D) {\n\t\tconst value = dataEntity[field.name as keyof D];\n\n\t\tif (Reference.isReference(value)) {\n\t\t\tconst { properties } = this.database.em.getMetadata().get(this.entityType);\n\t\t\tconst property = properties[field.name];\n\t\t\tconst [primaryKey] = property.targetMeta?.primaryKeys ?? [];\n\t\t\tif (!primaryKey) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Could not determine primary key for ${field.name} on ${this.entityType.name}`\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tconst foreignKey = (value.unwrap() as any)[primaryKey];\n\t\t\tif (foreignKey === undefined || foreignKey === null) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Could not read foreign key from reference: ${value.unwrap()} with primary key name ${primaryKey}`\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn foreignKey;\n\t\t}\n\n\t\treturn null;\n\t}\n\n\t@TraceMethod()\n\tpublic async aggregate(\n\t\tfilter: Filter<D>,\n\t\trequestedAggregations: Set<AggregationType>,\n\t\ttrace?: TraceOptions\n\t): Promise<AggregationResult> {\n\t\ttrace?.span.updateName(`Mikro-Orm - aggregate ${this.entityType.name}`);\n\t\tlogger.trace(`Running aggregate ${this.entityType.name} with filter`, {\n\t\t\tfilter: JSON.stringify(filter),\n\t\t});\n\n\t\t// Strip custom types out of the equation.\n\t\t// This query only works if we JSON.parse(JSON.stringify(filter)):\n\t\t//\n\t\t// query {\n\t\t// drivers (filter: { region: { name: \"North Shore\" }}) {\n\t\t// id\n\t\t// }\n\t\t// }\n\t\tconst where = filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\n\t\t// Convert from: { account: {id: '6' }}\n\t\t// to { accountId: '6' }\n\t\t// This conversion only works on root level objects\n\t\tconst whereWithAppliedExternalIdFields = where\n\t\t\t? this.applyExternalIdFields(this.entityType, where)\n\t\t\t: {};\n\n\t\t// Regions need some fancy handling with Query Builder. Process the where further\n\t\t// and return a Query Builder instance.\n\t\tconst query = this.em.createQueryBuilder(this.entityType);\n\n\t\t// Certain query filters can result in duplicate records once all joins are resolved\n\t\t// These duplicates can be discarded as related entities are returned to the\n\t\t// API consumer via field resolvers\n\t\tquery.setFlag(QueryFlag.DISTINCT);\n\n\t\tif (Object.keys(whereWithAppliedExternalIdFields).length > 0) {\n\t\t\tquery.andWhere(whereWithAppliedExternalIdFields);\n\t\t}\n\n\t\tconst result: AggregationResult = {};\n\n\t\ttry {\n\t\t\tif (requestedAggregations.has(AggregationType.COUNT)) {\n\t\t\t\tconst meta = this.database.em.getMetadata().get(this.entityType.name);\n\t\t\t\tresult.count = await query.getCount(meta.primaryKeys);\n\t\t\t}\n\t\t} catch (err) {\n\t\t\tlogger.error(`find ${this.entityType.name} error: ${JSON.stringify(err)}`);\n\n\t\t\tif ((err as PostgresError)?.routine === 'InitializeSessionUserId') {\n\t\t\t\t// Throw if the user credentials are incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct user credentials for the database.'\n\t\t\t\t);\n\t\t\t} else if ((err as PostgresError)?.code === 'ECONNREFUSED') {\n\t\t\t\t// Throw if the database address or port is incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct address and port for the database.'\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t}\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import {\n\tBackendProvider,\n\tPaginationOptions,\n\tSort,\n\tFilter,\n\tBackendProviderConfig,\n\tFieldMetadata,\n\tAggregationResult,\n\tAggregationType,\n\tTraceMethod,\n\tTraceOptions,\n\ttraceSync,\n\ttrace as startTrace,\n\tGraphweaverRequestEvent,\n\tGraphweaverPluginNextFunction,\n\tEntityMetadata,\n\tgraphweaverMetadata,\n} from '@exogee/graphweaver';\nimport { logger } from '@exogee/logger';\nimport { Reference, RequestContext, sql } from '@mikro-orm/core';\nimport { AutoPath, PopulateHint } from '@mikro-orm/postgresql';\nimport { pluginManager, apolloPluginManager } from '@exogee/graphweaver-server';\n\nimport {\n\tLockMode,\n\tQueryFlag,\n\tReferenceKind,\n\tConnectionManager,\n\texternalIdFieldMap,\n\tAnyEntity,\n\tIsolationLevel,\n\tConnectionOptions,\n\tconnectToDatabase,\n} from '..';\n\nimport { OptimisticLockError } from '../utils/errors';\nimport { assign } from './assign';\n\ntype PostgresError = {\n\tcode: string;\n\troutine: string;\n};\n\nconst objectOperations = new Set(['_and', '_or', '_not']);\nconst mikroObjectOperations = new Set(['$and', '$or', '$not']);\n\nconst appendPath = (path: string, newPath: string) =>\n\tpath.length ? `${path}.${newPath}` : newPath;\n\nexport const gqlToMikro: (filter: any) => any = (filter: any) => {\n\tif (Array.isArray(filter)) {\n\t\treturn filter.map((element) => gqlToMikro(element));\n\t} else if (typeof filter === 'object') {\n\t\tfor (const key of Object.keys(filter)) {\n\t\t\t// A null here is a user-specified value and is valid to filter on\n\t\t\tif (filter[key] === null) continue;\n\n\t\t\tif (objectOperations.has(key)) {\n\t\t\t\t// { _not: '1' } => { $not: '1' }\n\t\t\t\tfilter[key.replace('_', '$')] = gqlToMikro(filter[key]);\n\t\t\t\tdelete filter[key];\n\t\t\t} else if (typeof filter[key] === 'object' && !Array.isArray(filter[key])) {\n\t\t\t\t// Recurse over nested filters only (arrays are an argument to a filter, not a nested filter)\n\t\t\t\tfilter[key] = gqlToMikro(filter[key]);\n\t\t\t} else if (key.indexOf('_') >= 0) {\n\t\t\t\t// { firstName_in: ['k', 'b'] } => { firstName: { $in: ['k', 'b'] } }\n\t\t\t\tconst [newKey, operator] = key.split('_');\n\t\t\t\tconst newValue = { [`$${operator}`]: gqlToMikro(filter[key]) };\n\n\t\t\t\t// They can construct multiple filters for the same key. In that case we need\n\t\t\t\t// to append them all into an object.\n\t\t\t\tif (typeof filter[newKey] !== 'undefined') {\n\t\t\t\t\tfilter[newKey] = { ...filter[newKey], ...newValue };\n\t\t\t\t} else {\n\t\t\t\t\tfilter[newKey] = newValue;\n\t\t\t\t}\n\n\t\t\t\tdelete filter[key];\n\t\t\t}\n\t\t}\n\t}\n\treturn filter;\n};\n\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport class MikroBackendProvider<D> implements BackendProvider<D> {\n\tprivate _backendId: string;\n\n\tprivate connection: ConnectionOptions;\n\n\tpublic entityType: new () => D;\n\tpublic connectionManagerId?: string;\n\tprivate transactionIsolationLevel!: IsolationLevel;\n\n\tpublic readonly supportsInFilter = true;\n\n\t// Default backend provider config\n\tpublic readonly backendProviderConfig: BackendProviderConfig = {\n\t\tfilter: true,\n\t\tpagination: false,\n\t\torderBy: false,\n\t\tsort: false,\n\t\tsupportedAggregationTypes: new Set<AggregationType>([AggregationType.COUNT]),\n\t};\n\n\tget backendId() {\n\t\treturn this._backendId;\n\t}\n\n\tprivate get database() {\n\t\t// If we have a connection manager ID then use that else fallback to the Database\n\t\tif (!this.connectionManagerId) return ConnectionManager.default;\n\t\treturn ConnectionManager.database(this.connectionManagerId) || ConnectionManager.default;\n\t}\n\n\t// This is exposed for use in the RLS package\n\tpublic get transactional() {\n\t\treturn this.database.transactional;\n\t}\n\n\tpublic async withTransaction<T>(callback: () => Promise<T>) {\n\t\treturn this.database.transactional<T>(callback, this.transactionIsolationLevel);\n\t}\n\n\t// This is exposed for use in the RLS package\n\tpublic get em() {\n\t\treturn this.database.em;\n\t}\n\n\tpublic constructor(\n\t\tmikroType: new () => D,\n\t\tconnection: ConnectionOptions,\n\t\ttransactionIsolationLevel: IsolationLevel = IsolationLevel.REPEATABLE_READ\n\t) {\n\t\tthis.entityType = mikroType;\n\t\tthis.connectionManagerId = connection.connectionManagerId;\n\t\tthis._backendId = `mikro-orm-${connection.connectionManagerId || ''}`;\n\t\tthis.transactionIsolationLevel = transactionIsolationLevel;\n\t\tthis.connection = connection;\n\t\tthis.addRequestContext();\n\t\tthis.connectToDatabase();\n\t}\n\n\tprivate connectToDatabase = async () => {\n\t\tconst connectionManagerId = this.connectionManagerId;\n\t\tif (!connectionManagerId) {\n\t\t\tthrow new Error('Expected connectionManagerId to be defined when calling addRequestContext.');\n\t\t}\n\n\t\tapolloPluginManager.addPlugin(connectionManagerId, connectToDatabase(this.connection));\n\t};\n\n\tprivate addRequestContext = () => {\n\t\tconst connectionManagerId = this.connectionManagerId;\n\t\tif (!connectionManagerId) {\n\t\t\tthrow new Error('Expected connectionManagerId to be defined when calling addRequestContext.');\n\t\t}\n\n\t\tconst connectionPlugin = {\n\t\t\tname: connectionManagerId,\n\t\t\tevent: GraphweaverRequestEvent.OnRequest,\n\t\t\tnext: (_: GraphweaverRequestEvent, _next: GraphweaverPluginNextFunction) => {\n\t\t\t\tlogger.trace(`Graphweaver OnRequest plugin called`);\n\n\t\t\t\tconst connection = ConnectionManager.database(connectionManagerId);\n\t\t\t\tif (!connection) throw new Error('No database connection found');\n\n\t\t\t\treturn RequestContext.create(connection.orm.em, _next, {});\n\t\t\t},\n\t\t};\n\t\tpluginManager.addPlugin(connectionPlugin);\n\t};\n\n\tprivate mapAndAssignKeys = (result: D, entityType: new () => D, inputArgs: Partial<D>) => {\n\t\t// Clean the input and remove any GraphQL classes from the object\n\t\tconst assignmentObj = this.applyExternalIdFields(entityType, inputArgs);\n\t\treturn assign(result, assignmentObj, undefined, undefined, this.database.em);\n\t};\n\n\tprivate applyExternalIdFields = (target: AnyEntity | string, values: any) => {\n\t\tconst targetName = typeof target === 'string' ? target : target.name;\n\t\tconst map = externalIdFieldMap.get(targetName);\n\n\t\tconst mapFieldNames = (partialFilterObj: any) => {\n\t\t\tfor (const [from, to] of Object.entries(map || {})) {\n\t\t\t\tif (partialFilterObj[from] && typeof partialFilterObj[from].id !== 'undefined') {\n\t\t\t\t\tif (Object.keys(partialFilterObj[from]).length > 1) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`Expected precisely 1 key called 'id' in queryObj.${from} on ${target}, got ${JSON.stringify(\n\t\t\t\t\t\t\t\tpartialFilterObj[from],\n\t\t\t\t\t\t\t\tnull,\n\t\t\t\t\t\t\t\t4\n\t\t\t\t\t\t\t)}`\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tpartialFilterObj[to] = partialFilterObj[from].id;\n\t\t\t\t\tdelete partialFilterObj[from];\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\t// Check for and/or/etc at the root level and handle correctly\n\t\tfor (const rootLevelKey of Object.keys(values)) {\n\t\t\tif (mikroObjectOperations.has(rootLevelKey)) {\n\t\t\t\tfor (const field of values[rootLevelKey]) {\n\t\t\t\t\tmapFieldNames(field);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t// Map the rest of the field names as well\n\t\tmapFieldNames(values);\n\n\t\t// Traverse the nested entities\n\t\tconst { properties } = this.database.em.getMetadata().get(targetName);\n\t\tObject.values(properties)\n\t\t\t.filter((property) => typeof property.entity !== 'undefined' && values[property.name])\n\t\t\t.forEach((property) => {\n\t\t\t\tif (Array.isArray(values[property.name])) {\n\t\t\t\t\tvalues[property.name].forEach((value: any) =>\n\t\t\t\t\t\tthis.applyExternalIdFields(property.type, value)\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tvalues[property.name] = this.applyExternalIdFields(property.type, values[property.name]);\n\t\t\t\t}\n\t\t\t});\n\n\t\treturn values;\n\t};\n\n\t// Check if we have any keys that are a collection of entities\n\tpublic visitPathForPopulate = (entityName: string, updateArgBranch: any, populateBranch = '') => {\n\t\tconst { properties } = this.database.em.getMetadata().get(entityName);\n\t\tconst collectedPaths = populateBranch ? new Set<string>([populateBranch]) : new Set<string>([]);\n\n\t\tfor (const [key, value] of Object.entries(updateArgBranch ?? {})) {\n\t\t\tif (\n\t\t\t\t// If it's a relationship, go ahead and and '.' it in, recurse.\n\t\t\t\tproperties[key]?.kind === ReferenceKind.ONE_TO_ONE ||\n\t\t\t\tproperties[key]?.kind === ReferenceKind.ONE_TO_MANY ||\n\t\t\t\tproperties[key]?.kind === ReferenceKind.MANY_TO_ONE ||\n\t\t\t\tproperties[key]?.kind === ReferenceKind.MANY_TO_MANY\n\t\t\t) {\n\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t// In the case where the array is empty we also need to make sure we load the collection.\n\t\t\t\t\tcollectedPaths.add(appendPath(populateBranch, key));\n\n\t\t\t\t\tfor (const entry of value) {\n\t\t\t\t\t\t// Recurse\n\t\t\t\t\t\tconst newPaths = this.visitPathForPopulate(\n\t\t\t\t\t\t\tproperties[key].type,\n\t\t\t\t\t\t\tentry,\n\t\t\t\t\t\t\tappendPath(populateBranch, key)\n\t\t\t\t\t\t);\n\t\t\t\t\t\tnewPaths.forEach((path) => collectedPaths.add(path));\n\t\t\t\t\t}\n\t\t\t\t} else if (typeof value === 'object') {\n\t\t\t\t\t// Recurse\n\t\t\t\t\tconst newPaths = this.visitPathForPopulate(\n\t\t\t\t\t\tproperties[key].type,\n\t\t\t\t\t\tvalue,\n\t\t\t\t\t\tappendPath(populateBranch, key)\n\t\t\t\t\t);\n\t\t\t\t\tnewPaths.forEach((path) => collectedPaths.add(path));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn collectedPaths;\n\t};\n\n\t@TraceMethod()\n\tpublic async find(\n\t\tfilter: Filter<D>,\n\t\tpagination?: PaginationOptions,\n\t\ttrace?: TraceOptions\n\t): Promise<D[]> {\n\t\t// If we have a span, update the name\n\t\ttrace?.span.updateName(`Mikro-Orm - Find ${this.entityType.name}`);\n\n\t\tlogger.trace(`Running find ${this.entityType.name} with filter`, {\n\t\t\tfilter: JSON.stringify(filter),\n\t\t});\n\n\t\t// Strip custom types out of the equation.\n\t\t// This query only works if we JSON.parse(JSON.stringify(filter)):\n\t\t//\n\t\t// query {\n\t\t// drivers (filter: { region: { name: \"North Shore\" }}) {\n\t\t// id\n\t\t// }\n\t\t// }\n\t\tconst where = traceSync((trace?: TraceOptions) => {\n\t\t\ttrace?.span.updateName('Convert filter to Mikro-Orm format');\n\t\t\treturn filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\t\t})();\n\n\t\t// Convert from: { account: {id: '6' }}\n\t\t// to { accountId: '6' }\n\t\t// This conversion only works on root level objects\n\t\tconst whereWithAppliedExternalIdFields = where\n\t\t\t? this.applyExternalIdFields(this.entityType, where)\n\t\t\t: {};\n\n\t\t// Regions need some fancy handling with Query Builder. Process the where further\n\t\t// and return a Query Builder instance.\n\t\tconst query = this.em.createQueryBuilder(this.entityType);\n\t\tif (Object.keys(whereWithAppliedExternalIdFields).length > 0) {\n\t\t\tquery.andWhere(whereWithAppliedExternalIdFields);\n\t\t}\n\n\t\t// If we have specified a limit, offset or order then update the query\n\t\tpagination?.limit && query.limit(pagination.limit);\n\t\tpagination?.offset && query.offset(pagination.offset);\n\t\tpagination?.orderBy && query.orderBy({ ...pagination.orderBy });\n\n\t\t// Certain query filters can result in duplicate records once all joins are resolved\n\t\t// These duplicates can be discarded as related entities are returned to the\n\t\t// API consumer via field resolvers\n\t\tquery.setFlag(QueryFlag.DISTINCT);\n\n\t\t// 1:1 relations that aren't on the owning side need to get populated so the references get set.\n\t\t// This method is protected, but we need to use it from here, hence the `as any`.\n\t\tconst driver = this.database.em.getDriver();\n\t\tconst meta = this.database.em.getMetadata().get(this.entityType.name);\n\t\tquery.populate((driver as any).autoJoinOneToOneOwner(meta, []));\n\n\t\ttry {\n\t\t\tconst result = await startTrace(async (trace?: TraceOptions) => {\n\t\t\t\ttrace?.span.updateName('Mikro-Orm - Fetch Data');\n\t\t\t\treturn query.getResult();\n\t\t\t})();\n\n\t\t\tlogger.trace(`find ${this.entityType.name} result: ${result.length} rows`);\n\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tlogger.error(`find ${this.entityType.name} error: ${JSON.stringify(err)}`);\n\n\t\t\tif ((err as PostgresError)?.routine === 'InitializeSessionUserId') {\n\t\t\t\t// Throw if the user credentials are incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct user credentials for the database.'\n\t\t\t\t);\n\t\t\t} else if ((err as PostgresError)?.code === 'ECONNREFUSED') {\n\t\t\t\t// Throw if the database address or port is incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct address and port for the database.'\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\t}\n\n\t@TraceMethod()\n\tpublic async findOne(\n\t\tfilter: Filter<D>,\n\t\tentityMetadata?: EntityMetadata,\n\t\ttrace?: TraceOptions\n\t): Promise<D | null> {\n\t\ttrace?.span.updateName(`Mikro-Orm - FindOne ${this.entityType.name}`);\n\t\tlogger.trace(`Running findOne ${this.entityType.name} with filter ${filter}`);\n\n\t\tconst metadata = this.em.getMetadata().get(this.entityType.name);\n\t\tlet primaryKeyField = metadata.primaryKeys[0];\n\n\t\tif (!primaryKeyField && entityMetadata) {\n\t\t\t// When using virtual entities, MikroORM will have no primary keys.\n\t\t\t// In this scenario we actually know what the primary key is from\n\t\t\t// the GraphQL metadata, so we can go ahead and use it.\n\t\t\tprimaryKeyField = graphweaverMetadata.primaryKeyFieldForEntity(entityMetadata);\n\t\t}\n\n\t\tif (!primaryKeyField || metadata.primaryKeys.length > 1) {\n\t\t\tthrow new Error(\n\t\t\t\t`Entity ${this.entityType.name} has ${metadata.primaryKeys.length} primary keys. We only support entities with a single primary key at this stage.`\n\t\t\t);\n\t\t}\n\n\t\tconst [result] = await this.find(filter, {\n\t\t\torderBy: { [primaryKeyField]: Sort.DESC },\n\t\t\toffset: 0,\n\t\t\tlimit: 1,\n\t\t});\n\n\t\tlogger.trace(`findOne ${this.entityType.name} result`, { result });\n\n\t\treturn result;\n\t}\n\n\t@TraceMethod()\n\tpublic async findByRelatedId(\n\t\tentity: any,\n\t\trelatedField: string,\n\t\trelatedFieldIds: string[],\n\t\tfilter?: any,\n\t\ttrace?: TraceOptions\n\t): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - findByRelatedId ${this.entityType.name}`);\n\t\tconst queryFilter = {\n\t\t\t$and: [{ [relatedField]: { $in: relatedFieldIds } }, ...[gqlToMikro(filter) ?? []]],\n\t\t};\n\n\t\tconst populate = [relatedField as AutoPath<typeof entity, PopulateHint>];\n\t\tconst result = await this.database.em.find(entity, queryFilter, {\n\t\t\tpopulate,\n\t\t});\n\n\t\treturn result as D[];\n\t}\n\n\t@TraceMethod()\n\tpublic async updateOne(\n\t\tid: string | number,\n\t\tupdateArgs: Partial<D & { version?: number }>,\n\t\ttrace?: TraceOptions\n\t): Promise<D> {\n\t\ttrace?.span.updateName(`Mikro-Orm - updateOne ${this.entityType.name}`);\n\n\t\tlogger.trace(`Running update ${this.entityType.name} with args`, {\n\t\t\tid,\n\t\t\tupdateArgs: JSON.stringify(updateArgs),\n\t\t});\n\n\t\tconst entity = await this.database.em.findOne(this.entityType, id, {\n\t\t\t// This is an optimisation so that assign() doesn't have to go fetch everything one at a time.\n\t\t\tpopulate: [...this.visitPathForPopulate(this.entityType.name, updateArgs)] as `${string}.`[],\n\t\t});\n\n\t\tif (entity === null) {\n\t\t\tthrow new Error(`Unable to locate ${this.entityType.name} with ID: '${id}' for updating.`);\n\t\t}\n\n\t\tconst { version, ...updateArgsWithoutVersion } = updateArgs;\n\n\t\t// If a version has been sent, let's check it\n\t\tif (version) {\n\t\t\ttry {\n\t\t\t\tawait this.database.em.lock(entity, LockMode.OPTIMISTIC, version);\n\t\t\t} catch (err) {\n\t\t\t\tthrow new OptimisticLockError((err as Error)?.message, { entity });\n\t\t\t}\n\t\t}\n\n\t\tawait this.mapAndAssignKeys(entity, this.entityType, updateArgsWithoutVersion as Partial<D>);\n\t\tawait this.database.em.persistAndFlush(entity);\n\n\t\tlogger.trace(`update ${this.entityType.name} entity`, entity);\n\n\t\treturn entity;\n\t}\n\n\t@TraceMethod()\n\tpublic async updateMany(\n\t\tupdateItems: (Partial<D> & { id: string })[],\n\t\ttrace?: TraceOptions\n\t): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - updateMany ${this.entityType.name}`);\n\t\tlogger.trace(`Running update many ${this.entityType.name} with args`, {\n\t\t\tupdateItems: JSON.stringify(updateItems),\n\t\t});\n\n\t\tconst entities = await this.database.transactional<D[]>(async () => {\n\t\t\treturn Promise.all<D>(\n\t\t\t\tupdateItems.map(async (item) => {\n\t\t\t\t\tif (!item?.id) throw new Error('You must pass an ID for this entity to update it.');\n\n\t\t\t\t\t// Find the entity in the database\n\t\t\t\t\tconst entity = await this.database.em.findOneOrFail(this.entityType, item.id, {\n\t\t\t\t\t\tpopulate: [...this.visitPathForPopulate(this.entityType.name, item)] as `${string}.`[],\n\t\t\t\t\t});\n\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\tthis.database.em.persist(entity);\n\t\t\t\t\treturn entity;\n\t\t\t\t})\n\t\t\t);\n\t\t});\n\n\t\tlogger.trace(`updated ${this.entityType.name} items `, entities);\n\n\t\treturn entities;\n\t}\n\n\t@TraceMethod()\n\tpublic async createOrUpdateMany(items: Partial<D>[], trace?: TraceOptions): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - createOrUpdateMany ${this.entityType.name}`);\n\t\tlogger.trace(`Running create or update many for ${this.entityType.name} with args`, {\n\t\t\titems: JSON.stringify(items),\n\t\t});\n\n\t\tconst entities = await this.database.transactional<D[]>(async () => {\n\t\t\treturn Promise.all<D>(\n\t\t\t\titems.map(async (item) => {\n\t\t\t\t\tlet entity;\n\t\t\t\t\tconst { id } = item as any;\n\t\t\t\t\tif (id) {\n\t\t\t\t\t\tentity = await this.database.em.findOneOrFail(this.entityType, id, {\n\t\t\t\t\t\t\tpopulate: [\n\t\t\t\t\t\t\t\t...this.visitPathForPopulate(this.entityType.name, item),\n\t\t\t\t\t\t\t] as `${string}.`[],\n\t\t\t\t\t\t});\n\t\t\t\t\t\tlogger.trace(`Running update on ${this.entityType.name} with item`, {\n\t\t\t\t\t\t\titem: JSON.stringify(item),\n\t\t\t\t\t\t});\n\t\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tentity = new this.entityType();\n\t\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\t\tlogger.trace(`Running create on ${this.entityType.name} with item`, {\n\t\t\t\t\t\t\titem: JSON.stringify(item),\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t\tthis.database.em.persist(entity);\n\t\t\t\t\treturn entity;\n\t\t\t\t})\n\t\t\t);\n\t\t});\n\n\t\tlogger.trace(`created or updated ${this.entityType.name} items `, entities);\n\n\t\treturn entities;\n\t}\n\n\t@TraceMethod()\n\tpublic async createOne(createArgs: Partial<D>, trace?: TraceOptions): Promise<D> {\n\t\ttrace?.span.updateName(`Mikro-Orm - createOne ${this.entityType.name}`);\n\t\tlogger.trace(`Running create ${this.entityType.name} with args`, {\n\t\t\tcreateArgs: JSON.stringify(createArgs),\n\t\t});\n\n\t\tconst entity = new this.entityType();\n\t\tawait this.mapAndAssignKeys(entity, this.entityType, createArgs);\n\t\tawait this.database.em.persistAndFlush(entity as Partial<D>);\n\n\t\tlogger.trace(`create ${this.entityType.name} result`, entity);\n\n\t\treturn entity;\n\t}\n\n\t@TraceMethod()\n\tpublic async createMany(createItems: Partial<D>[], trace?: TraceOptions): Promise<D[]> {\n\t\ttrace?.span.updateName(`Mikro-Orm - createMany ${this.entityType.name}`);\n\t\treturn this._createMany(createItems);\n\t}\n\n\tpublic async createTraces(createItems: Partial<D>[]): Promise<D[]> {\n\t\treturn this._createMany(createItems);\n\t}\n\n\tprivate async _createMany(createItems: Partial<D>[]) {\n\t\tlogger.trace(`Running create ${this.entityType.name} with args`, {\n\t\t\tcreateArgs: JSON.stringify(createItems),\n\t\t});\n\n\t\tconst entities = await this.database.transactional<D[]>(async () => {\n\t\t\treturn Promise.all<D>(\n\t\t\t\tcreateItems.map(async (item) => {\n\t\t\t\t\tconst entity = new this.entityType();\n\t\t\t\t\tawait this.mapAndAssignKeys(entity, this.entityType, item);\n\t\t\t\t\tthis.database.em.persist(entity as Partial<D>);\n\t\t\t\t\treturn entity;\n\t\t\t\t})\n\t\t\t);\n\t\t});\n\n\t\tlogger.trace(`created ${this.entityType.name} items `, entities);\n\n\t\treturn entities;\n\t}\n\n\t@TraceMethod()\n\tpublic async deleteOne(filter: Filter<D>, trace?: TraceOptions): Promise<boolean> {\n\t\ttrace?.span.updateName(`Mikro-Orm - deleteOne ${this.entityType.name}`);\n\t\tlogger.trace(filter, `Running delete ${this.entityType.name} with filter.`);\n\t\tconst where = filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\t\tconst whereWithAppliedExternalIdFields =\n\t\t\twhere && this.applyExternalIdFields(this.entityType, where);\n\n\t\tconst deletedRows = await this.database.em.nativeDelete(\n\t\t\tthis.entityType,\n\t\t\twhereWithAppliedExternalIdFields\n\t\t);\n\n\t\tif (deletedRows > 1) {\n\t\t\tthrow new Error('Multiple deleted rows');\n\t\t}\n\n\t\tlogger.trace(`delete ${this.entityType.name} result: deleted ${deletedRows} row(s)`);\n\n\t\treturn deletedRows === 1;\n\t}\n\n\t@TraceMethod()\n\tpublic async deleteMany(filter: Filter<D>, trace?: TraceOptions): Promise<boolean> {\n\t\ttrace?.span.updateName(`Mikro-Orm - deleteMany ${this.entityType.name}`);\n\t\tlogger.trace(`Running delete ${this.entityType.name}`);\n\n\t\tconst deletedRows = await this.database.transactional<number>(async () => {\n\t\t\tconst where = filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\t\t\tconst whereWithAppliedExternalIdFields =\n\t\t\t\twhere && this.applyExternalIdFields(this.entityType, where);\n\n\t\t\tconst toDelete = await this.database.em.count(\n\t\t\t\tthis.entityType,\n\t\t\t\twhereWithAppliedExternalIdFields\n\t\t\t);\n\t\t\tconst deletedCount = await this.database.em.nativeDelete(\n\t\t\t\tthis.entityType,\n\t\t\t\twhereWithAppliedExternalIdFields\n\t\t\t);\n\n\t\t\tif (deletedCount !== toDelete) {\n\t\t\t\tthrow new Error('We did not delete any rows, rolling back.');\n\t\t\t}\n\n\t\t\treturn deletedCount;\n\t\t});\n\n\t\tlogger.trace(`delete ${this.entityType.name} result: deleted ${deletedRows} row(s)`);\n\n\t\treturn true;\n\t}\n\n\tpublic foreignKeyForRelationshipField?(field: FieldMetadata, dataEntity: D) {\n\t\tconst value = dataEntity[field.name as keyof D];\n\n\t\tif (Reference.isReference(value)) {\n\t\t\tconst { properties } = this.database.em.getMetadata().get(this.entityType);\n\t\t\tconst property = properties[field.name];\n\t\t\tconst [primaryKey] = property.targetMeta?.primaryKeys ?? [];\n\t\t\tif (!primaryKey) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Could not determine primary key for ${field.name} on ${this.entityType.name}`\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tconst foreignKey = (value.unwrap() as any)[primaryKey];\n\t\t\tif (foreignKey === undefined || foreignKey === null) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Could not read foreign key from reference: ${value.unwrap()} with primary key name ${primaryKey}`\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn foreignKey;\n\t\t}\n\n\t\treturn null;\n\t}\n\n\t@TraceMethod()\n\tpublic async aggregate(\n\t\tfilter: Filter<D>,\n\t\trequestedAggregations: Set<AggregationType>,\n\t\ttrace?: TraceOptions\n\t): Promise<AggregationResult> {\n\t\ttrace?.span.updateName(`Mikro-Orm - aggregate ${this.entityType.name}`);\n\t\tlogger.trace(`Running aggregate ${this.entityType.name} with filter`, {\n\t\t\tfilter: JSON.stringify(filter),\n\t\t});\n\n\t\t// Strip custom types out of the equation.\n\t\t// This query only works if we JSON.parse(JSON.stringify(filter)):\n\t\t//\n\t\t// query {\n\t\t// drivers (filter: { region: { name: \"North Shore\" }}) {\n\t\t// id\n\t\t// }\n\t\t// }\n\t\tconst where = filter ? gqlToMikro(JSON.parse(JSON.stringify(filter))) : undefined;\n\n\t\t// Convert from: { account: {id: '6' }}\n\t\t// to { accountId: '6' }\n\t\t// This conversion only works on root level objects\n\t\tconst whereWithAppliedExternalIdFields = where\n\t\t\t? this.applyExternalIdFields(this.entityType, where)\n\t\t\t: {};\n\n\t\t// Regions need some fancy handling with Query Builder. Process the where further\n\t\t// and return a Query Builder instance.\n\t\tconst query = this.em.createQueryBuilder(this.entityType);\n\n\t\tif (Object.keys(whereWithAppliedExternalIdFields).length > 0) {\n\t\t\tquery.andWhere(whereWithAppliedExternalIdFields);\n\t\t}\n\n\t\tconst result: AggregationResult = {};\n\n\t\ttry {\n\t\t\tif (requestedAggregations.has(AggregationType.COUNT)) {\n\t\t\t\tconst meta = this.database.em.getMetadata().get(this.entityType.name);\n\t\t\t\tif (meta.primaryKeys.length) {\n\t\t\t\t\t// It's a standard entity with primary keys, we can do a full distinct\n\t\t\t\t\t// on these keys.\n\t\t\t\t\tresult.count = await query.getCount(meta.primaryKeys, true);\n\t\t\t\t} else {\n\t\t\t\t\t// It's either a virtual entity, or it's an entity without primary keys.\n\t\t\t\t\t// We just need to count * as a fallback, no distinct.\n\t\t\t\t\tconst [firstRow] = await query.select(sql`count(*)`.as('count')).execute();\n\t\t\t\t\tresult.count = firstRow.count;\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (err) {\n\t\t\tlogger.error(`find ${this.entityType.name} error: ${JSON.stringify(err)}`);\n\n\t\t\tif ((err as PostgresError)?.routine === 'InitializeSessionUserId') {\n\t\t\t\t// Throw if the user credentials are incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct user credentials for the database.'\n\t\t\t\t);\n\t\t\t} else if ((err as PostgresError)?.code === 'ECONNREFUSED') {\n\t\t\t\t// Throw if the database address or port is incorrect\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Database connection failed, please check you are using the correct address and port for the database.'\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t}\n}\n"],
5
+ "mappings": "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",
6
6
  "names": ["trace", "startTrace"]
7
7
  }
package/package.json CHANGED
@@ -1,8 +1,8 @@
1
1
  {
2
2
  "name": "@exogee/graphweaver-mikroorm",
3
- "version": "2.0.7",
3
+ "version": "2.2.0",
4
4
  "description": "MikroORM backend for @exogee/graphweaver",
5
- "license": "MIT",
5
+ "license": "Apache-2.0",
6
6
  "main": "lib/index.js",
7
7
  "source": "src/index.ts",
8
8
  "directories": {
@@ -13,39 +13,39 @@
13
13
  ],
14
14
  "dependencies": {
15
15
  "@apollo/server": "4.10.5",
16
- "@aws-sdk/client-secrets-manager": "3.621.0",
16
+ "@aws-sdk/client-secrets-manager": "3.624.0",
17
17
  "dataloader": "2.2.2",
18
18
  "decimal.js": "10.4.3",
19
19
  "dotenv": "16.4.5",
20
20
  "graphql": "16.9.0",
21
21
  "pluralize": "8.0.0",
22
22
  "reflect-metadata": "0.2.2",
23
- "@exogee/logger": "2.0.7",
24
- "@exogee/graphweaver": "2.0.7",
25
- "@exogee/graphweaver-server": "2.0.7"
23
+ "@exogee/graphweaver": "2.2.0",
24
+ "@exogee/graphweaver-server": "2.2.0",
25
+ "@exogee/logger": "2.2.0"
26
26
  },
27
27
  "devDependencies": {
28
- "@mikro-orm/core": "6.3.1",
29
- "@mikro-orm/knex": "6.3.1",
30
- "@mikro-orm/mysql": "6.3.1",
31
- "@mikro-orm/postgresql": "6.3.1",
32
- "@mikro-orm/sqlite": "6.3.1",
33
- "@types/node": "22.0.0",
28
+ "@mikro-orm/core": "6.3.4",
29
+ "@mikro-orm/knex": "6.3.4",
30
+ "@mikro-orm/mysql": "6.3.4",
31
+ "@mikro-orm/postgresql": "6.3.4",
32
+ "@mikro-orm/sqlite": "6.3.4",
33
+ "@types/node": "22.1.0",
34
34
  "@types/pluralize": "0.0.33",
35
35
  "esbuild": "0.23.0",
36
36
  "glob": "10.4.3",
37
- "ts-node": "10.9.2",
37
+ "tsx": "4.16.5",
38
38
  "typescript": "5.5.4"
39
39
  },
40
40
  "optionalDependencies": {
41
- "@mikro-orm/knex": "6.3.1",
42
- "@mikro-orm/mysql": "6.3.1",
43
- "@mikro-orm/postgresql": "6.3.1",
44
- "@mikro-orm/sqlite": "6.3.1"
41
+ "@mikro-orm/knex": "6.3.4",
42
+ "@mikro-orm/mysql": "6.3.4",
43
+ "@mikro-orm/postgresql": "6.3.4",
44
+ "@mikro-orm/sqlite": "6.3.4"
45
45
  },
46
46
  "peerDependencies": {
47
- "@mikro-orm/core": "6.3.1",
48
- "@mikro-orm/knex": "6.3.1"
47
+ "@mikro-orm/core": "6.3.4",
48
+ "@mikro-orm/knex": "6.3.4"
49
49
  },
50
50
  "keywords": [
51
51
  "graphql",
@@ -61,9 +61,10 @@
61
61
  "build": "npm run build:js && npm run build:types",
62
62
  "build:js": "node build.js",
63
63
  "build:types": "tsc --emitDeclarationOnly",
64
+ "generate:schema": "tsx ./src/utils/generate-db-schema.ts",
64
65
  "package:pack": "pnpm pack",
65
66
  "prettier": "prettier --write src/**/*.ts",
66
- "generate:schema": "ts-node ./src/utils/generate-db-schema.ts",
67
+ "test-introspection": "tsx scripts/test-introspection.ts",
67
68
  "version": "npm version --no-git-tag-version"
68
69
  }
69
70
  }