diff options
| author | Sam Wilkins <samwilkins333@gmail.com> | 2020-05-14 01:29:19 -0700 | 
|---|---|---|
| committer | Sam Wilkins <samwilkins333@gmail.com> | 2020-05-14 01:29:19 -0700 | 
| commit | f9385130fe297088754d4ce46d6c318c8be2121d (patch) | |
| tree | 0435585464fb614e6126f59136d64bcb87cb65bd /src/server/authentication/models/user_model.ts | |
| parent | 26e94812b02e178ead5d5be7cfe5bf73e92ac875 (diff) | |
server side restructure, some documentation to accompany new wiki overview entry
Diffstat (limited to 'src/server/authentication/models/user_model.ts')
| -rw-r--r-- | src/server/authentication/models/user_model.ts | 86 | 
1 files changed, 0 insertions, 86 deletions
| diff --git a/src/server/authentication/models/user_model.ts b/src/server/authentication/models/user_model.ts deleted file mode 100644 index a0b688328..000000000 --- a/src/server/authentication/models/user_model.ts +++ /dev/null @@ -1,86 +0,0 @@ -//@ts-ignore -import * as bcrypt from "bcrypt-nodejs"; -//@ts-ignore -import * as mongoose from 'mongoose'; - -export type DashUserModel = mongoose.Document & { -    email: String, -    password: string, -    passwordResetToken?: string, -    passwordResetExpires?: Date, - -    userDocumentId: string; - -    profile: { -        name: string, -        gender: string, -        location: string, -        website: string, -        picture: string -    }, - -    comparePassword: comparePasswordFunction, -}; - -type comparePasswordFunction = (candidatePassword: string, cb: (err: any, isMatch: any) => {}) => void; - -export type AuthToken = { -    accessToken: string, -    kind: string -}; - -const userSchema = new mongoose.Schema({ -    email: String, -    password: String, -    passwordResetToken: String, -    passwordResetExpires: Date, - -    userDocumentId: String, - -    facebook: String, -    twitter: String, -    google: String, - -    profile: { -        name: String, -        gender: String, -        location: String, -        website: String, -        picture: String -    } -}, { timestamps: true }); - -/** - * Password hash middleware. - */ -userSchema.pre("save", function save(next) { -    const user = this as DashUserModel; -    if (!user.isModified("password")) { -        return next(); -    } -    bcrypt.genSalt(10, (err, salt) => { -        if (err) { -            return next(err); -        } -        bcrypt.hash(user.password, salt, () => void {}, (err: mongoose.Error, hash) => { -            if (err) { -                return next(err); -            } -            user.password = hash; -            next(); -        }); -    }); -}); - -const comparePassword: comparePasswordFunction = function (this: DashUserModel, candidatePassword, cb) { -    // Choose one of the following bodies for authentication logic. -    // secure (expected, default) -    bcrypt.compare(candidatePassword, this.password, cb); -    // bypass password (debugging) -    // cb(undefined, true); -}; - -userSchema.methods.comparePassword = comparePassword; - -const User = mongoose.model("User", userSchema); -export default User;
\ No newline at end of file | 
