@jazim/test 2.0.2 → 2.0.3
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.
- package/dist/index.js.map +1 -1
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/lib/handlerbar.ts","../src/helpers.ts","../src/generate-migration.ts","../src/generate-entity.ts","../src/adapter.ts"],"names":["Handlebars","fs","Equal","Not","LessThan","LessThanOrEqual","MoreThan","MoreThanOrEqual","In","Like","dataSource","BetterAuthError","adapter","createAdapterFactory"],"mappings":"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","file":"index.js","sourcesContent":["import Handlebars from \"handlebars\";\n\nHandlebars.registerHelper(\"upper\", (str: string) => str.toUpperCase());\n\nHandlebars.registerHelper(\"quoteJoin\", function (array: string[]) {\n return array.map((item) => `\"${item}\"`).join(\", \");\n});\n\nexport { Handlebars };\n","import { DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\n\nexport const mapBetterAuthTypeToDBType = (\n betterAuthType: DBFieldAttribute[\"type\"],\n provider: Provider,\n isBigInt: boolean = false\n): string => {\n if (Array.isArray(betterAuthType)) {\n return betterAuthType[0] || \"varchar\";\n }\n\n let dbType = \"\";\n\n switch (betterAuthType) {\n case \"string\":\n dbType = \"varchar\";\n break;\n case \"boolean\":\n dbType = \"boolean\";\n break;\n case \"number\":\n dbType = provider === \"sqlite\" ? \"integer\" : \"int\";\n dbType = isBigInt && provider === \"sqlite\" ? dbType : \"bigint\";\n break;\n case \"date\":\n dbType = provider === \"postgres\" ? \"timestamp\" : \"datetime\";\n break;\n case \"json\":\n dbType = provider === \"sqlite\" ? \"text\" : \"json\";\n break;\n default:\n dbType = \"varchar\";\n break;\n }\n\n return dbType;\n};\n","import { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class MigrationGenerator {\n constructor(private readonly provider: Provider) {}\n\n async generate(authDbSchema: BetterAuthDBSchema) {\n const timestamp = Date.now();\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const tableInfo: TableDefinition = {\n name: name,\n columns: [],\n fkConstraints: [],\n };\n\n this.generatePrimaryKeyColumn(tableInfo);\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(migrationTemplate);\n\n const migrationCode = template({\n timestamp,\n tables: tableDefinitions,\n tablesReversed: [...tableDefinitions].reverse(),\n });\n\n return { code: migrationCode, migrationFileName: `${timestamp}-BetterAuthMigration.ts` };\n }\n\n private generatePrimaryKeyColumn(tableInfo: TableDefinition) {\n const column = {\n name: \"id\",\n type: this.provider === \"postgres\" ? \"uuid\" : \"varchar\",\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"uuid\",\n } as TableDefinition[\"columns\"][0];\n\n tableInfo.columns.push(column);\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n}\n\nexport interface TableDefinition {\n name: string;\n entityName?: string;\n columns: {\n name: string;\n type: string;\n isNullable?: boolean;\n isUnique?: boolean;\n default?: any;\n isPrimary?: boolean;\n isGenerated?: boolean;\n generationStrategy?: \"uuid\" | \"increment\";\n }[];\n fkConstraints: {\n columnNames: string[];\n referencedColumnNames: string[];\n referencedTableName: string;\n onDelete: string;\n }[];\n}\n\nconst migrationTemplate = `import { MigrationInterface, QueryRunner, Table } from \"typeorm\";\n\nexport class BetterAuthMigration{{timestamp}} implements MigrationInterface {\n public async up(queryRunner: QueryRunner): Promise<void> {\n{{#each tables}}\n await queryRunner.createTable(\n new Table({\n name: \"{{name}}\",\n columns: [\n{{#each columns}}\n {\n name: \"{{name}}\",\n type: \"{{type}}\",\n{{#if isPrimary}}\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"{{generationStrategy}}\",\n{{/if}}\n{{#if isNullable}}\n isNullable: {{isNullable}},\n{{/if}}\n{{#if isUnique}}\n isUnique: true,\n{{/if}}\n },\n{{/each}}\n ],\n{{#if fkConstraints.length}}\n foreignKeys: [\n{{#each fkConstraints}}\n {\n columnNames: [{{{quoteJoin columnNames}}}],\n referencedTableName: \"{{referencedTableName}}\",\n referencedColumnNames: [{{{quoteJoin referencedColumnNames}}}],\n onDelete: \"{{onDelete}}\",\n },\n{{/each}}\n ],\n{{/if}}\n })\n );\n{{/each}}\n }\n\n public async down(queryRunner: QueryRunner): Promise<void> {\n{{#each tablesReversed}}\n await queryRunner.dropTable(\"{{name}}\");\n{{/each}}\n }\n}\n`;\n","import fs from \"fs/promises\";\nimport { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { TableDefinition } from \"./generate-migration\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class EntityGenerator {\n constructor(private readonly provider: Provider) {}\n\n async generate(\n authDbSchema: BetterAuthDBSchema,\n entitiesPath: string,\n mappedEntities?: Record<string, any>\n ) {\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const entityName = mappedEntities ? mappedEntities[name] : undefined;\n const tableInfo: TableDefinition = {\n name: name,\n entityName: entityName,\n columns: [],\n fkConstraints: [],\n };\n\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(entityTemplate);\n\n const entityCode = template({\n tables: tableDefinitions.map((table) => ({\n ...table,\n columns: table.columns.map((column) => ({\n ...column,\n tsType: this.mapDBTypeToTSType(column.type, column.isNullable),\n })),\n fkConstraints: table.fkConstraints.map((fk) => ({\n ...fk,\n referencedTable: fk.referencedTableName,\n referencedEntity: mappedEntities\n ? mappedEntities[fk.referencedTableName]\n : fk.referencedTableName,\n columnName: fk.columnNames[0],\n })),\n })),\n });\n\n // check if entitiesPath exists, if not create it\n try {\n await fs.access(entitiesPath);\n } catch {\n await fs.mkdir(entitiesPath, { recursive: true });\n } finally {\n await fs.writeFile(`${entitiesPath}/auth.ts`, entityCode);\n }\n\n return entityCode;\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n\n private mapDBTypeToTSType(dbType: string, isNullable?: boolean): string {\n let tsType: string;\n\n switch (dbType) {\n case \"varchar\":\n case \"text\":\n case \"json\":\n tsType = \"string\";\n break;\n case \"boolean\":\n tsType = \"boolean\";\n break;\n case \"int\":\n case \"integer\":\n case \"bigint\":\n tsType = \"number\";\n break;\n case \"datetime\":\n case \"timestamp\":\n tsType = \"Date\";\n break;\n default:\n tsType = \"any\";\n break;\n }\n\n if (isNullable) {\n tsType += \" | null\";\n }\n\n return tsType;\n }\n}\n\nconst entityTemplate = `import { Entity, PrimaryGeneratedColumn, Column, ManyToOne } from \"typeorm\";\n\n{{#each tables}}\n@Entity(\"{{name}}\")\nexport class {{entityName}} {\n @PrimaryGeneratedColumn(\"uuid\")\n id!: string;\n\n {{#each columns}}\n {{#if isNullable}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { nullable: true, unique: true })\n {{else}}\n @Column(\"{{type}}\", { nullable: true })\n {{/if}}\n {{else}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { unique: true })\n {{else}}\n @Column(\"{{type}}\")\n {{/if}}\n {{/if}}\n {{name}}{{#if isNullable}}?: {{tsType}}{{else}}!: {{tsType}}{{/if}};\\n\n {{/each}}\n\n {{#each fkConstraints}}\n @ManyToOne(() => {{referencedEntity}}{{#if onDelete}}, { onDelete: \"{{upper onDelete }}\" }{{/if}})\n {{referencedTable}}: {{referencedEntity}};\n {{/each}}\n}\\n\n{{/each}}\n`;\n","import { BetterAuthError, BetterAuthOptions } from \"better-auth\";\nimport {\n AdapterFactoryOptions,\n createAdapterFactory,\n Where,\n type AdapterFactoryCustomizeAdapterCreator,\n} from \"better-auth/adapters\";\nimport {\n DataSource,\n Equal,\n FindOptionsWhere,\n In,\n LessThan,\n LessThanOrEqual,\n Like,\n MoreThan,\n MoreThanOrEqual,\n Not,\n ObjectLiteral,\n} from \"typeorm\";\nimport { MigrationGenerator } from \"./generate-migration\";\nimport { TypeOrmAdapterConfig } from \"./types\";\nimport { EntityGenerator } from \"./generate-entity\";\n\nconst DEFAULT_ENTITIES = {\n user: \"User\",\n account: \"Account\",\n session: \"Session\",\n verification: \"Verification\",\n} as const;\n\nexport const typeormAdapter = (dataSource: DataSource, config: TypeOrmAdapterConfig = {}) => {\n config = {\n entitiesPath: \"./entities\",\n migrationsPath: \"./migrations\",\n provider: \"postgres\",\n generateEntities: true,\n generateMigrations: true,\n ...(config || {}),\n entities: {\n ...DEFAULT_ENTITIES,\n ...(config?.entities || {}),\n },\n };\n\n let lazyOptions: BetterAuthOptions | null = null;\n\n const convertOperatorToTypeORM = (operator: Where[\"operator\"], value: unknown) => {\n switch (operator) {\n case \"eq\":\n return Equal(value);\n case \"ne\":\n return Not(value);\n case \"lt\":\n return LessThan(value);\n case \"lte\":\n return LessThanOrEqual(value);\n case \"gt\":\n return MoreThan(value);\n case \"gte\":\n return MoreThanOrEqual(value);\n case \"in\":\n return In(value as unknown[]);\n case \"not_in\":\n return Not(In(value as unknown[]));\n case \"contains\":\n return Like(`%${value}%`);\n case \"starts_with\":\n return Like(`${value}%`);\n case \"ends_with\":\n return Like(`%${value}`);\n default:\n return value;\n }\n };\n\n const convertWhereToFindOptions = (where: Where[]): FindOptionsWhere<ObjectLiteral> => {\n if (!where || where.length === 0) return {};\n\n const findOptions: FindOptionsWhere<ObjectLiteral> = {};\n\n for (const w of where) {\n if (!w.operator) {\n findOptions[w.field] = w.value;\n } else {\n findOptions[w.field] = convertOperatorToTypeORM(w.operator, w.value);\n }\n }\n\n return findOptions;\n };\n\n const createCustomAdapter =\n (dataSource: DataSource): AdapterFactoryCustomizeAdapterCreator =>\n ({ getDefaultModelName, getFieldName, transformOutput }) => {\n const getRepositoryName = (model: string) => {\n const modelName = getDefaultModelName(model);\n const repositoryName =\n config.entities?.[modelName as keyof typeof config.entities] || modelName;\n return dataSource.getRepository(repositoryName);\n };\n\n const getMappedEntities = () => {\n const mappedEntities = { ...DEFAULT_ENTITIES };\n for (const key of Object.keys(lazyOptions as any)) {\n if (!(lazyOptions as any)[key].modelName) {\n continue;\n }\n const entity = DEFAULT_ENTITIES[key as keyof typeof DEFAULT_ENTITIES];\n const modelName = (lazyOptions as any)[key].modelName;\n (mappedEntities as any)[modelName] = entity;\n }\n return mappedEntities;\n };\n\n return {\n async create({ data, model }) {\n try {\n const repository = getRepositoryName(model);\n const entity = repository.create(data);\n const saved = await repository.save(entity);\n return saved as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to create ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async update({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n await repository.update(conditions, update as Record<string, any>);\n const updated = await repository.findOne({ where: conditions });\n\n if (!updated) return null;\n return updated as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to update ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async updateMany({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n const result = await repository.update(conditions, update as Record<string, any>);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to updateMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async delete({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n await repository.delete(conditions);\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to delete ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async deleteMany({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.delete(conditions);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to deleteMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findOne({ model, where, select }) {\n try {\n const repository = getRepositoryName(model);\n const defaultModelName = getDefaultModelName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.findOne({ where: conditions, select });\n\n if (!result) return null;\n\n const output = await transformOutput(result, defaultModelName, select);\n return output as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findOne ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findMany({ model, where, limit, sortBy, offset }) {\n try {\n const defaultModelName = getDefaultModelName(model);\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const result = await repository.find({\n where: conditions,\n take: limit,\n skip: offset,\n order: sortBy\n ? {\n [getFieldName({ model, field: sortBy.field })]:\n sortBy.direction.toUpperCase() as \"ASC\" | \"DESC\",\n }\n : undefined,\n });\n\n // Transform all results from database fields to logical fields\n const transformed = await Promise.all(\n result.map((r) => transformOutput(r, defaultModelName))\n );\n return transformed as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async count({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const count = await repository.count({ where: conditions });\n return count;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to count ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async createSchema({ tables }) {\n console.log(\"Creating database schema...\");\n\n if (config.generateEntities) {\n const mappedEntities = getMappedEntities();\n const entityGenerator = new EntityGenerator(config.provider!);\n await entityGenerator.generate(tables, config.entitiesPath!, mappedEntities);\n }\n\n if (!config.generateMigrations) {\n return { code: \"\", path: \"\" };\n }\n\n const migrationGenerator = new MigrationGenerator(config.provider!);\n const { code, migrationFileName } = await migrationGenerator.generate(tables);\n\n return { code, path: `${config.migrationsPath}/${migrationFileName}` };\n },\n options: config,\n };\n };\n\n let adapterOptions: AdapterFactoryOptions | null = null;\n adapterOptions = {\n config: {\n adapterId: \"typeorm\",\n adapterName: \"TypeORM Adapter\",\n usePlural: config?.usePlural ?? false,\n debugLogs: config?.debugLogs ?? false,\n supportsUUIDs: config.provider === \"postgres\" ? true : false,\n supportsJSON: config.provider === \"postgres\" ? true : false, // even though mysql also supports it, mysql requires to pass stringified json anyway.\n supportsArrays: config.provider === \"postgres\" ? true : false,\n transaction: config.transaction\n ? (cb) =>\n dataSource.transaction(async (entityManager) => {\n const adapter = createAdapterFactory({\n config: adapterOptions!.config,\n adapter: createCustomAdapter(entityManager as any),\n })(lazyOptions!);\n\n return cb(adapter);\n })\n : undefined,\n },\n adapter: (options) => {\n return createCustomAdapter(dataSource)(options);\n },\n };\n\n const adapter = createAdapterFactory(adapterOptions!);\n return (options: BetterAuthOptions) => {\n lazyOptions = options;\n return adapter(options);\n };\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/lib/handlerbar.ts","../src/helpers.ts","../src/generate-migration.ts","../src/generate-entity.ts","../src/adapter.ts"],"names":["Handlebars","fs","Equal","Not","LessThan","LessThanOrEqual","MoreThan","MoreThanOrEqual","In","Like","dataSource","BetterAuthError","adapter","createAdapterFactory"],"mappings":"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","file":"index.js","sourcesContent":["import Handlebars from \"handlebars\";\n\nHandlebars.registerHelper(\"upper\", (str: string) => str.toUpperCase());\n\nHandlebars.registerHelper(\"quoteJoin\", function (array: string[]) {\n return array.map((item) => `\"${item}\"`).join(\", \");\n});\n\nexport { Handlebars };\n","import { DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\n\nexport const mapBetterAuthTypeToDBType = (\n betterAuthType: DBFieldAttribute[\"type\"],\n provider: Provider,\n isBigInt: boolean = false\n): string => {\n if (Array.isArray(betterAuthType)) {\n return betterAuthType[0] || \"varchar\";\n }\n\n let dbType = \"\";\n\n switch (betterAuthType) {\n case \"string\":\n dbType = \"varchar\";\n break;\n case \"boolean\":\n dbType = \"boolean\";\n break;\n case \"number\":\n dbType = provider === \"sqlite\" ? \"integer\" : \"int\";\n dbType = isBigInt && provider === \"sqlite\" ? dbType : \"bigint\";\n break;\n case \"date\":\n dbType = provider === \"postgres\" ? \"timestamp\" : \"datetime\";\n break;\n case \"json\":\n dbType = provider === \"sqlite\" ? \"text\" : \"json\";\n break;\n default:\n dbType = \"varchar\";\n break;\n }\n\n return dbType;\n};\n","import { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class MigrationGenerator {\n private provider: Provider;\n\n constructor(provider: Provider) {\n this.provider = provider;\n }\n\n async generate(authDbSchema: BetterAuthDBSchema) {\n const timestamp = Date.now();\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const tableInfo: TableDefinition = {\n name: name,\n columns: [],\n fkConstraints: [],\n };\n\n this.generatePrimaryKeyColumn(tableInfo);\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(migrationTemplate);\n\n const migrationCode = template({\n timestamp,\n tables: tableDefinitions,\n tablesReversed: [...tableDefinitions].reverse(),\n });\n\n return { code: migrationCode, migrationFileName: `${timestamp}-BetterAuthMigration.ts` };\n }\n\n private generatePrimaryKeyColumn(tableInfo: TableDefinition) {\n const column = {\n name: \"id\",\n type: this.provider === \"postgres\" ? \"uuid\" : \"varchar\",\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"uuid\",\n } as TableDefinition[\"columns\"][0];\n\n tableInfo.columns.push(column);\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n}\n\nexport interface TableDefinition {\n name: string;\n entityName?: string;\n columns: {\n name: string;\n type: string;\n isNullable?: boolean;\n isUnique?: boolean;\n default?: any;\n isPrimary?: boolean;\n isGenerated?: boolean;\n generationStrategy?: \"uuid\" | \"increment\";\n }[];\n fkConstraints: {\n columnNames: string[];\n referencedColumnNames: string[];\n referencedTableName: string;\n onDelete: string;\n }[];\n}\n\nconst migrationTemplate = `import { MigrationInterface, QueryRunner, Table } from \"typeorm\";\n\nexport class BetterAuthMigration{{timestamp}} implements MigrationInterface {\n public async up(queryRunner: QueryRunner): Promise<void> {\n{{#each tables}}\n await queryRunner.createTable(\n new Table({\n name: \"{{name}}\",\n columns: [\n{{#each columns}}\n {\n name: \"{{name}}\",\n type: \"{{type}}\",\n{{#if isPrimary}}\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"{{generationStrategy}}\",\n{{/if}}\n{{#if isNullable}}\n isNullable: {{isNullable}},\n{{/if}}\n{{#if isUnique}}\n isUnique: true,\n{{/if}}\n },\n{{/each}}\n ],\n{{#if fkConstraints.length}}\n foreignKeys: [\n{{#each fkConstraints}}\n {\n columnNames: [{{{quoteJoin columnNames}}}],\n referencedTableName: \"{{referencedTableName}}\",\n referencedColumnNames: [{{{quoteJoin referencedColumnNames}}}],\n onDelete: \"{{onDelete}}\",\n },\n{{/each}}\n ],\n{{/if}}\n })\n );\n{{/each}}\n }\n\n public async down(queryRunner: QueryRunner): Promise<void> {\n{{#each tablesReversed}}\n await queryRunner.dropTable(\"{{name}}\");\n{{/each}}\n }\n}\n`;\n","import fs from \"fs/promises\";\nimport { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { TableDefinition } from \"./generate-migration\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class EntityGenerator {\n private provider: Provider;\n\n constructor(provider: Provider) {\n this.provider = provider;\n }\n\n async generate(\n authDbSchema: BetterAuthDBSchema,\n entitiesPath: string,\n mappedEntities?: Record<string, any>\n ) {\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const entityName = mappedEntities ? mappedEntities[name] : undefined;\n const tableInfo: TableDefinition = {\n name: name,\n entityName: entityName,\n columns: [],\n fkConstraints: [],\n };\n\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(entityTemplate);\n\n const entityCode = template({\n tables: tableDefinitions.map((table) => ({\n ...table,\n columns: table.columns.map((column) => ({\n ...column,\n tsType: this.mapDBTypeToTSType(column.type, column.isNullable),\n })),\n fkConstraints: table.fkConstraints.map((fk) => ({\n ...fk,\n referencedTable: fk.referencedTableName,\n referencedEntity: mappedEntities\n ? mappedEntities[fk.referencedTableName]\n : fk.referencedTableName,\n columnName: fk.columnNames[0],\n })),\n })),\n });\n\n // check if entitiesPath exists, if not create it\n try {\n await fs.access(entitiesPath);\n } catch {\n await fs.mkdir(entitiesPath, { recursive: true });\n } finally {\n await fs.writeFile(`${entitiesPath}/auth.ts`, entityCode);\n }\n\n return entityCode;\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n\n private mapDBTypeToTSType(dbType: string, isNullable?: boolean): string {\n let tsType: string;\n\n switch (dbType) {\n case \"varchar\":\n case \"text\":\n case \"json\":\n tsType = \"string\";\n break;\n case \"boolean\":\n tsType = \"boolean\";\n break;\n case \"int\":\n case \"integer\":\n case \"bigint\":\n tsType = \"number\";\n break;\n case \"datetime\":\n case \"timestamp\":\n tsType = \"Date\";\n break;\n default:\n tsType = \"any\";\n break;\n }\n\n if (isNullable) {\n tsType += \" | null\";\n }\n\n return tsType;\n }\n}\n\nconst entityTemplate = `import { Entity, PrimaryGeneratedColumn, Column, ManyToOne } from \"typeorm\";\n\n{{#each tables}}\n@Entity(\"{{name}}\")\nexport class {{entityName}} {\n @PrimaryGeneratedColumn(\"uuid\")\n id!: string;\n\n {{#each columns}}\n {{#if isNullable}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { nullable: true, unique: true })\n {{else}}\n @Column(\"{{type}}\", { nullable: true })\n {{/if}}\n {{else}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { unique: true })\n {{else}}\n @Column(\"{{type}}\")\n {{/if}}\n {{/if}}\n {{name}}{{#if isNullable}}?: {{tsType}}{{else}}!: {{tsType}}{{/if}};\\n\n {{/each}}\n\n {{#each fkConstraints}}\n @ManyToOne(() => {{referencedEntity}}{{#if onDelete}}, { onDelete: \"{{upper onDelete }}\" }{{/if}})\n {{referencedTable}}: {{referencedEntity}};\n {{/each}}\n}\\n\n{{/each}}\n`;\n","import { BetterAuthError, BetterAuthOptions } from \"better-auth\";\nimport {\n AdapterFactoryOptions,\n createAdapterFactory,\n Where,\n type AdapterFactoryCustomizeAdapterCreator,\n} from \"better-auth/adapters\";\nimport {\n DataSource,\n Equal,\n FindOptionsWhere,\n In,\n LessThan,\n LessThanOrEqual,\n Like,\n MoreThan,\n MoreThanOrEqual,\n Not,\n ObjectLiteral,\n} from \"typeorm\";\nimport { MigrationGenerator } from \"./generate-migration\";\nimport { TypeOrmAdapterConfig } from \"./types\";\nimport { EntityGenerator } from \"./generate-entity\";\n\nconst DEFAULT_ENTITIES = {\n user: \"User\",\n account: \"Account\",\n session: \"Session\",\n verification: \"Verification\",\n} as const;\n\nexport const typeormAdapter = (dataSource: DataSource, config: TypeOrmAdapterConfig = {}) => {\n config = {\n entitiesPath: \"./entities\",\n migrationsPath: \"./migrations\",\n provider: \"postgres\",\n generateEntities: true,\n generateMigrations: true,\n ...(config || {}),\n entities: {\n ...DEFAULT_ENTITIES,\n ...(config?.entities || {}),\n },\n };\n\n let lazyOptions: BetterAuthOptions | null = null;\n\n const convertOperatorToTypeORM = (operator: Where[\"operator\"], value: unknown) => {\n switch (operator) {\n case \"eq\":\n return Equal(value);\n case \"ne\":\n return Not(value);\n case \"lt\":\n return LessThan(value);\n case \"lte\":\n return LessThanOrEqual(value);\n case \"gt\":\n return MoreThan(value);\n case \"gte\":\n return MoreThanOrEqual(value);\n case \"in\":\n return In(value as unknown[]);\n case \"not_in\":\n return Not(In(value as unknown[]));\n case \"contains\":\n return Like(`%${value}%`);\n case \"starts_with\":\n return Like(`${value}%`);\n case \"ends_with\":\n return Like(`%${value}`);\n default:\n return value;\n }\n };\n\n const convertWhereToFindOptions = (where: Where[]): FindOptionsWhere<ObjectLiteral> => {\n if (!where || where.length === 0) return {};\n\n const findOptions: FindOptionsWhere<ObjectLiteral> = {};\n\n for (const w of where) {\n if (!w.operator) {\n findOptions[w.field] = w.value;\n } else {\n findOptions[w.field] = convertOperatorToTypeORM(w.operator, w.value);\n }\n }\n\n return findOptions;\n };\n\n const createCustomAdapter =\n (dataSource: DataSource): AdapterFactoryCustomizeAdapterCreator =>\n ({ getDefaultModelName, getFieldName, transformOutput }) => {\n const getRepositoryName = (model: string) => {\n const modelName = getDefaultModelName(model);\n const repositoryName =\n config.entities?.[modelName as keyof typeof config.entities] || modelName;\n return dataSource.getRepository(repositoryName);\n };\n\n const getMappedEntities = () => {\n const mappedEntities = { ...DEFAULT_ENTITIES };\n for (const key of Object.keys(lazyOptions as any)) {\n if (!(lazyOptions as any)[key].modelName) {\n continue;\n }\n const entity = DEFAULT_ENTITIES[key as keyof typeof DEFAULT_ENTITIES];\n const modelName = (lazyOptions as any)[key].modelName;\n (mappedEntities as any)[modelName] = entity;\n }\n return mappedEntities;\n };\n\n return {\n async create({ data, model }) {\n try {\n const repository = getRepositoryName(model);\n const entity = repository.create(data);\n const saved = await repository.save(entity);\n return saved as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to create ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async update({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n await repository.update(conditions, update as Record<string, any>);\n const updated = await repository.findOne({ where: conditions });\n\n if (!updated) return null;\n return updated as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to update ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async updateMany({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n const result = await repository.update(conditions, update as Record<string, any>);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to updateMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async delete({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n await repository.delete(conditions);\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to delete ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async deleteMany({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.delete(conditions);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to deleteMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findOne({ model, where, select }) {\n try {\n const repository = getRepositoryName(model);\n const defaultModelName = getDefaultModelName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.findOne({ where: conditions, select });\n\n if (!result) return null;\n\n const output = await transformOutput(result, defaultModelName, select);\n return output as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findOne ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findMany({ model, where, limit, sortBy, offset }) {\n try {\n const defaultModelName = getDefaultModelName(model);\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const result = await repository.find({\n where: conditions,\n take: limit,\n skip: offset,\n order: sortBy\n ? {\n [getFieldName({ model, field: sortBy.field })]:\n sortBy.direction.toUpperCase() as \"ASC\" | \"DESC\",\n }\n : undefined,\n });\n\n // Transform all results from database fields to logical fields\n const transformed = await Promise.all(\n result.map((r) => transformOutput(r, defaultModelName))\n );\n return transformed as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async count({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const count = await repository.count({ where: conditions });\n return count;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to count ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async createSchema({ tables }) {\n console.log(\"Creating database schema...\");\n\n if (config.generateEntities) {\n const mappedEntities = getMappedEntities();\n const entityGenerator = new EntityGenerator(config.provider!);\n await entityGenerator.generate(tables, config.entitiesPath!, mappedEntities);\n }\n\n if (!config.generateMigrations) {\n return { code: \"\", path: \"\" };\n }\n\n const migrationGenerator = new MigrationGenerator(config.provider!);\n const { code, migrationFileName } = await migrationGenerator.generate(tables);\n\n return { code, path: `${config.migrationsPath}/${migrationFileName}` };\n },\n options: config,\n };\n };\n\n let adapterOptions: AdapterFactoryOptions | null = null;\n adapterOptions = {\n config: {\n adapterId: \"typeorm\",\n adapterName: \"TypeORM Adapter\",\n usePlural: config?.usePlural ?? false,\n debugLogs: config?.debugLogs ?? false,\n supportsUUIDs: config.provider === \"postgres\" ? true : false,\n supportsJSON: config.provider === \"postgres\" ? true : false, // even though mysql also supports it, mysql requires to pass stringified json anyway.\n supportsArrays: config.provider === \"postgres\" ? true : false,\n transaction: config.transaction\n ? (cb) =>\n dataSource.transaction(async (entityManager) => {\n const adapter = createAdapterFactory({\n config: adapterOptions!.config,\n adapter: createCustomAdapter(entityManager as any),\n })(lazyOptions!);\n\n return cb(adapter);\n })\n : undefined,\n },\n adapter: (options) => {\n return createCustomAdapter(dataSource)(options);\n },\n };\n\n const adapter = createAdapterFactory(adapterOptions!);\n return (options: BetterAuthOptions) => {\n lazyOptions = options;\n return adapter(options);\n };\n};\n"]}
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/lib/handlerbar.ts","../src/helpers.ts","../src/generate-migration.ts","../src/generate-entity.ts","../src/adapter.ts"],"names":["dataSource","adapter"],"mappings":"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","file":"index.mjs","sourcesContent":["import Handlebars from \"handlebars\";\n\nHandlebars.registerHelper(\"upper\", (str: string) => str.toUpperCase());\n\nHandlebars.registerHelper(\"quoteJoin\", function (array: string[]) {\n return array.map((item) => `\"${item}\"`).join(\", \");\n});\n\nexport { Handlebars };\n","import { DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\n\nexport const mapBetterAuthTypeToDBType = (\n betterAuthType: DBFieldAttribute[\"type\"],\n provider: Provider,\n isBigInt: boolean = false\n): string => {\n if (Array.isArray(betterAuthType)) {\n return betterAuthType[0] || \"varchar\";\n }\n\n let dbType = \"\";\n\n switch (betterAuthType) {\n case \"string\":\n dbType = \"varchar\";\n break;\n case \"boolean\":\n dbType = \"boolean\";\n break;\n case \"number\":\n dbType = provider === \"sqlite\" ? \"integer\" : \"int\";\n dbType = isBigInt && provider === \"sqlite\" ? dbType : \"bigint\";\n break;\n case \"date\":\n dbType = provider === \"postgres\" ? \"timestamp\" : \"datetime\";\n break;\n case \"json\":\n dbType = provider === \"sqlite\" ? \"text\" : \"json\";\n break;\n default:\n dbType = \"varchar\";\n break;\n }\n\n return dbType;\n};\n","import { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class MigrationGenerator {\n constructor(private readonly provider: Provider) {}\n\n async generate(authDbSchema: BetterAuthDBSchema) {\n const timestamp = Date.now();\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const tableInfo: TableDefinition = {\n name: name,\n columns: [],\n fkConstraints: [],\n };\n\n this.generatePrimaryKeyColumn(tableInfo);\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(migrationTemplate);\n\n const migrationCode = template({\n timestamp,\n tables: tableDefinitions,\n tablesReversed: [...tableDefinitions].reverse(),\n });\n\n return { code: migrationCode, migrationFileName: `${timestamp}-BetterAuthMigration.ts` };\n }\n\n private generatePrimaryKeyColumn(tableInfo: TableDefinition) {\n const column = {\n name: \"id\",\n type: this.provider === \"postgres\" ? \"uuid\" : \"varchar\",\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"uuid\",\n } as TableDefinition[\"columns\"][0];\n\n tableInfo.columns.push(column);\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n}\n\nexport interface TableDefinition {\n name: string;\n entityName?: string;\n columns: {\n name: string;\n type: string;\n isNullable?: boolean;\n isUnique?: boolean;\n default?: any;\n isPrimary?: boolean;\n isGenerated?: boolean;\n generationStrategy?: \"uuid\" | \"increment\";\n }[];\n fkConstraints: {\n columnNames: string[];\n referencedColumnNames: string[];\n referencedTableName: string;\n onDelete: string;\n }[];\n}\n\nconst migrationTemplate = `import { MigrationInterface, QueryRunner, Table } from \"typeorm\";\n\nexport class BetterAuthMigration{{timestamp}} implements MigrationInterface {\n public async up(queryRunner: QueryRunner): Promise<void> {\n{{#each tables}}\n await queryRunner.createTable(\n new Table({\n name: \"{{name}}\",\n columns: [\n{{#each columns}}\n {\n name: \"{{name}}\",\n type: \"{{type}}\",\n{{#if isPrimary}}\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"{{generationStrategy}}\",\n{{/if}}\n{{#if isNullable}}\n isNullable: {{isNullable}},\n{{/if}}\n{{#if isUnique}}\n isUnique: true,\n{{/if}}\n },\n{{/each}}\n ],\n{{#if fkConstraints.length}}\n foreignKeys: [\n{{#each fkConstraints}}\n {\n columnNames: [{{{quoteJoin columnNames}}}],\n referencedTableName: \"{{referencedTableName}}\",\n referencedColumnNames: [{{{quoteJoin referencedColumnNames}}}],\n onDelete: \"{{onDelete}}\",\n },\n{{/each}}\n ],\n{{/if}}\n })\n );\n{{/each}}\n }\n\n public async down(queryRunner: QueryRunner): Promise<void> {\n{{#each tablesReversed}}\n await queryRunner.dropTable(\"{{name}}\");\n{{/each}}\n }\n}\n`;\n","import fs from \"fs/promises\";\nimport { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { TableDefinition } from \"./generate-migration\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class EntityGenerator {\n constructor(private readonly provider: Provider) {}\n\n async generate(\n authDbSchema: BetterAuthDBSchema,\n entitiesPath: string,\n mappedEntities?: Record<string, any>\n ) {\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const entityName = mappedEntities ? mappedEntities[name] : undefined;\n const tableInfo: TableDefinition = {\n name: name,\n entityName: entityName,\n columns: [],\n fkConstraints: [],\n };\n\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(entityTemplate);\n\n const entityCode = template({\n tables: tableDefinitions.map((table) => ({\n ...table,\n columns: table.columns.map((column) => ({\n ...column,\n tsType: this.mapDBTypeToTSType(column.type, column.isNullable),\n })),\n fkConstraints: table.fkConstraints.map((fk) => ({\n ...fk,\n referencedTable: fk.referencedTableName,\n referencedEntity: mappedEntities\n ? mappedEntities[fk.referencedTableName]\n : fk.referencedTableName,\n columnName: fk.columnNames[0],\n })),\n })),\n });\n\n // check if entitiesPath exists, if not create it\n try {\n await fs.access(entitiesPath);\n } catch {\n await fs.mkdir(entitiesPath, { recursive: true });\n } finally {\n await fs.writeFile(`${entitiesPath}/auth.ts`, entityCode);\n }\n\n return entityCode;\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n\n private mapDBTypeToTSType(dbType: string, isNullable?: boolean): string {\n let tsType: string;\n\n switch (dbType) {\n case \"varchar\":\n case \"text\":\n case \"json\":\n tsType = \"string\";\n break;\n case \"boolean\":\n tsType = \"boolean\";\n break;\n case \"int\":\n case \"integer\":\n case \"bigint\":\n tsType = \"number\";\n break;\n case \"datetime\":\n case \"timestamp\":\n tsType = \"Date\";\n break;\n default:\n tsType = \"any\";\n break;\n }\n\n if (isNullable) {\n tsType += \" | null\";\n }\n\n return tsType;\n }\n}\n\nconst entityTemplate = `import { Entity, PrimaryGeneratedColumn, Column, ManyToOne } from \"typeorm\";\n\n{{#each tables}}\n@Entity(\"{{name}}\")\nexport class {{entityName}} {\n @PrimaryGeneratedColumn(\"uuid\")\n id!: string;\n\n {{#each columns}}\n {{#if isNullable}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { nullable: true, unique: true })\n {{else}}\n @Column(\"{{type}}\", { nullable: true })\n {{/if}}\n {{else}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { unique: true })\n {{else}}\n @Column(\"{{type}}\")\n {{/if}}\n {{/if}}\n {{name}}{{#if isNullable}}?: {{tsType}}{{else}}!: {{tsType}}{{/if}};\\n\n {{/each}}\n\n {{#each fkConstraints}}\n @ManyToOne(() => {{referencedEntity}}{{#if onDelete}}, { onDelete: \"{{upper onDelete }}\" }{{/if}})\n {{referencedTable}}: {{referencedEntity}};\n {{/each}}\n}\\n\n{{/each}}\n`;\n","import { BetterAuthError, BetterAuthOptions } from \"better-auth\";\nimport {\n AdapterFactoryOptions,\n createAdapterFactory,\n Where,\n type AdapterFactoryCustomizeAdapterCreator,\n} from \"better-auth/adapters\";\nimport {\n DataSource,\n Equal,\n FindOptionsWhere,\n In,\n LessThan,\n LessThanOrEqual,\n Like,\n MoreThan,\n MoreThanOrEqual,\n Not,\n ObjectLiteral,\n} from \"typeorm\";\nimport { MigrationGenerator } from \"./generate-migration\";\nimport { TypeOrmAdapterConfig } from \"./types\";\nimport { EntityGenerator } from \"./generate-entity\";\n\nconst DEFAULT_ENTITIES = {\n user: \"User\",\n account: \"Account\",\n session: \"Session\",\n verification: \"Verification\",\n} as const;\n\nexport const typeormAdapter = (dataSource: DataSource, config: TypeOrmAdapterConfig = {}) => {\n config = {\n entitiesPath: \"./entities\",\n migrationsPath: \"./migrations\",\n provider: \"postgres\",\n generateEntities: true,\n generateMigrations: true,\n ...(config || {}),\n entities: {\n ...DEFAULT_ENTITIES,\n ...(config?.entities || {}),\n },\n };\n\n let lazyOptions: BetterAuthOptions | null = null;\n\n const convertOperatorToTypeORM = (operator: Where[\"operator\"], value: unknown) => {\n switch (operator) {\n case \"eq\":\n return Equal(value);\n case \"ne\":\n return Not(value);\n case \"lt\":\n return LessThan(value);\n case \"lte\":\n return LessThanOrEqual(value);\n case \"gt\":\n return MoreThan(value);\n case \"gte\":\n return MoreThanOrEqual(value);\n case \"in\":\n return In(value as unknown[]);\n case \"not_in\":\n return Not(In(value as unknown[]));\n case \"contains\":\n return Like(`%${value}%`);\n case \"starts_with\":\n return Like(`${value}%`);\n case \"ends_with\":\n return Like(`%${value}`);\n default:\n return value;\n }\n };\n\n const convertWhereToFindOptions = (where: Where[]): FindOptionsWhere<ObjectLiteral> => {\n if (!where || where.length === 0) return {};\n\n const findOptions: FindOptionsWhere<ObjectLiteral> = {};\n\n for (const w of where) {\n if (!w.operator) {\n findOptions[w.field] = w.value;\n } else {\n findOptions[w.field] = convertOperatorToTypeORM(w.operator, w.value);\n }\n }\n\n return findOptions;\n };\n\n const createCustomAdapter =\n (dataSource: DataSource): AdapterFactoryCustomizeAdapterCreator =>\n ({ getDefaultModelName, getFieldName, transformOutput }) => {\n const getRepositoryName = (model: string) => {\n const modelName = getDefaultModelName(model);\n const repositoryName =\n config.entities?.[modelName as keyof typeof config.entities] || modelName;\n return dataSource.getRepository(repositoryName);\n };\n\n const getMappedEntities = () => {\n const mappedEntities = { ...DEFAULT_ENTITIES };\n for (const key of Object.keys(lazyOptions as any)) {\n if (!(lazyOptions as any)[key].modelName) {\n continue;\n }\n const entity = DEFAULT_ENTITIES[key as keyof typeof DEFAULT_ENTITIES];\n const modelName = (lazyOptions as any)[key].modelName;\n (mappedEntities as any)[modelName] = entity;\n }\n return mappedEntities;\n };\n\n return {\n async create({ data, model }) {\n try {\n const repository = getRepositoryName(model);\n const entity = repository.create(data);\n const saved = await repository.save(entity);\n return saved as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to create ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async update({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n await repository.update(conditions, update as Record<string, any>);\n const updated = await repository.findOne({ where: conditions });\n\n if (!updated) return null;\n return updated as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to update ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async updateMany({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n const result = await repository.update(conditions, update as Record<string, any>);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to updateMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async delete({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n await repository.delete(conditions);\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to delete ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async deleteMany({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.delete(conditions);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to deleteMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findOne({ model, where, select }) {\n try {\n const repository = getRepositoryName(model);\n const defaultModelName = getDefaultModelName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.findOne({ where: conditions, select });\n\n if (!result) return null;\n\n const output = await transformOutput(result, defaultModelName, select);\n return output as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findOne ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findMany({ model, where, limit, sortBy, offset }) {\n try {\n const defaultModelName = getDefaultModelName(model);\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const result = await repository.find({\n where: conditions,\n take: limit,\n skip: offset,\n order: sortBy\n ? {\n [getFieldName({ model, field: sortBy.field })]:\n sortBy.direction.toUpperCase() as \"ASC\" | \"DESC\",\n }\n : undefined,\n });\n\n // Transform all results from database fields to logical fields\n const transformed = await Promise.all(\n result.map((r) => transformOutput(r, defaultModelName))\n );\n return transformed as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async count({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const count = await repository.count({ where: conditions });\n return count;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to count ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async createSchema({ tables }) {\n console.log(\"Creating database schema...\");\n\n if (config.generateEntities) {\n const mappedEntities = getMappedEntities();\n const entityGenerator = new EntityGenerator(config.provider!);\n await entityGenerator.generate(tables, config.entitiesPath!, mappedEntities);\n }\n\n if (!config.generateMigrations) {\n return { code: \"\", path: \"\" };\n }\n\n const migrationGenerator = new MigrationGenerator(config.provider!);\n const { code, migrationFileName } = await migrationGenerator.generate(tables);\n\n return { code, path: `${config.migrationsPath}/${migrationFileName}` };\n },\n options: config,\n };\n };\n\n let adapterOptions: AdapterFactoryOptions | null = null;\n adapterOptions = {\n config: {\n adapterId: \"typeorm\",\n adapterName: \"TypeORM Adapter\",\n usePlural: config?.usePlural ?? false,\n debugLogs: config?.debugLogs ?? false,\n supportsUUIDs: config.provider === \"postgres\" ? true : false,\n supportsJSON: config.provider === \"postgres\" ? true : false, // even though mysql also supports it, mysql requires to pass stringified json anyway.\n supportsArrays: config.provider === \"postgres\" ? true : false,\n transaction: config.transaction\n ? (cb) =>\n dataSource.transaction(async (entityManager) => {\n const adapter = createAdapterFactory({\n config: adapterOptions!.config,\n adapter: createCustomAdapter(entityManager as any),\n })(lazyOptions!);\n\n return cb(adapter);\n })\n : undefined,\n },\n adapter: (options) => {\n return createCustomAdapter(dataSource)(options);\n },\n };\n\n const adapter = createAdapterFactory(adapterOptions!);\n return (options: BetterAuthOptions) => {\n lazyOptions = options;\n return adapter(options);\n };\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/lib/handlerbar.ts","../src/helpers.ts","../src/generate-migration.ts","../src/generate-entity.ts","../src/adapter.ts"],"names":["dataSource","adapter"],"mappings":"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","file":"index.mjs","sourcesContent":["import Handlebars from \"handlebars\";\n\nHandlebars.registerHelper(\"upper\", (str: string) => str.toUpperCase());\n\nHandlebars.registerHelper(\"quoteJoin\", function (array: string[]) {\n return array.map((item) => `\"${item}\"`).join(\", \");\n});\n\nexport { Handlebars };\n","import { DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\n\nexport const mapBetterAuthTypeToDBType = (\n betterAuthType: DBFieldAttribute[\"type\"],\n provider: Provider,\n isBigInt: boolean = false\n): string => {\n if (Array.isArray(betterAuthType)) {\n return betterAuthType[0] || \"varchar\";\n }\n\n let dbType = \"\";\n\n switch (betterAuthType) {\n case \"string\":\n dbType = \"varchar\";\n break;\n case \"boolean\":\n dbType = \"boolean\";\n break;\n case \"number\":\n dbType = provider === \"sqlite\" ? \"integer\" : \"int\";\n dbType = isBigInt && provider === \"sqlite\" ? dbType : \"bigint\";\n break;\n case \"date\":\n dbType = provider === \"postgres\" ? \"timestamp\" : \"datetime\";\n break;\n case \"json\":\n dbType = provider === \"sqlite\" ? \"text\" : \"json\";\n break;\n default:\n dbType = \"varchar\";\n break;\n }\n\n return dbType;\n};\n","import { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class MigrationGenerator {\n private provider: Provider;\n\n constructor(provider: Provider) {\n this.provider = provider;\n }\n\n async generate(authDbSchema: BetterAuthDBSchema) {\n const timestamp = Date.now();\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const tableInfo: TableDefinition = {\n name: name,\n columns: [],\n fkConstraints: [],\n };\n\n this.generatePrimaryKeyColumn(tableInfo);\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(migrationTemplate);\n\n const migrationCode = template({\n timestamp,\n tables: tableDefinitions,\n tablesReversed: [...tableDefinitions].reverse(),\n });\n\n return { code: migrationCode, migrationFileName: `${timestamp}-BetterAuthMigration.ts` };\n }\n\n private generatePrimaryKeyColumn(tableInfo: TableDefinition) {\n const column = {\n name: \"id\",\n type: this.provider === \"postgres\" ? \"uuid\" : \"varchar\",\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"uuid\",\n } as TableDefinition[\"columns\"][0];\n\n tableInfo.columns.push(column);\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n}\n\nexport interface TableDefinition {\n name: string;\n entityName?: string;\n columns: {\n name: string;\n type: string;\n isNullable?: boolean;\n isUnique?: boolean;\n default?: any;\n isPrimary?: boolean;\n isGenerated?: boolean;\n generationStrategy?: \"uuid\" | \"increment\";\n }[];\n fkConstraints: {\n columnNames: string[];\n referencedColumnNames: string[];\n referencedTableName: string;\n onDelete: string;\n }[];\n}\n\nconst migrationTemplate = `import { MigrationInterface, QueryRunner, Table } from \"typeorm\";\n\nexport class BetterAuthMigration{{timestamp}} implements MigrationInterface {\n public async up(queryRunner: QueryRunner): Promise<void> {\n{{#each tables}}\n await queryRunner.createTable(\n new Table({\n name: \"{{name}}\",\n columns: [\n{{#each columns}}\n {\n name: \"{{name}}\",\n type: \"{{type}}\",\n{{#if isPrimary}}\n isPrimary: true,\n isGenerated: true,\n generationStrategy: \"{{generationStrategy}}\",\n{{/if}}\n{{#if isNullable}}\n isNullable: {{isNullable}},\n{{/if}}\n{{#if isUnique}}\n isUnique: true,\n{{/if}}\n },\n{{/each}}\n ],\n{{#if fkConstraints.length}}\n foreignKeys: [\n{{#each fkConstraints}}\n {\n columnNames: [{{{quoteJoin columnNames}}}],\n referencedTableName: \"{{referencedTableName}}\",\n referencedColumnNames: [{{{quoteJoin referencedColumnNames}}}],\n onDelete: \"{{onDelete}}\",\n },\n{{/each}}\n ],\n{{/if}}\n })\n );\n{{/each}}\n }\n\n public async down(queryRunner: QueryRunner): Promise<void> {\n{{#each tablesReversed}}\n await queryRunner.dropTable(\"{{name}}\");\n{{/each}}\n }\n}\n`;\n","import fs from \"fs/promises\";\nimport { BetterAuthDBSchema, DBFieldAttribute } from \"better-auth\";\nimport { Provider } from \"./types\";\nimport { Handlebars } from \"./lib/handlerbar\";\nimport { TableDefinition } from \"./generate-migration\";\nimport { mapBetterAuthTypeToDBType } from \"./helpers\";\n\nexport class EntityGenerator {\n private provider: Provider;\n\n constructor(provider: Provider) {\n this.provider = provider;\n }\n\n async generate(\n authDbSchema: BetterAuthDBSchema,\n entitiesPath: string,\n mappedEntities?: Record<string, any>\n ) {\n const tableDefinitions: TableDefinition[] = [];\n\n for (const [tableName, tableSchema] of Object.entries(authDbSchema)) {\n const name = tableSchema.modelName || tableName;\n const entityName = mappedEntities ? mappedEntities[name] : undefined;\n const tableInfo: TableDefinition = {\n name: name,\n entityName: entityName,\n columns: [],\n fkConstraints: [],\n };\n\n for (const [fieldName, fieldConfig] of Object.entries(tableSchema.fields)) {\n this.generateColumn(fieldName, fieldConfig, tableInfo);\n }\n\n tableDefinitions.push(tableInfo);\n }\n\n const template = Handlebars.compile(entityTemplate);\n\n const entityCode = template({\n tables: tableDefinitions.map((table) => ({\n ...table,\n columns: table.columns.map((column) => ({\n ...column,\n tsType: this.mapDBTypeToTSType(column.type, column.isNullable),\n })),\n fkConstraints: table.fkConstraints.map((fk) => ({\n ...fk,\n referencedTable: fk.referencedTableName,\n referencedEntity: mappedEntities\n ? mappedEntities[fk.referencedTableName]\n : fk.referencedTableName,\n columnName: fk.columnNames[0],\n })),\n })),\n });\n\n // check if entitiesPath exists, if not create it\n try {\n await fs.access(entitiesPath);\n } catch {\n await fs.mkdir(entitiesPath, { recursive: true });\n } finally {\n await fs.writeFile(`${entitiesPath}/auth.ts`, entityCode);\n }\n\n return entityCode;\n }\n\n private generateColumn(\n defaultFieldName: string,\n betterAuthField: DBFieldAttribute,\n tableInfo: TableDefinition\n ) {\n const column = {} as TableDefinition[\"columns\"][0];\n column.name = betterAuthField.fieldName || defaultFieldName;\n column.type = mapBetterAuthTypeToDBType(\n betterAuthField.type,\n this.provider,\n betterAuthField.bigint\n );\n\n if (!betterAuthField.required) {\n column.isNullable = true;\n }\n\n if (betterAuthField.unique) {\n column.isUnique = true;\n }\n\n if (betterAuthField.defaultValue) {\n column.default = betterAuthField.defaultValue;\n }\n\n tableInfo.columns.push(column);\n\n if (betterAuthField.references) {\n tableInfo.fkConstraints.push({\n columnNames: [column.name],\n referencedTableName: betterAuthField.references.model,\n referencedColumnNames: [betterAuthField.references.field],\n onDelete: betterAuthField.references.onDelete || \"no action\",\n });\n }\n }\n\n private mapDBTypeToTSType(dbType: string, isNullable?: boolean): string {\n let tsType: string;\n\n switch (dbType) {\n case \"varchar\":\n case \"text\":\n case \"json\":\n tsType = \"string\";\n break;\n case \"boolean\":\n tsType = \"boolean\";\n break;\n case \"int\":\n case \"integer\":\n case \"bigint\":\n tsType = \"number\";\n break;\n case \"datetime\":\n case \"timestamp\":\n tsType = \"Date\";\n break;\n default:\n tsType = \"any\";\n break;\n }\n\n if (isNullable) {\n tsType += \" | null\";\n }\n\n return tsType;\n }\n}\n\nconst entityTemplate = `import { Entity, PrimaryGeneratedColumn, Column, ManyToOne } from \"typeorm\";\n\n{{#each tables}}\n@Entity(\"{{name}}\")\nexport class {{entityName}} {\n @PrimaryGeneratedColumn(\"uuid\")\n id!: string;\n\n {{#each columns}}\n {{#if isNullable}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { nullable: true, unique: true })\n {{else}}\n @Column(\"{{type}}\", { nullable: true })\n {{/if}}\n {{else}}\n {{#if isUnique}}\n @Column(\"{{type}}\", { unique: true })\n {{else}}\n @Column(\"{{type}}\")\n {{/if}}\n {{/if}}\n {{name}}{{#if isNullable}}?: {{tsType}}{{else}}!: {{tsType}}{{/if}};\\n\n {{/each}}\n\n {{#each fkConstraints}}\n @ManyToOne(() => {{referencedEntity}}{{#if onDelete}}, { onDelete: \"{{upper onDelete }}\" }{{/if}})\n {{referencedTable}}: {{referencedEntity}};\n {{/each}}\n}\\n\n{{/each}}\n`;\n","import { BetterAuthError, BetterAuthOptions } from \"better-auth\";\nimport {\n AdapterFactoryOptions,\n createAdapterFactory,\n Where,\n type AdapterFactoryCustomizeAdapterCreator,\n} from \"better-auth/adapters\";\nimport {\n DataSource,\n Equal,\n FindOptionsWhere,\n In,\n LessThan,\n LessThanOrEqual,\n Like,\n MoreThan,\n MoreThanOrEqual,\n Not,\n ObjectLiteral,\n} from \"typeorm\";\nimport { MigrationGenerator } from \"./generate-migration\";\nimport { TypeOrmAdapterConfig } from \"./types\";\nimport { EntityGenerator } from \"./generate-entity\";\n\nconst DEFAULT_ENTITIES = {\n user: \"User\",\n account: \"Account\",\n session: \"Session\",\n verification: \"Verification\",\n} as const;\n\nexport const typeormAdapter = (dataSource: DataSource, config: TypeOrmAdapterConfig = {}) => {\n config = {\n entitiesPath: \"./entities\",\n migrationsPath: \"./migrations\",\n provider: \"postgres\",\n generateEntities: true,\n generateMigrations: true,\n ...(config || {}),\n entities: {\n ...DEFAULT_ENTITIES,\n ...(config?.entities || {}),\n },\n };\n\n let lazyOptions: BetterAuthOptions | null = null;\n\n const convertOperatorToTypeORM = (operator: Where[\"operator\"], value: unknown) => {\n switch (operator) {\n case \"eq\":\n return Equal(value);\n case \"ne\":\n return Not(value);\n case \"lt\":\n return LessThan(value);\n case \"lte\":\n return LessThanOrEqual(value);\n case \"gt\":\n return MoreThan(value);\n case \"gte\":\n return MoreThanOrEqual(value);\n case \"in\":\n return In(value as unknown[]);\n case \"not_in\":\n return Not(In(value as unknown[]));\n case \"contains\":\n return Like(`%${value}%`);\n case \"starts_with\":\n return Like(`${value}%`);\n case \"ends_with\":\n return Like(`%${value}`);\n default:\n return value;\n }\n };\n\n const convertWhereToFindOptions = (where: Where[]): FindOptionsWhere<ObjectLiteral> => {\n if (!where || where.length === 0) return {};\n\n const findOptions: FindOptionsWhere<ObjectLiteral> = {};\n\n for (const w of where) {\n if (!w.operator) {\n findOptions[w.field] = w.value;\n } else {\n findOptions[w.field] = convertOperatorToTypeORM(w.operator, w.value);\n }\n }\n\n return findOptions;\n };\n\n const createCustomAdapter =\n (dataSource: DataSource): AdapterFactoryCustomizeAdapterCreator =>\n ({ getDefaultModelName, getFieldName, transformOutput }) => {\n const getRepositoryName = (model: string) => {\n const modelName = getDefaultModelName(model);\n const repositoryName =\n config.entities?.[modelName as keyof typeof config.entities] || modelName;\n return dataSource.getRepository(repositoryName);\n };\n\n const getMappedEntities = () => {\n const mappedEntities = { ...DEFAULT_ENTITIES };\n for (const key of Object.keys(lazyOptions as any)) {\n if (!(lazyOptions as any)[key].modelName) {\n continue;\n }\n const entity = DEFAULT_ENTITIES[key as keyof typeof DEFAULT_ENTITIES];\n const modelName = (lazyOptions as any)[key].modelName;\n (mappedEntities as any)[modelName] = entity;\n }\n return mappedEntities;\n };\n\n return {\n async create({ data, model }) {\n try {\n const repository = getRepositoryName(model);\n const entity = repository.create(data);\n const saved = await repository.save(entity);\n return saved as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to create ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async update({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n await repository.update(conditions, update as Record<string, any>);\n const updated = await repository.findOne({ where: conditions });\n\n if (!updated) return null;\n return updated as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to update ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async updateMany({ model, where, update }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n\n const result = await repository.update(conditions, update as Record<string, any>);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to updateMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async delete({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n await repository.delete(conditions);\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to delete ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async deleteMany({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.delete(conditions);\n return result.affected || 0;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to deleteMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findOne({ model, where, select }) {\n try {\n const repository = getRepositoryName(model);\n const defaultModelName = getDefaultModelName(model);\n const conditions = convertWhereToFindOptions(where);\n const result = await repository.findOne({ where: conditions, select });\n\n if (!result) return null;\n\n const output = await transformOutput(result, defaultModelName, select);\n return output as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findOne ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async findMany({ model, where, limit, sortBy, offset }) {\n try {\n const defaultModelName = getDefaultModelName(model);\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const result = await repository.find({\n where: conditions,\n take: limit,\n skip: offset,\n order: sortBy\n ? {\n [getFieldName({ model, field: sortBy.field })]:\n sortBy.direction.toUpperCase() as \"ASC\" | \"DESC\",\n }\n : undefined,\n });\n\n // Transform all results from database fields to logical fields\n const transformed = await Promise.all(\n result.map((r) => transformOutput(r, defaultModelName))\n );\n return transformed as any;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to findMany ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async count({ model, where }) {\n try {\n const repository = getRepositoryName(model);\n const conditions = convertWhereToFindOptions(where ?? []);\n const count = await repository.count({ where: conditions });\n return count;\n } catch (error: any) {\n throw new BetterAuthError(\n `Failed to count ${model}: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n },\n async createSchema({ tables }) {\n console.log(\"Creating database schema...\");\n\n if (config.generateEntities) {\n const mappedEntities = getMappedEntities();\n const entityGenerator = new EntityGenerator(config.provider!);\n await entityGenerator.generate(tables, config.entitiesPath!, mappedEntities);\n }\n\n if (!config.generateMigrations) {\n return { code: \"\", path: \"\" };\n }\n\n const migrationGenerator = new MigrationGenerator(config.provider!);\n const { code, migrationFileName } = await migrationGenerator.generate(tables);\n\n return { code, path: `${config.migrationsPath}/${migrationFileName}` };\n },\n options: config,\n };\n };\n\n let adapterOptions: AdapterFactoryOptions | null = null;\n adapterOptions = {\n config: {\n adapterId: \"typeorm\",\n adapterName: \"TypeORM Adapter\",\n usePlural: config?.usePlural ?? false,\n debugLogs: config?.debugLogs ?? false,\n supportsUUIDs: config.provider === \"postgres\" ? true : false,\n supportsJSON: config.provider === \"postgres\" ? true : false, // even though mysql also supports it, mysql requires to pass stringified json anyway.\n supportsArrays: config.provider === \"postgres\" ? true : false,\n transaction: config.transaction\n ? (cb) =>\n dataSource.transaction(async (entityManager) => {\n const adapter = createAdapterFactory({\n config: adapterOptions!.config,\n adapter: createCustomAdapter(entityManager as any),\n })(lazyOptions!);\n\n return cb(adapter);\n })\n : undefined,\n },\n adapter: (options) => {\n return createCustomAdapter(dataSource)(options);\n },\n };\n\n const adapter = createAdapterFactory(adapterOptions!);\n return (options: BetterAuthOptions) => {\n lazyOptions = options;\n return adapter(options);\n };\n};\n"]}
|