diff options
Diffstat (limited to 'models')
-rw-r--r-- | models/Access.js (renamed from models/access.js) | 0 | ||||
-rw-r--r-- | models/Project.js (renamed from models/project.js) | 0 | ||||
-rw-r--r-- | models/User.js (renamed from models/user.js) | 23 |
3 files changed, 22 insertions, 1 deletions
diff --git a/models/access.js b/models/Access.js index ce75f8c..ce75f8c 100644 --- a/models/access.js +++ b/models/Access.js diff --git a/models/project.js b/models/Project.js index f29c7f8..f29c7f8 100644 --- a/models/project.js +++ b/models/Project.js diff --git a/models/user.js b/models/User.js index b61f7c9..4d32941 100644 --- a/models/user.js +++ b/models/User.js @@ -5,7 +5,7 @@ var mongoose = require('mongoose') , Schema = mongoose.Schema - , crypto =require('crypto') + , crypto = require('crypto') , authTypes = ['facebook', 'twitter']; @@ -20,6 +20,7 @@ var UserSchema = new Schema({ provider: String, hashed_password: String, salt: String, + accessToken: String, facebook: {}, twitter: {} }); @@ -98,6 +99,7 @@ UserSchema.methods = { return this.encryptPassword(plainText) === this.hashed_password; }, + /** * Make salt * @@ -109,6 +111,7 @@ UserSchema.methods = { return Math.round((new Date().valueOf() * Math.random())) + ''; }, + /** * Encrypt password * @@ -120,6 +123,24 @@ UserSchema.methods = { encryptPassword: function(password) { if (!password) return ''; return crypto.createHmac('sha1', this.salt).update(password).digest('hex'); + }, + + + /** + * Generate random access token for Remember Me function + * + * @return {String} + * @api public + */ + + generateRandomToken: function() { + var chars = "_!abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890" + , token = new Date().getTime() + '_'; + for (var i = 0; i < 16; i++) { + var x = Math.floor(Math.random() * 62); + token += chars.charAt(x); + } + return token; } } |