57 lines
1.1 KiB
CoffeeScript
57 lines
1.1 KiB
CoffeeScript
# node libraries
|
|
# (require 'debug').enable 'FFTCG'
|
|
logger = (require 'logging').default 'FFTCG'
|
|
fastify = (require 'fastify')
|
|
logger: level: 'warn'
|
|
|
|
# fastify and plugin framework
|
|
fastify.register (require 'fastify-ws'), library: 'uws'
|
|
fastify.register (require 'fastify-cors')
|
|
|
|
# API routes
|
|
fastify.route (require "./routes/#{route}") for route in [
|
|
# test route
|
|
'test'
|
|
# log in user
|
|
'user/login'
|
|
# user info
|
|
'user/info'
|
|
# log out user
|
|
'user/logout'
|
|
# register user
|
|
'user/register'
|
|
# list decks
|
|
'decks/list'
|
|
# add deck
|
|
'decks/add'
|
|
# modify deck
|
|
'decks/modify'
|
|
]
|
|
|
|
# request logging
|
|
fastify.addHook 'onRequest', (req, res, next) ->
|
|
logger.debug 'requested', req.url
|
|
next()
|
|
|
|
# finalize loadup
|
|
fastify.ready()
|
|
.then ->
|
|
# create websocket on successful load
|
|
socket = (require './socket')
|
|
fastify.ws.on 'connection', socket
|
|
|
|
.catch (err) ->
|
|
# abort on load failure
|
|
logger.error err
|
|
process.exit 1
|
|
|
|
# start server
|
|
fastify.listen 3001, '0.0.0.0'
|
|
.catch (err) ->
|
|
logger.error err
|
|
|
|
# Handle termination
|
|
process.on 'SIGINT', ->
|
|
socket.close()
|
|
logger.info 'shutting down after SIGINT'
|
|
process.exit()
|