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 ;
let responseData = { forwarding _events : [ ] , last _offset _index : 0 } ;
const num _max _events = 100 ;
export const forwardingHistory = ( req , res , next ) => {
getAllForwardingEvents ( req , req . body . start _time , req . body . end _time , 0 , ( eventsResponse ) => {
if ( eventsResponse . error ) {
res . status ( eventsResponse . error . statusCode ) . json ( eventsResponse ) ;
}
else {
res . status ( 201 ) . json ( eventsResponse ) ;
}
} ) ;
} ;
export const getAllForwardingEvents = ( req , start , end , offset , callback ) => {
logger . log ( { selectedNode : req . session . selectedNode , level : 'INFO' , fileName : 'Switch' , msg : 'Getting Forwarding Events..' } ) ;
if ( offset === 0 ) {
responseData = { forwarding _events : [ ] , last _offset _index : 0 } ;
}
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 ) {
responseData . forwarding _events . push ( ... body . forwarding _events ) ;
}
if ( ! body . last _offset _index || body . last _offset _index < offset + num _max _events ) {
responseData . last _offset _index = body . last _offset _index ? body . last _offset _index : 0 ;
if ( responseData . forwarding _events ) {
responseData . forwarding _events = common . sortDescByKey ( responseData . forwarding _events , 'timestamp' ) ;
}
return callback ( responseData ) ;
}
else {
return getAllForwardingEvents ( req , start , end , offset + num _max _events , callback ) ;
}
} ) . 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 } ) ;
} ) ;
} ;