Skip to content

Instantly share code, notes, and snippets.

@timbaev
Last active January 28, 2019 19:45
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save timbaev/374db222c8768fc4f762b27de7dab313 to your computer and use it in GitHub Desktop.
Save timbaev/374db222c8768fc4f762b27de7dab313 to your computer and use it in GitHub Desktop.
func signIn(request: Request, user: User) throws -> Future<AccessDto> {
return User
.query(on: request)
.filter(\.login == user.login)
.first()
.unwrap(or: Abort(.badRequest, reason: "User with login \(user.login) not found"))
.flatMap { persistedUser in
let digest = try request.make(BCryptDigest.self)
if try digest.verify(user.password, created: persistedUser.password) {
let accessToken = try TokenHelpers.createAccessToken(from: persistedUser)
let expiredAt = try TokenHelpers.expiredDate(of: accessToken)
let refreshToken = TokenHelpers.createRefreshToken()
let accessDto = AccessDto(refreshToken: refreshToken, accessToken: accessToken, expiredAt: expiredAt)
return RefreshToken(token: refreshToken, userID: try persistedUser.requireID())
.save(on: request)
.transform(to: accessDto)
} else {
throw Abort(.badRequest, reason: "Incorrect user password")
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment