| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- // Objection Docs:
- // http://vincit.github.io/objection.js/
- import { Model } from "objection";
- import db from "../db.js";
- import { castJsonIfNeed, convertBoolFieldsToInt, convertIntFieldsToBool } from "../lib/helpers.js";
- import Certificate from "./certificate.js";
- import now from "./now_helper.js";
- import User from "./user.js";
- Model.knex(db());
- const boolFields = ["is_deleted", "ssl_forced", "http2_support", "enabled", "hsts_enabled", "hsts_subdomains"];
- class DeadHost extends Model {
- $beforeInsert() {
- this.created_on = now();
- this.modified_on = 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 = now();
- // Sort domain_names
- if (typeof this.domain_names !== "undefined") {
- this.domain_names.sort();
- }
- }
- $parseDatabaseJson(json) {
- const thisJson = super.$parseDatabaseJson(json);
- return convertIntFieldsToBool(thisJson, boolFields);
- }
- $formatDatabaseJson(json) {
- const thisJson = convertBoolFieldsToInt(json, boolFields);
- return super.$formatDatabaseJson(thisJson);
- }
- static get name() {
- return "DeadHost";
- }
- static get tableName() {
- return "dead_host";
- }
- static get jsonAttributes() {
- return ["domain_names", "meta"];
- }
- static get defaultAllowGraph() {
- return "[owner,certificate]";
- }
- static get defaultExpand() {
- return ["certificate", "owner"];
- }
- static get defaultOrder() {
- return [castJsonIfNeed("domain_names"), "ASC"];
- }
- static get relationMappings() {
- return {
- owner: {
- relation: Model.HasOneRelation,
- modelClass: User,
- join: {
- from: "dead_host.owner_user_id",
- to: "user.id",
- },
- modify: (qb) => {
- qb.where("user.is_deleted", 0);
- },
- },
- certificate: {
- relation: Model.HasOneRelation,
- modelClass: Certificate,
- join: {
- from: "dead_host.certificate_id",
- to: "certificate.id",
- },
- modify: (qb) => {
- qb.where("certificate.is_deleted", 0);
- },
- },
- };
- }
- }
- export default DeadHost;
|