redirection_host.js 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. // Objection Docs:
  2. // http://vincit.github.io/objection.js/
  3. 'use strict';
  4. const db = require('../db');
  5. const Model = require('objection').Model;
  6. const User = require('./user');
  7. const Certificate = require('./certificate');
  8. Model.knex(db);
  9. class RedirectionHost extends Model {
  10. $beforeInsert () {
  11. this.created_on = Model.raw('NOW()');
  12. this.modified_on = Model.raw('NOW()');
  13. }
  14. $beforeUpdate () {
  15. this.modified_on = Model.raw('NOW()');
  16. }
  17. static get name () {
  18. return 'RedirectionHost';
  19. }
  20. static get tableName () {
  21. return 'redirection_host';
  22. }
  23. static get jsonAttributes () {
  24. return ['domain_names', 'meta'];
  25. }
  26. static get relationMappings () {
  27. return {
  28. owner: {
  29. relation: Model.HasOneRelation,
  30. modelClass: User,
  31. join: {
  32. from: 'redirection_host.owner_user_id',
  33. to: 'user.id'
  34. },
  35. modify: function (qb) {
  36. qb.where('user.is_deleted', 0);
  37. qb.omit(['id', 'created_on', 'modified_on', 'is_deleted', 'email', 'roles']);
  38. }
  39. },
  40. certificate: {
  41. relation: Model.HasOneRelation,
  42. modelClass: Certificate,
  43. join: {
  44. from: 'redirection_host.certificate_id',
  45. to: 'certificate.id'
  46. },
  47. modify: function (qb) {
  48. qb.where('certificate.is_deleted', 0);
  49. qb.omit(['id', 'created_on', 'modified_on', 'is_deleted']);
  50. }
  51. }
  52. };
  53. }
  54. }
  55. module.exports = RedirectionHost;