|
|
|
@ -1,7 +1,9 @@ |
|
|
|
|
'use strict'; |
|
|
|
|
|
|
|
|
|
const Tripcodes = require(__dirname+'/../db/trips.js') |
|
|
|
|
, crypto = require('crypto'); |
|
|
|
|
, util = require('util') |
|
|
|
|
, crypto = require('crypto') |
|
|
|
|
, randomBytes = util.promisify(crypto.randomBytes); |
|
|
|
|
|
|
|
|
|
module.exports = async (password) => { |
|
|
|
|
|
|
|
|
@ -12,7 +14,8 @@ module.exports = async (password) => { |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//fix, not sure how secure
|
|
|
|
|
const fullTripCodeHash = crypto.createHash('sha256').update(password + Math.random()).digest('base64'); |
|
|
|
|
const salt = (await randomBytes(128)).toString('hex'); |
|
|
|
|
const fullTripCodeHash = crypto.createHash('sha256').update(password + salt).digest('base64'); |
|
|
|
|
const trip = fullTripCodeHash.substring(fullTripCodeHash.length-10); |
|
|
|
|
await Tripcodes.insertOne(password, trip); |
|
|
|
|
return trip; |
|
|
|
|