2021-12-29 18:08:41 -05:00
import request from 'request-promise' ;
import { Logger , LoggerService } from '../../utils/logger.js' ;
import { Common , CommonService } from '../../utils/common.js' ;
let options = null ;
const logger : LoggerService = Logger ;
const common : CommonService = 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 ) = > {
2022-05-01 13:35:20 -04:00
getAllForwardingEvents ( req , req . body . start_time , req . body . 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..' } ) ;
2022-05-01 13:35:20 -04:00
if ( offset === 0 ) { 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 ) ;
options . url = req . session . selectedNode . ln_server_url + '/v1/switch' ;
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 ;
if ( responseData [ caller ] . forwarding_events ) {
responseData [ caller ] . forwarding_events = common . sortDescByKey ( responseData [ caller ] . forwarding_events , 'timestamp' ) ;
2021-12-29 18:08:41 -05:00
}
2022-05-01 13:35:20 -04:00
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 } ) ;
} ) ;
} ;