aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/models/application.ts
blob: acd0dfbf2e38fb9d8c5f651dd29a9b64046027ca (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import * as Sequelize from 'sequelize'

import { addMethodsToModel } from './utils'
import {
  ApplicationClass,
  ApplicationAttributes,
  ApplicationInstance,

  ApplicationMethods
} from './application-interface'

let Application: Sequelize.Model<ApplicationInstance, ApplicationAttributes>
let loadMigrationVersion: ApplicationMethods.LoadMigrationVersion
let updateMigrationVersion: ApplicationMethods.UpdateMigrationVersion

export default function defineApplication (sequelize: Sequelize.Sequelize, DataTypes) {
  Application = sequelize.define<ApplicationInstance, ApplicationAttributes>('Application',
    {
      migrationVersion: {
        type: DataTypes.INTEGER,
        defaultValue: 0,
        allowNull: false,
        validate: {
          isInt: true
        }
      }
    }
  )

  const classMethods = [ loadMigrationVersion, updateMigrationVersion ]
  addMethodsToModel(Application, classMethods)

  return Application
}

// ---------------------------------------------------------------------------

loadMigrationVersion = function (callback: (err: Error, version: number) => void) {
  const query = {
    attributes: [ 'migrationVersion' ]
  }

  return Application.findOne(query).asCallback(function (err, data) {
    const version = data ? data.migrationVersion : null

    return callback(err, version)
  })
}

updateMigrationVersion = function (newVersion: number, transaction: any, callback: any) {
  const options: Sequelize.UpdateOptions = {
    where: {}
  }

  if (!callback) {
    transaction = callback
  } else {
    options.transaction = transaction
  }

  return Application.update({ migrationVersion: newVersion }, options).asCallback(callback)
}