mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-27 11:18:14 +01: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
 |