mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-11-04 09:25:15 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			99 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
// Objection Docs:
 | 
						|
// http://vincit.github.io/objection.js/
 | 
						|
 | 
						|
const bcrypt  = require('bcrypt');
 | 
						|
const db      = require('../db');
 | 
						|
const helpers = require('../lib/helpers');
 | 
						|
const Model   = require('objection').Model;
 | 
						|
const User    = require('./user');
 | 
						|
const now     = require('./now_helper');
 | 
						|
 | 
						|
Model.knex(db);
 | 
						|
 | 
						|
const boolFields = [
 | 
						|
	'is_deleted',
 | 
						|
];
 | 
						|
 | 
						|
function encryptPassword () {
 | 
						|
	/* jshint -W040 */
 | 
						|
	let _this = this;
 | 
						|
 | 
						|
	if (_this.type === 'password' && _this.secret) {
 | 
						|
		return bcrypt.hash(_this.secret, 13)
 | 
						|
			.then(function (hash) {
 | 
						|
				_this.secret = hash;
 | 
						|
			});
 | 
						|
	}
 | 
						|
 | 
						|
	return null;
 | 
						|
}
 | 
						|
 | 
						|
class Auth extends Model {
 | 
						|
	$beforeInsert (queryContext) {
 | 
						|
		this.created_on  = now();
 | 
						|
		this.modified_on = now();
 | 
						|
 | 
						|
		// Default for meta
 | 
						|
		if (typeof this.meta === 'undefined') {
 | 
						|
			this.meta = {};
 | 
						|
		}
 | 
						|
 | 
						|
		return encryptPassword.apply(this, queryContext);
 | 
						|
	}
 | 
						|
 | 
						|
	$beforeUpdate (queryContext) {
 | 
						|
		this.modified_on = now();
 | 
						|
		return encryptPassword.apply(this, queryContext);
 | 
						|
	}
 | 
						|
 | 
						|
	$parseDatabaseJson(json) {
 | 
						|
		json = super.$parseDatabaseJson(json);
 | 
						|
		return helpers.convertIntFieldsToBool(json, boolFields);
 | 
						|
	}
 | 
						|
 | 
						|
	$formatDatabaseJson(json) {
 | 
						|
		json = helpers.convertBoolFieldsToInt(json, boolFields);
 | 
						|
		return super.$formatDatabaseJson(json);
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Verify a plain password against the encrypted password
 | 
						|
	 *
 | 
						|
	 * @param {String} password
 | 
						|
	 * @returns {Promise}
 | 
						|
	 */
 | 
						|
	verifyPassword (password) {
 | 
						|
		return bcrypt.compare(password, this.secret);
 | 
						|
	}
 | 
						|
 | 
						|
	static get name () {
 | 
						|
		return 'Auth';
 | 
						|
	}
 | 
						|
 | 
						|
	static get tableName () {
 | 
						|
		return 'auth';
 | 
						|
	}
 | 
						|
 | 
						|
	static get jsonAttributes () {
 | 
						|
		return ['meta'];
 | 
						|
	}
 | 
						|
 | 
						|
	static get relationMappings () {
 | 
						|
		return {
 | 
						|
			user: {
 | 
						|
				relation:   Model.HasOneRelation,
 | 
						|
				modelClass: User,
 | 
						|
				join:       {
 | 
						|
					from: 'auth.user_id',
 | 
						|
					to:   'user.id'
 | 
						|
				},
 | 
						|
				filter: {
 | 
						|
					is_deleted: 0
 | 
						|
				}
 | 
						|
			}
 | 
						|
		};
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
module.exports = Auth;
 |