You've already forked nginx-proxy-manager
							
							
				mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-10-30 18:05:34 +03: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;
 |