Fixes #10 - Don't use defaults for json fields in migration

This commit is contained in:
Jamie Curnow 2018-09-03 09:50:18 +10:00
parent 02b4def04a
commit bbe02bc70a
12 changed files with 105 additions and 11 deletions

View File

@ -22,7 +22,7 @@ exports.up = function (knex/*, Promise*/) {
table.integer('user_id').notNull().unsigned(); table.integer('user_id').notNull().unsigned();
table.string('type', 30).notNull(); table.string('type', 30).notNull();
table.string('secret').notNull(); table.string('secret').notNull();
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
table.integer('is_deleted').notNull().unsigned().defaultTo(0); table.integer('is_deleted').notNull().unsigned().defaultTo(0);
}) })
.then(() => { .then(() => {
@ -77,7 +77,7 @@ exports.up = function (knex/*, Promise*/) {
table.integer('caching_enabled').notNull().unsigned().defaultTo(0); table.integer('caching_enabled').notNull().unsigned().defaultTo(0);
table.integer('block_exploits').notNull().unsigned().defaultTo(0); table.integer('block_exploits').notNull().unsigned().defaultTo(0);
table.text('advanced_config').notNull().defaultTo(''); table.text('advanced_config').notNull().defaultTo('');
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {
@ -96,7 +96,7 @@ exports.up = function (knex/*, Promise*/) {
table.integer('ssl_forced').notNull().unsigned().defaultTo(0); table.integer('ssl_forced').notNull().unsigned().defaultTo(0);
table.integer('block_exploits').notNull().unsigned().defaultTo(0); table.integer('block_exploits').notNull().unsigned().defaultTo(0);
table.text('advanced_config').notNull().defaultTo(''); table.text('advanced_config').notNull().defaultTo('');
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {
@ -112,7 +112,7 @@ exports.up = function (knex/*, Promise*/) {
table.integer('certificate_id').notNull().unsigned().defaultTo(0); table.integer('certificate_id').notNull().unsigned().defaultTo(0);
table.integer('ssl_forced').notNull().unsigned().defaultTo(0); table.integer('ssl_forced').notNull().unsigned().defaultTo(0);
table.text('advanced_config').notNull().defaultTo(''); table.text('advanced_config').notNull().defaultTo('');
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {
@ -129,7 +129,7 @@ exports.up = function (knex/*, Promise*/) {
table.integer('forwarding_port').notNull().unsigned(); table.integer('forwarding_port').notNull().unsigned();
table.integer('tcp_forwarding').notNull().unsigned().defaultTo(0); table.integer('tcp_forwarding').notNull().unsigned().defaultTo(0);
table.integer('udp_forwarding').notNull().unsigned().defaultTo(0); table.integer('udp_forwarding').notNull().unsigned().defaultTo(0);
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {
@ -142,7 +142,7 @@ exports.up = function (knex/*, Promise*/) {
table.integer('owner_user_id').notNull().unsigned(); table.integer('owner_user_id').notNull().unsigned();
table.integer('is_deleted').notNull().unsigned().defaultTo(0); table.integer('is_deleted').notNull().unsigned().defaultTo(0);
table.string('name').notNull(); table.string('name').notNull();
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {
@ -156,9 +156,9 @@ exports.up = function (knex/*, Promise*/) {
table.integer('is_deleted').notNull().unsigned().defaultTo(0); table.integer('is_deleted').notNull().unsigned().defaultTo(0);
table.string('provider').notNull(); table.string('provider').notNull();
table.string('nice_name').notNull().defaultTo(''); table.string('nice_name').notNull().defaultTo('');
table.json('domain_names').notNull().defaultTo('[]'); table.json('domain_names').notNull();
table.dateTime('expires_on').notNull(); table.dateTime('expires_on').notNull();
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {
@ -171,7 +171,7 @@ exports.up = function (knex/*, Promise*/) {
table.integer('access_list_id').notNull().unsigned(); table.integer('access_list_id').notNull().unsigned();
table.string('username').notNull(); table.string('username').notNull();
table.string('password').notNull(); table.string('password').notNull();
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {
@ -185,7 +185,7 @@ exports.up = function (knex/*, Promise*/) {
table.string('object_type').notNull().defaultTo(''); table.string('object_type').notNull().defaultTo('');
table.integer('object_id').notNull().unsigned().defaultTo(0); table.integer('object_id').notNull().unsigned().defaultTo(0);
table.string('action').notNull(); table.string('action').notNull();
table.json('meta').notNull().defaultTo('{}'); table.json('meta').notNull();
}); });
}) })
.then(() => { .then(() => {

View File

@ -14,6 +14,11 @@ class AccessList extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
} }
$beforeUpdate () { $beforeUpdate () {

View File

@ -12,6 +12,11 @@ class AccessListAuth extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
} }
$beforeUpdate () { $beforeUpdate () {

View File

@ -13,6 +13,11 @@ class AuditLog extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
} }
$beforeUpdate () { $beforeUpdate () {

View File

@ -29,6 +29,11 @@ class Auth extends Model {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
return encryptPassword.apply(this, queryContext); return encryptPassword.apply(this, queryContext);
} }

View File

@ -14,13 +14,31 @@ class Certificate extends Model {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for expires_on
if (typeof this.expires_on === 'undefined') { if (typeof this.expires_on === 'undefined') {
this.expires_on = Model.raw('NOW()'); this.expires_on = Model.raw('NOW()');
} }
// Default for domain_names
if (typeof this.domain_names === 'undefined') {
this.domain_names = [];
}
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
this.domain_names.sort();
} }
$beforeUpdate () { $beforeUpdate () {
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Sort domain_names
if (typeof this.domain_names !== 'undefined') {
this.domain_names.sort();
}
} }
static get name () { static get name () {

View File

@ -14,10 +14,27 @@ class DeadHost extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for domain_names
if (typeof this.domain_names === 'undefined') {
this.domain_names = [];
}
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
this.domain_names.sort();
} }
$beforeUpdate () { $beforeUpdate () {
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Sort domain_names
if (typeof this.domain_names !== 'undefined') {
this.domain_names.sort();
}
} }
static get name () { static get name () {

View File

@ -15,11 +15,24 @@ class ProxyHost extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for domain_names
if (typeof this.domain_names === 'undefined') {
this.domain_names = [];
}
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
this.domain_names.sort(); this.domain_names.sort();
} }
$beforeUpdate () { $beforeUpdate () {
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Sort domain_names
if (typeof this.domain_names !== 'undefined') { if (typeof this.domain_names !== 'undefined') {
this.domain_names.sort(); this.domain_names.sort();
} }

View File

@ -14,10 +14,27 @@ class RedirectionHost extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for domain_names
if (typeof this.domain_names === 'undefined') {
this.domain_names = [];
}
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
this.domain_names.sort();
} }
$beforeUpdate () { $beforeUpdate () {
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Sort domain_names
if (typeof this.domain_names !== 'undefined') {
this.domain_names.sort();
}
} }
static get name () { static get name () {

View File

@ -13,6 +13,11 @@ class Stream extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for meta
if (typeof this.meta === 'undefined') {
this.meta = {};
}
} }
$beforeUpdate () { $beforeUpdate () {

View File

@ -19,7 +19,6 @@ module.exports = function () {
let token_data = {}; let token_data = {};
let self = { let self = {
//return {
/** /**
* @param {Object} payload * @param {Object} payload
* @param {Object} [user_options] * @param {Object} [user_options]

View File

@ -13,6 +13,11 @@ class User extends Model {
$beforeInsert () { $beforeInsert () {
this.created_on = Model.raw('NOW()'); this.created_on = Model.raw('NOW()');
this.modified_on = Model.raw('NOW()'); this.modified_on = Model.raw('NOW()');
// Default for roles
if (typeof this.roles === 'undefined') {
this.roles = [];
}
} }
$beforeUpdate () { $beforeUpdate () {