You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

107 lines
2.5 KiB

6 years ago
/*!
* lib/auth/auth-rest-api.js
* Copyright © 2019 Katana Cryptographic Ltd. All Rights Reserved.
*/
'use strict'
const bodyParser = require('body-parser')
const passport = require('passport')
const network = require('../bitcoin/network')
const keys = require('../../keys/')[network.key]
const HttpServer = require('../http-server/http-server')
const authentMgr = require('./authentication-manager')
const authorzMgr = require('./authorizations-manager')
/**
* Auth API endpoints
*/
class AuthRestApi {
/**
* Constructor
* @param {pushtx.HttpServer} httpServer - HTTP server
*/
constructor(httpServer) {
this.httpServer = httpServer
// Initialize passport
this.httpServer.app.use(passport.initialize())
// Check if authentication is activated
if (keys.auth.activeStrategy == null)
return
// Establish routes
const urlencodedParser = bodyParser.urlencoded({ extended: true })
this.httpServer.app.post(
'/auth/login',
urlencodedParser,
authentMgr.authenticate({session: false}),
authentMgr.serialize,
authorzMgr.generateAuthorizations.bind(authorzMgr),
this.login.bind(this),
HttpServer.sendAuthError
)
this.httpServer.app.post(
'/auth/logout',
urlencodedParser,
authorzMgr.revokeAuthorizations.bind(authorzMgr),
this.logout.bind(this),
HttpServer.sendAuthError
)
this.httpServer.app.post(
'/auth/refresh',
urlencodedParser,
authorzMgr.refreshAuthorizations.bind(authorzMgr),
this.refresh.bind(this),
HttpServer.sendAuthError
)
}
/**
* Login
* @param {object} req - http request object
* @param {object} res - http response object
*/
login(req, res) {
try {
const result = {authorizations: req.authorizations}
const ret = JSON.stringify(result, null, 2)
HttpServer.sendRawData(res, ret)
} catch(e) {
HttpServer.sendError(res, e)
}
}
/**
* Refresh
* @param {object} req - http request object
* @param {object} res - http response object
*/
refresh(req, res) {
try {
const result = {authorizations: req.authorizations}
const ret = JSON.stringify(result, null, 2)
HttpServer.sendRawData(res, ret)
} catch(e) {
HttpServer.sendError(res, e)
}
}
/**
* Logout
* @param {object} req - http request object
* @param {object} res - http response object
*/
logout(req, res) {
HttpServer.sendOk(res)
}
}
module.exports = AuthRestApi