This repository has been archived on 2024-04-29. You can view files and clone it, but cannot push or open issues or pull requests.
node-fftcg/backend/routes/user/login.coffee

42 lines
1.2 KiB
CoffeeScript
Raw Normal View History

2019-05-09 12:32:28 +00:00
logger = (require 'logging').default '/user/login'
2019-02-19 18:57:22 +00:00
# session storage (volatile data)
session = (require '../../session')
# fftcg.db (persistent data)
fftcgdb = (require '../../db')
module.exports =
2019-02-16 18:04:16 +00:00
url: '/user/login'
method: 'POST'
2019-02-19 18:57:22 +00:00
schema: (require './user.schema')
2019-02-16 18:04:16 +00:00
handler: (request, reply) ->
new Promise (resolve) ->
2019-05-07 15:37:07 +00:00
session.check request.body.session ? ""
2019-02-16 18:04:16 +00:00
.then (user) ->
# active session found
2019-05-07 15:37:07 +00:00
logger.debug "OK '#{user.login}' resumed session '#{request.body.session}'"
resolve request.body.session
2019-02-16 18:04:16 +00:00
.catch ->
2019-02-19 18:57:22 +00:00
fftcgdb.login request.body.login, request.body.password
2019-02-16 18:04:16 +00:00
.then (user) ->
# login successful: start new session
2019-02-19 18:57:22 +00:00
logger.info "OK '#{request.body.login}'"
session.start user
2019-05-08 16:45:24 +00:00
.then (cookie_data) ->
resolve cookie_data
2019-02-16 18:04:16 +00:00
.catch (err) ->
# login failed
2019-05-07 15:37:07 +00:00
logger.info "FAIL '#{request.body.login}: #{err}'"
2019-02-16 18:04:16 +00:00
reply.send
success: false
2019-05-07 15:37:07 +00:00
message: err
2019-02-16 18:04:16 +00:00
2019-05-08 16:45:24 +00:00
.then (cookie_data) ->
2019-05-07 20:29:01 +00:00
# login or resume successful
2019-02-16 18:04:16 +00:00
reply.send
success: true
2019-05-08 16:45:24 +00:00
message: JSON.stringify cookie_data