bb0f4bfa62
* Fix wrapping when too many hosts are shown (#207) * Update npm packages, fixes CVE-2019-10757 * Revert some breaking packages * Major overhaul - Docker buildx support in CI - Cypress API Testing in CI - Restructured folder layout (insert clean face meme) - Added Swagger documentation and validate API against that (to be completed) - Use common base image for all supported archs, which includes updated nginx with ipv6 support - Updated certbot and changes required for it - Large amount of Hosts names will wrap in UI - Updated packages for frontend - Version bump 2.1.0 * Updated documentation * Fix JWT expire time going crazy. Now set to 1day * Backend JS formatting rules * Remove v1 importer, I doubt anyone is using v1 anymore * Added backend formatting rules and enforce them in Jenkins builds * Fix CI, doesn't need a tty * Thanks bcrypt. Why can't you just be normal. * Cleanup after syntax check Co-authored-by: Marcelo Castagna <margaale@users.noreply.github.com>
94 lines
2.0 KiB
JavaScript
94 lines
2.0 KiB
JavaScript
// Objection Docs:
|
|
// http://vincit.github.io/objection.js/
|
|
|
|
const db = require('../db');
|
|
const Model = require('objection').Model;
|
|
const User = require('./user');
|
|
const AccessList = require('./access_list');
|
|
const Certificate = require('./certificate');
|
|
|
|
Model.knex(db);
|
|
|
|
class ProxyHost extends Model {
|
|
$beforeInsert () {
|
|
this.created_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 () {
|
|
this.modified_on = Model.raw('NOW()');
|
|
|
|
// Sort domain_names
|
|
if (typeof this.domain_names !== 'undefined') {
|
|
this.domain_names.sort();
|
|
}
|
|
}
|
|
|
|
static get name () {
|
|
return 'ProxyHost';
|
|
}
|
|
|
|
static get tableName () {
|
|
return 'proxy_host';
|
|
}
|
|
|
|
static get jsonAttributes () {
|
|
return ['domain_names', 'meta', 'locations'];
|
|
}
|
|
|
|
static get relationMappings () {
|
|
return {
|
|
owner: {
|
|
relation: Model.HasOneRelation,
|
|
modelClass: User,
|
|
join: {
|
|
from: 'proxy_host.owner_user_id',
|
|
to: 'user.id'
|
|
},
|
|
modify: function (qb) {
|
|
qb.where('user.is_deleted', 0);
|
|
qb.omit(['id', 'created_on', 'modified_on', 'is_deleted', 'email', 'roles']);
|
|
}
|
|
},
|
|
access_list: {
|
|
relation: Model.HasOneRelation,
|
|
modelClass: AccessList,
|
|
join: {
|
|
from: 'proxy_host.access_list_id',
|
|
to: 'access_list.id'
|
|
},
|
|
modify: function (qb) {
|
|
qb.where('access_list.is_deleted', 0);
|
|
qb.omit(['id', 'created_on', 'modified_on', 'is_deleted']);
|
|
}
|
|
},
|
|
certificate: {
|
|
relation: Model.HasOneRelation,
|
|
modelClass: Certificate,
|
|
join: {
|
|
from: 'proxy_host.certificate_id',
|
|
to: 'certificate.id'
|
|
},
|
|
modify: function (qb) {
|
|
qb.where('certificate.is_deleted', 0);
|
|
qb.omit(['id', 'created_on', 'modified_on', 'is_deleted']);
|
|
}
|
|
}
|
|
};
|
|
}
|
|
}
|
|
|
|
module.exports = ProxyHost;
|