2013-12-23 04:24:40 +00:00
|
|
|
Promise = require 'bluebird'
|
2014-03-19 19:17:07 +00:00
|
|
|
Knex = require 'knex'
|
2013-12-14 05:18:20 +00:00
|
|
|
|
2016-10-10 14:14:31 -07:00
|
|
|
knex = Knex(
|
2013-12-14 05:18:20 +00:00
|
|
|
client: 'sqlite3'
|
|
|
|
connection:
|
2014-04-27 22:41:59 +01:00
|
|
|
filename: '/data/database.sqlite'
|
2013-12-14 05:18:20 +00:00
|
|
|
)
|
|
|
|
|
2014-08-19 18:21:44 +01:00
|
|
|
addColumn = (table, column, type) ->
|
|
|
|
knex.schema.hasColumn(table, column)
|
|
|
|
.then (exists) ->
|
|
|
|
if not exists
|
|
|
|
knex.schema.table table, (t) ->
|
|
|
|
t[type](column)
|
|
|
|
|
2013-12-23 04:24:40 +00:00
|
|
|
knex.init = Promise.all([
|
2014-03-19 19:17:07 +00:00
|
|
|
knex.schema.hasTable('config')
|
|
|
|
.then (exists) ->
|
2013-12-23 04:24:40 +00:00
|
|
|
if not exists
|
2014-03-19 19:17:07 +00:00
|
|
|
knex.schema.createTable 'config', (t) ->
|
2013-12-23 04:24:40 +00:00
|
|
|
t.string('key').primary()
|
|
|
|
t.string('value')
|
2014-03-19 19:17:07 +00:00
|
|
|
|
2016-08-19 21:28:53 +00:00
|
|
|
knex.schema.hasTable('deviceConfig')
|
|
|
|
.then (exists) ->
|
|
|
|
if not exists
|
|
|
|
knex.schema.createTable 'deviceConfig', (t) ->
|
|
|
|
t.json('values')
|
|
|
|
t.json('targetValues')
|
2016-12-05 17:59:04 -03:00
|
|
|
.then ->
|
|
|
|
knex('deviceConfig').select()
|
|
|
|
.then (deviceConfigs) ->
|
|
|
|
knex('deviceConfig').insert({ values: '{}', targetValues: '{}' }) if deviceConfigs.length == 0
|
2016-08-19 21:28:53 +00:00
|
|
|
|
2014-03-19 19:17:07 +00:00
|
|
|
knex.schema.hasTable('app')
|
|
|
|
.then (exists) ->
|
2013-12-23 04:24:40 +00:00
|
|
|
if not exists
|
2014-03-19 19:17:07 +00:00
|
|
|
knex.schema.createTable 'app', (t) ->
|
2013-12-23 04:24:40 +00:00
|
|
|
t.increments('id').primary()
|
|
|
|
t.string('name')
|
|
|
|
t.string('containerId')
|
2014-07-19 03:24:01 +01:00
|
|
|
t.string('commit')
|
2013-12-23 04:24:40 +00:00
|
|
|
t.string('imageId')
|
2014-08-19 18:21:44 +01:00
|
|
|
t.string('appId')
|
2013-12-23 04:24:40 +00:00
|
|
|
t.boolean('privileged')
|
2014-04-03 18:16:37 +01:00
|
|
|
t.json('env')
|
2016-08-19 21:28:53 +00:00
|
|
|
t.json('config')
|
2014-07-19 03:24:01 +01:00
|
|
|
else
|
2014-08-19 18:21:44 +01:00
|
|
|
Promise.all [
|
|
|
|
addColumn('app', 'commit', 'string')
|
|
|
|
addColumn('app', 'appId', 'string')
|
2016-08-19 21:28:53 +00:00
|
|
|
addColumn('app', 'config', 'json')
|
2014-08-19 18:21:44 +01:00
|
|
|
]
|
2014-07-19 03:24:01 +01:00
|
|
|
|
2016-05-11 14:44:05 +00:00
|
|
|
knex.schema.hasTable('image')
|
|
|
|
.then (exists) ->
|
|
|
|
if not exists
|
|
|
|
knex.schema.createTable 'image', (t) ->
|
|
|
|
t.increments('id').primary()
|
|
|
|
t.string('repoTag')
|
2016-07-20 20:01:49 +00:00
|
|
|
knex.schema.hasTable('container')
|
|
|
|
.then (exists) ->
|
|
|
|
if not exists
|
|
|
|
knex.schema.createTable 'container', (t) ->
|
|
|
|
t.increments('id').primary()
|
|
|
|
t.string('containerId')
|
2016-05-11 14:44:05 +00:00
|
|
|
|
2016-08-19 21:28:53 +00:00
|
|
|
knex.schema.hasTable('dependentApp')
|
|
|
|
.then (exists) ->
|
|
|
|
if not exists
|
|
|
|
knex.schema.createTable 'dependentApp', (t) ->
|
|
|
|
t.increments('id').primary()
|
|
|
|
t.string('appId')
|
|
|
|
t.string('parentAppId')
|
|
|
|
t.string('name')
|
|
|
|
t.string('commit')
|
|
|
|
t.string('imageId')
|
|
|
|
t.json('config')
|
|
|
|
|
|
|
|
knex.schema.hasTable('dependentDevice')
|
|
|
|
.then (exists) ->
|
|
|
|
if not exists
|
|
|
|
knex.schema.createTable 'dependentDevice', (t) ->
|
|
|
|
t.increments('id').primary()
|
|
|
|
t.string('uuid')
|
|
|
|
t.string('appId')
|
|
|
|
t.string('device_type')
|
|
|
|
t.string('logs_channel')
|
|
|
|
t.string('deviceId')
|
|
|
|
t.boolean('is_online')
|
|
|
|
t.string('name')
|
|
|
|
t.string('status')
|
|
|
|
t.string('download_progress')
|
|
|
|
t.string('commit')
|
|
|
|
t.string('targetCommit')
|
|
|
|
t.json('environment')
|
|
|
|
t.json('targetEnvironment')
|
|
|
|
t.json('config')
|
|
|
|
t.json('targetConfig')
|
2016-10-07 14:16:27 +00:00
|
|
|
t.boolean('markedForDeletion')
|
|
|
|
else
|
|
|
|
addColumn('dependentDevice', 'markedForDeletion', 'boolean')
|
2013-12-23 04:24:40 +00:00
|
|
|
])
|
2013-12-14 05:18:20 +00:00
|
|
|
|
|
|
|
module.exports = knex
|