Files
DefinitelyTyped/umzug/index.d.ts
2016-07-07 17:36:44 -07:00

193 lines
4.8 KiB
TypeScript

// Type definitions for Umzug v1.8.0
// Project: https://github.com/sequelize/umzug
// Definitions by: Ivan Drinchev <https://github.com/drinchev/>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
/// <reference types="bluebird" />
/// <reference types="sequelize" />
import Sequelize = require("sequelize");
declare namespace umzug {
interface MigrationOptions {
/*
* The params that gets passed to the migrations.
* Might be an array or a synchronous function which returns an array.
*/
params?: Array<any>;
/** The path to the migrations directory. */
path?: string;
/** The pattern that determines whether or not a file is a migration. */
pattern?: RegExp;
/**
* A function that receives and returns the to be executed function.
* This can be used to modify the function.
*/
wrap?: <T>(fn: T) => T;
}
interface JSONStorageOptions {
/**
* The path to the json storage.
* Defaults to process.cwd() + '/umzug.json';
*/
path?: string;
}
interface SequelizeStorageOptions {
/**
* The configured instance of Sequelize.
* Optional if `model` is passed.
*/
sequelize?: Sequelize.Sequelize;
/**
* The to be used Sequelize model.
* Must have column name matching `columnName` option
* Optional of `sequelize` is passed.
*/
model?: Sequelize.Model<any, any>;
/**
* The name of the to be used model.
* Defaults to 'SequelizeMeta'
*/
modelName?: string;
/**
* The name of table to create if `model` option is not supplied
* Defaults to `modelName`
*/
tableName?: string;
/**
* The name of table column holding migration name.
* Defaults to 'name'.
*/
columnName: string;
/**
* The type of the column holding migration name.
* Defaults to `Sequelize.STRING`
*/
columnType: Sequelize.DataTypeAbstract;
}
interface ExecuteOptions {
migrations?: Array<string>;
method?: string;
}
interface UmzugOptions {
/**
* The storage.
* Possible values: 'json', 'sequelize', an object
*/
storage?: string;
/**
* The options for the storage.
*/
storageOptions?: JSONStorageOptions | SequelizeStorageOptions | Object;
/**
* The logging function.
* A function that gets executed everytime migrations start and have ended.
*/
logging?: boolean | Function;
/**
* The name of the positive method in migrations.
*/
upName?: string;
/**
* The name of the negative method in migrations.
*/
downName?: string;
/**
* Options for defined migration
*/
migrations?: MigrationOptions;
}
interface UpDownToOptions {
/**
* It is also possible to pass the name of a migration in order to
* just run the migrations from the current state to the passed
* migration name.
*/
to: string;
}
interface UpDownMigrationsOptions {
/**
* Running specific migrations while ignoring the right order, can be
* done like this:
*/
migrations: Array<string>;
}
interface Migration {
path: string;
file: string;
}
interface Umzug {
/**
* The execute method is a general purpose function that runs for
* every specified migrations the respective function.
*/
execute(options?: ExecuteOptions): Promise<Migration[]>;
/**
* You can get a list of pending/not yet executed migrations like this:
*/
pending(): Promise<Migration[]>;
/**
* You can get a list of already executed migrations like this:
*/
executed(): Promise<Migration[]>;
/**
* The up method can be used to execute all pending migrations.
*/
up(migration?: string): Promise<Migration[]>;
up(migrations?: string[]): Promise<Migration[]>;
up(options?: UpDownToOptions | UpDownMigrationsOptions): Promise<Migration[]>;
/**
* The down method can be used to revert the last executed migration.
*/
down(migration?: string): Promise<Migration[]>;
down(migrations?: string[]): Promise<Migration[]>;
down(options?: UpDownToOptions | UpDownMigrationsOptions): Promise<Migration[]>;
}
interface UmzugStatic {
new (options?: UmzugOptions): Umzug;
}
}
declare var umzug: umzug.UmzugStatic;
export = umzug;