mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-18 11:18:10 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			85 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.SequelizeStorage = void 0;
 | |
| const DIALECTS_WITH_CHARSET_AND_COLLATE = new Set(['mysql', 'mariadb']);
 | |
| class SequelizeStorage {
 | |
|     /**
 | |
|       Constructs Sequelize based storage. Migrations will be stored in a SequelizeMeta table using the given instance of Sequelize.
 | |
|   
 | |
|       If a model is given, it will be used directly as the model for the SequelizeMeta table. Otherwise, it will be created automatically according to the given options.
 | |
|   
 | |
|       If the table does not exist it will be created automatically upon the logging of the first migration.
 | |
|       */
 | |
|     constructor(options) {
 | |
|         var _a, _b, _c, _d, _e, _f;
 | |
|         if (!options || (!options.model && !options.sequelize)) {
 | |
|             throw new Error('One of "sequelize" or "model" storage option is required');
 | |
|         }
 | |
|         this.sequelize = (_a = options.sequelize) !== null && _a !== void 0 ? _a : options.model.sequelize;
 | |
|         this.columnType = (_b = options.columnType) !== null && _b !== void 0 ? _b : this.sequelize.constructor.DataTypes.STRING;
 | |
|         this.columnName = (_c = options.columnName) !== null && _c !== void 0 ? _c : 'name';
 | |
|         this.timestamps = (_d = options.timestamps) !== null && _d !== void 0 ? _d : false;
 | |
|         this.modelName = (_e = options.modelName) !== null && _e !== void 0 ? _e : 'SequelizeMeta';
 | |
|         this.tableName = options.tableName;
 | |
|         this.schema = options.schema;
 | |
|         this.model = (_f = options.model) !== null && _f !== void 0 ? _f : this.getModel();
 | |
|     }
 | |
|     getModel() {
 | |
|         var _a;
 | |
|         if (this.sequelize.isDefined(this.modelName)) {
 | |
|             // eslint-disable-next-line @typescript-eslint/no-unsafe-return
 | |
|             return this.sequelize.model(this.modelName);
 | |
|         }
 | |
|         const dialectName = (_a = this.sequelize.dialect) === null || _a === void 0 ? void 0 : _a.name;
 | |
|         const hasCharsetAndCollate = dialectName && DIALECTS_WITH_CHARSET_AND_COLLATE.has(dialectName);
 | |
|         return this.sequelize.define(this.modelName, {
 | |
|             [this.columnName]: {
 | |
|                 type: this.columnType,
 | |
|                 allowNull: false,
 | |
|                 unique: true,
 | |
|                 primaryKey: true,
 | |
|                 autoIncrement: false,
 | |
|             },
 | |
|         }, {
 | |
|             tableName: this.tableName,
 | |
|             schema: this.schema,
 | |
|             timestamps: this.timestamps,
 | |
|             charset: hasCharsetAndCollate ? 'utf8' : undefined,
 | |
|             collate: hasCharsetAndCollate ? 'utf8_unicode_ci' : undefined,
 | |
|         });
 | |
|     }
 | |
|     async syncModel() {
 | |
|         await this.model.sync();
 | |
|     }
 | |
|     async logMigration({ name: migrationName }) {
 | |
|         await this.syncModel();
 | |
|         await this.model.create({
 | |
|             [this.columnName]: migrationName,
 | |
|         });
 | |
|     }
 | |
|     async unlogMigration({ name: migrationName }) {
 | |
|         await this.syncModel();
 | |
|         await this.model.destroy({
 | |
|             where: {
 | |
|                 [this.columnName]: migrationName,
 | |
|             },
 | |
|         });
 | |
|     }
 | |
|     async executed() {
 | |
|         await this.syncModel();
 | |
|         const migrations = await this.model.findAll({ order: [[this.columnName, 'ASC']] });
 | |
|         return migrations.map(migration => {
 | |
|             const name = migration[this.columnName];
 | |
|             if (typeof name !== 'string') {
 | |
|                 throw new TypeError(`Unexpected migration name type: expected string, got ${typeof name}`);
 | |
|             }
 | |
|             return name;
 | |
|         });
 | |
|     }
 | |
|     // TODO remove this
 | |
|     _model() {
 | |
|         return this.model;
 | |
|     }
 | |
| }
 | |
| exports.SequelizeStorage = SequelizeStorage;
 | |
| //# sourceMappingURL=sequelize.js.map
 |