var request = require('request-promise'); var common = require('../../common'); var logger = require('../shared/logger'); var options = {}; exports.getInfo = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Boltz Get Info Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/info'; request(options).then(function (body) { logger.info({fileName: 'Boltz', msg: 'Boltz Get Info: ' + JSON.stringify(body)}); res.status(200).json(body); }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 22, msg: 'Boltz Get Info Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Boltz Get Info Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); }; exports.getServiceInfo = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Boltz Get Service Info Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/serviceinfo'; request(options).then(function (body) { logger.info({fileName: 'Boltz', msg: 'Boltz Get Service Info: ' + JSON.stringify(body)}); res.status(200).json(body); }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 46, msg: 'Boltz Get Service Info Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Boltz Get Service Info Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); }; exports.listSwaps = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Boltz List Swaps Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/listswaps'; request(options).then(function (body) { logger.info({fileName: 'Boltz', msg: 'Boltz List Swaps Info: ' + JSON.stringify(body)}); if (body && body.swaps && body.swaps.length && body.swaps.length > 0) { body.swaps = body.swaps.reverse(); } if (body && body.reverseSwaps && body.reverseSwaps.length && body.reverseSwaps.length > 0) { body.reverseSwaps = body.reverseSwaps.reverse(); } res.status(200).json(body); }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 70, msg: 'Boltz List Swaps Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Boltz List Swaps Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); }; exports.getSwapInfo = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Boltz Swap Info Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/swap/' + req.params.swapId; request(options).then(function (body) { logger.info({fileName: 'Boltz', msg: 'Boltz Swap Info: ' + JSON.stringify(body)}); res.status(200).json(body); }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 94, msg: 'Boltz Swap Info Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Boltz Swap Info Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); }; exports.createSwap = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Create Swap Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/createswap'; options.body = { amount: req.body.amount }; if (req.body.address !== '') { options.body.address = req.body.address; } logger.info({fileName: 'Boltz', msg: 'Create Swap Body: ' + JSON.stringify(options.body)}); request.post(options).then(createSwapRes => { logger.info({fileName: 'Boltz', msg: 'Create Swap Response: ' + JSON.stringify(createSwapRes)}); if(!createSwapRes || createSwapRes.error) { logger.error({fileName: 'Boltz', lineNum: 112, msg: 'Create Swap Error: ' + JSON.stringify(createSwapRes.error)}); res.status(500).json({ message: 'Create Swap Failed!', error: (!createSwapRes) ? 'Error From Server!' : createSwapRes.error.message }); } else { res.status(201).json(createSwapRes); } }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 129, msg: 'Create Swap Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Create Swap Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); }; exports.createReverseSwap = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Create Reverse Swap Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/createreverseswap'; options.body = { amount: req.body.amount }; if (req.body.address !== '') { options.body.address = req.body.address; } logger.info({fileName: 'Boltz', msg: 'Create Reverse Swap Body: ' + JSON.stringify(options.body)}); request.post(options).then(createReverseSwapRes => { logger.info({fileName: 'Boltz', msg: 'Create Reverse Swap Response: ' + JSON.stringify(createReverseSwapRes)}); if(!createReverseSwapRes || createReverseSwapRes.error) { logger.error({fileName: 'Boltz', lineNum: 147, msg: 'Create Reverse Swap Error: ' + JSON.stringify(createReverseSwapRes.error)}); res.status(500).json({ message: 'Create Reverse Swap Failed!', error: (!createReverseSwapRes) ? 'Error From Server!' : createReverseSwapRes.error.message }); } else { res.status(201).json(createReverseSwapRes); } }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 164, msg: 'Create Reverse Swap Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Create Reverse Swap Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); }; exports.createChannel = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Create Channel Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/createchannel'; options.body = { amount: req.body.amount }; if (req.body.address !== '') { options.body.address = req.body.address; } logger.info({fileName: 'Boltz', msg: 'Create Channel Body: ' + JSON.stringify(options.body)}); request.post(options).then(createChannelRes => { logger.info({fileName: 'Boltz', msg: 'Create Channel Response: ' + JSON.stringify(createChannelRes)}); if(!createChannelRes || createChannelRes.error) { logger.error({fileName: 'Boltz', lineNum: 182, msg: 'Create Channel Error: ' + JSON.stringify(createChannelRes.error)}); res.status(500).json({ message: 'Create Channel Failed!', error: (!createChannelRes) ? 'Error From Server!' : createChannelRes.error.message }); } else { res.status(201).json(createChannelRes); } }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 199, msg: 'Create Channel Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Create Channel Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); }; exports.deposit = (req, res, next) => { options = common.getBoltzServerOptions(); if(options.url === '') { return res.status(500).json({message: "Deposit Failed!",error: { message: 'Boltz Server URL is missing in the configuration.'}}); } options.url = options.url + '/v1/deposit'; request.post(options).then(depositRes => { logger.info({fileName: 'Boltz', msg: 'Deposit Response: ' + JSON.stringify(depositRes)}); if(!depositRes || depositRes.error) { logger.error({fileName: 'Boltz', lineNum: 214, msg: 'Deposit Error: ' + JSON.stringify(depositRes.error)}); res.status(500).json({ message: 'Deposit Failed!', error: (!depositRes) ? 'Error From Server!' : depositRes.error.message }); } else { res.status(201).json(depositRes); } }) .catch(errRes => { let err = JSON.parse(JSON.stringify(errRes)); if (err.options && err.options.headers && err.options.headers['Grpc-Metadata-macaroon']) { delete err.options.headers['Grpc-Metadata-macaroon']; } if (err.response && err.response.request && err.response.request.headers && err.response.request.headers['Grpc-Metadata-macaroon']) { delete err.response.request.headers['Grpc-Metadata-macaroon']; } logger.error({fileName: 'Boltz', lineNum: 231, msg: 'Deposit Error: ' + JSON.stringify(err)}); return res.status(500).json({ message: "Deposit Failed!", error: (err.error && err.error.error) ? err.error.error : (err.error) ? err.error : err }); }); };