2021-12-29 18:08:41 -05:00
import request from 'request-promise' ;
import { Logger } from '../../utils/logger.js' ;
import { Common } from '../../utils/common.js' ;
let options = null ;
const logger = Logger ;
const common = Common ;
2022-05-01 13:35:20 -04:00
const responseData = { switch : { forwarding _events : [ ] , last _offset _index : 0 } , fees : { forwarding _events : [ ] , last _offset _index : 0 } } ;
2021-12-29 18:08:41 -05:00
const num _max _events = 100 ;
export const forwardingHistory = ( req , res , next ) => {
2024-06-10 12:40:37 -07:00
const { start _time , end _time } = req . body ;
getAllForwardingEvents ( req , start _time , end _time , 0 , 'switch' , ( eventsResponse ) => {
2021-12-29 18:08:41 -05:00
if ( eventsResponse . error ) {
res . status ( eventsResponse . error . statusCode ) . json ( eventsResponse ) ;
}
else {
res . status ( 201 ) . json ( eventsResponse ) ;
}
} ) ;
} ;
2022-05-01 13:35:20 -04:00
export const getAllForwardingEvents = ( req , start , end , offset , caller , callback ) => {
2021-12-29 18:08:41 -05:00
logger . log ( { selectedNode : req . session . selectedNode , level : 'INFO' , fileName : 'Switch' , msg : 'Getting Forwarding Events..' } ) ;
if ( offset === 0 ) {
2022-05-01 13:35:20 -04:00
responseData [ caller ] = { forwarding _events : [ ] , last _offset _index : 0 } ;
2021-12-29 18:08:41 -05:00
}
if ( ! req . session . selectedNode ) {
const err = common . handleError ( { message : 'Session Expired after a day\'s inactivity.' , statusCode : 401 } , 'Balance' , 'Get Balance Error' , req . session . selectedNode ) ;
return callback ( { message : err . message , error : err . error , statusCode : err . statusCode } ) ;
}
options = common . getOptions ( req ) ;
2024-06-10 12:40:37 -07:00
options . url = req . session . selectedNode . settings . lnServerUrl + '/v1/switch' ;
2021-12-29 18:08:41 -05:00
options . form = { } ;
if ( start ) {
options . form . start _time = start ;
}
if ( end ) {
options . form . end _time = end ;
}
options . form . num _max _events = num _max _events ;
options . form . index _offset = offset ;
options . form = JSON . stringify ( options . form ) ;
2022-01-16 15:55:50 -05:00
logger . log ( { selectedNode : req . session . selectedNode , level : 'DEBUG' , fileName : 'Switch' , msg : 'Forwarding Events Params' , data : options . form } ) ;
2021-12-29 18:08:41 -05:00
return request . post ( options ) . then ( ( body ) => {
2022-01-16 15:55:50 -05:00
logger . log ( { selectedNode : req . session . selectedNode , level : 'INFO' , fileName : 'Switch' , msg : 'Forwarding Events Received' , data : body } ) ;
2021-12-29 18:08:41 -05:00
if ( body . forwarding _events ) {
2022-05-01 13:35:20 -04:00
responseData [ caller ] . forwarding _events . push ( ... body . forwarding _events ) ;
responseData [ caller ] . last _offset _index = body . last _offset _index ? body . last _offset _index : 0 ;
2021-12-29 18:08:41 -05:00
}
if ( ! body . last _offset _index || body . last _offset _index < offset + num _max _events ) {
2022-05-01 13:35:20 -04:00
responseData [ caller ] . last _offset _index = body . last _offset _index ? body . last _offset _index : 0 ;
return callback ( responseData [ caller ] ) ;
2021-12-29 18:08:41 -05:00
}
else {
2022-05-01 13:35:20 -04:00
return getAllForwardingEvents ( req , start , end , offset + num _max _events , caller , callback ) ;
2021-12-29 18:08:41 -05:00
}
} ) . catch ( ( errRes ) => {
const err = common . handleError ( errRes , 'Switch' , 'Get All Forwarding Events Error' , req . session . selectedNode ) ;
return callback ( { message : err . message , error : err . error , statusCode : err . statusCode } ) ;
} ) ;
} ;