mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-11-04 09:25:15 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			78 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import { Model } from "objection";
 | 
						|
import db from "../db.js";
 | 
						|
import { 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", "enabled", "tcp_forwarding", "udp_forwarding"];
 | 
						|
 | 
						|
class Stream extends Model {
 | 
						|
	$beforeInsert() {
 | 
						|
		this.created_on = now();
 | 
						|
		this.modified_on = now();
 | 
						|
 | 
						|
		// Default for meta
 | 
						|
		if (typeof this.meta === "undefined") {
 | 
						|
			this.meta = {};
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	$beforeUpdate() {
 | 
						|
		this.modified_on = now();
 | 
						|
	}
 | 
						|
 | 
						|
	$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 "Stream";
 | 
						|
	}
 | 
						|
 | 
						|
	static get tableName() {
 | 
						|
		return "stream";
 | 
						|
	}
 | 
						|
 | 
						|
	static get jsonAttributes() {
 | 
						|
		return ["meta"];
 | 
						|
	}
 | 
						|
 | 
						|
	static get relationMappings() {
 | 
						|
		return {
 | 
						|
			owner: {
 | 
						|
				relation: Model.HasOneRelation,
 | 
						|
				modelClass: User,
 | 
						|
				join: {
 | 
						|
					from: "stream.owner_user_id",
 | 
						|
					to: "user.id",
 | 
						|
				},
 | 
						|
				modify: (qb) => {
 | 
						|
					qb.where("user.is_deleted", 0);
 | 
						|
				},
 | 
						|
			},
 | 
						|
			certificate: {
 | 
						|
				relation: Model.HasOneRelation,
 | 
						|
				modelClass: Certificate,
 | 
						|
				join: {
 | 
						|
					from: "stream.certificate_id",
 | 
						|
					to: "certificate.id",
 | 
						|
				},
 | 
						|
				modify: (qb) => {
 | 
						|
					qb.where("certificate.is_deleted", 0);
 | 
						|
				},
 | 
						|
			},
 | 
						|
		};
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
export default Stream;
 |