我正在将用户保存在数据库中。
这是我要遵循的步骤
1)验证请求。
2)对密码进行哈希处理。
3)然后使用哈希密码将用户详细信息存储在用户集合中。
因此,在下面的代码中,我获得了hashPassword
方法,一旦我得到了哈希字符串,便用哈希字符串创建用户。订阅save
方法并将结果分配给观察者的下一个方法。
如何执行此zip()
或map()
运算符,而不是一次又一次地订阅。
createUser(req: Request, res: Response): Observable<mongoose.Document> {
const body = req.body
const self = this
return singleObservable(Observable.create((observer: Observer<mongoose.Document>) => {
const errorMessage = new UserValidator(req).validateRequest()
if (errorMessage) {
observer.error(errorMessage)
} else {
self.hashPassword(req.body.password).subscribe(new BaseObserver(
(value) => {
const newUser = new this.userModule({ email: req.body.email, username: req.body.username, password: value })
this.save(newUser).subscribe(new BaseObserver((value) => {
observer.next(value)
}, (err) => {
observer.error(err)
}))
}, (error) => observer.error(error)))
}
}))
}
private hashPassword(password: string): Observable<string> {
return singleObservable(Observable.create((observer: Observer<string>) => {
bcrypt.hash(password, 10, (err, result) => {
result.length > 0 ? observer.next(result) : observer.error(err)
})
}))
}
save<T extends mongoose.Document>(model: mongoose.Document): Observable<T> {
return singleObservable(Observable.create(function (observer: Observer<mongoose.Document>) {
model.save(function (err, object) {
emitResult(observer, object, err)
})
}))
}
emitResult<T, E>(observer: Observer<T>, result: T | null, err: E) {
result ? observer.next(result) : observer.error(err);
}
singleObservable<T>(observable: Observable<T>) : Observable<T> {
return observable.pipe(first())
}
答案 0 :(得分:1)
我使用flatMap
运算符解决了我的问题
createUser(req: Request, res: Response): Observable<mongoose.Document> {
const body = req.body
const self = this
const errorMessage = new UserValidator(req).validateRequest()
if (errorMessage) {
return throwError(errorMessage)
} else {
return self.hashPassword(req.body.password).pipe(flatMap((hashedString) => {
const newUser = new this.userModule({ email: req.body.email, username: req.body.username, password: hashedString })
return this.save(newUser)
}), catchError((err) => throwError(err))
}
}