'use strict';


var bcrypt = require('bcryptjs');

process.on('message', function(m) {
	if (m.type === 'hash') {
		hash(m.rounds, m.password);
	} else if (m.type === 'compare') {
		compare(m.password, m.hash);
	}
});

function hash(rounds, password) {
	bcrypt.genSalt(rounds, function(err, salt) {
		if (err) {
			return process.send({type:'hash', err: {message: err.message}});
		}
		bcrypt.hash(password, salt, function(err, hash) {
			process.send({type:'hash', err: err ? {message: err.message} : null, hash: hash, password: password});
		});
	});
}

function compare(password, hash) {
	bcrypt.compare(password, hash, function(err, res) {
		process.send({type:'compare', err: err ? {message: err.message} : null, hash: hash, password: password, result: res});
	});
}