| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 | // Objection Docs:// http://vincit.github.io/objection.js/const db             = require('../db');const helpers        = require('../lib/helpers');const Model          = require('objection').Model;const UserPermission = require('./user_permission');const now            = require('./now_helper');Model.knex(db);const boolFields = [	'is_deleted',	'is_disabled',];class User extends Model {	$beforeInsert () {		this.created_on  = now();		this.modified_on = now();		// Default for roles		if (typeof this.roles === 'undefined') {			this.roles = [];		}	}	$beforeUpdate () {		this.modified_on = now();	}	$parseDatabaseJson(json) {		json = super.$parseDatabaseJson(json);		return helpers.convertIntFieldsToBool(json, boolFields);	}	$formatDatabaseJson(json) {		json = helpers.convertBoolFieldsToInt(json, boolFields);		return super.$formatDatabaseJson(json);	}	static get name () {		return 'User';	}	static get tableName () {		return 'user';	}	static get jsonAttributes () {		return ['roles'];	}	static get relationMappings () {		return {			permissions: {				relation:   Model.HasOneRelation,				modelClass: UserPermission,				join:       {					from: 'user.id',					to:   'user_permission.user_id'				}			}		};	}}module.exports = User;
 |