41 lines
1.1 KiB
CoffeeScript
41 lines
1.1 KiB
CoffeeScript
logger = (require 'logging').default 'login'
|
|
|
|
# session storage (volatile data)
|
|
session = (require '../../session')
|
|
# fftcg.db (persistent data)
|
|
fftcgdb = (require '../../db')
|
|
|
|
module.exports =
|
|
url: '/user/login'
|
|
method: 'POST'
|
|
schema: (require './user.schema')
|
|
|
|
handler: (request, reply) ->
|
|
new Promise (resolve) ->
|
|
session.check request.body.session ? ""
|
|
.then (user) ->
|
|
# active session found
|
|
logger.debug "OK '#{user.login}' resumed session '#{request.body.session}'"
|
|
resolve request.body.session
|
|
|
|
.catch ->
|
|
fftcgdb.login request.body.login, request.body.password
|
|
.then (user) ->
|
|
# login successful: start new session
|
|
logger.info "OK '#{request.body.login}'"
|
|
session.start user
|
|
.then (session_id) ->
|
|
resolve session_id
|
|
|
|
.catch (err) ->
|
|
# login failed
|
|
logger.info "FAIL '#{request.body.login}: #{err}'"
|
|
reply.send
|
|
success: false
|
|
message: err
|
|
|
|
.then (session_id) ->
|
|
#
|
|
reply.send
|
|
success: true
|
|
message: session_id
|