UNPKG

screwdriver-data-schema

Version:
75 lines (69 loc) 2.32 kB
/* eslint-disable new-cap */ 'use strict'; const prefix = process.env.DATASTORE_SEQUELIZE_PREFIX || ''; const table = `${prefix}pipelines`; module.exports = { up: async (queryInterface, Sequelize) => { await queryInterface.sequelize.transaction(async transaction => { await queryInterface.createTable( table, { id: { allowNull: false, autoIncrement: true, primaryKey: true, type: Sequelize.INTEGER.UNSIGNED }, scmUri: { type: Sequelize.STRING(128) }, scmRepo: { type: Sequelize.TEXT }, createTime: { type: Sequelize.TEXT }, admins: { type: Sequelize.TEXT }, annotations: { type: Sequelize.TEXT }, scmContext: { type: Sequelize.STRING(128) }, lastEventId: { type: Sequelize.DOUBLE }, workflowGraph: { type: Sequelize.TEXT }, configPipelineId: { type: Sequelize.DOUBLE }, childPipelines: { type: Sequelize.TEXT }, name: { type: Sequelize.TEXT }, prChain: { type: Sequelize.BOOLEAN } }, { transaction } ); await queryInterface.addConstraint(table, { name: `${table}_scmUri_key`, fields: ['scmUri'], type: 'unique', transaction }); await queryInterface.addIndex(table, { name: `${table}_scm_uri`, fields: ['scmUri'], transaction }); }); } };