Server: fix remaining milli seconds before the next requests feature
This commit is contained in:
parent
1ab844d859
commit
5abeec313f
|
@ -28,11 +28,9 @@ function getStatsRequests (req, res, next) {
|
||||||
Request.list(function (err, requests) {
|
Request.list(function (err, requests) {
|
||||||
if (err) return next(err)
|
if (err) return next(err)
|
||||||
|
|
||||||
const remainingMilliSeconds = constants.REQUESTS_INTERVAL - (Date.now() % constants.REQUESTS_INTERVAL)
|
|
||||||
|
|
||||||
return res.json({
|
return res.json({
|
||||||
requests: requests,
|
requests: requests,
|
||||||
remainingMilliSeconds: remainingMilliSeconds,
|
remainingMilliSeconds: Request.remainingMilliSeconds(),
|
||||||
milliSecondsInterval: constants.REQUESTS_INTERVAL
|
milliSecondsInterval: constants.REQUESTS_INTERVAL
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -14,6 +14,7 @@ const Pod = mongoose.model('Pod')
|
||||||
const Video = mongoose.model('Video')
|
const Video = mongoose.model('Video')
|
||||||
|
|
||||||
let timer = null
|
let timer = null
|
||||||
|
let lastRequestTimestamp = 0
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -27,7 +28,8 @@ RequestSchema.statics = {
|
||||||
deactivate,
|
deactivate,
|
||||||
flush,
|
flush,
|
||||||
forceSend,
|
forceSend,
|
||||||
list
|
list,
|
||||||
|
remainingMilliSeconds
|
||||||
}
|
}
|
||||||
|
|
||||||
RequestSchema.pre('save', function (next) {
|
RequestSchema.pre('save', function (next) {
|
||||||
|
@ -54,12 +56,19 @@ mongoose.model('Request', RequestSchema)
|
||||||
|
|
||||||
function activate () {
|
function activate () {
|
||||||
logger.info('Requests scheduler activated.')
|
logger.info('Requests scheduler activated.')
|
||||||
timer = setInterval(makeRequests.bind(this), constants.REQUESTS_INTERVAL)
|
lastRequestTimestamp = Date.now()
|
||||||
|
|
||||||
|
const self = this
|
||||||
|
timer = setInterval(function () {
|
||||||
|
lastRequestTimestamp = Date.now()
|
||||||
|
makeRequests.call(self)
|
||||||
|
}, constants.REQUESTS_INTERVAL)
|
||||||
}
|
}
|
||||||
|
|
||||||
function deactivate () {
|
function deactivate () {
|
||||||
logger.info('Requests scheduler deactivated.')
|
logger.info('Requests scheduler deactivated.')
|
||||||
clearInterval(timer)
|
clearInterval(timer)
|
||||||
|
timer = null
|
||||||
}
|
}
|
||||||
|
|
||||||
function flush () {
|
function flush () {
|
||||||
|
@ -77,6 +86,12 @@ function list (callback) {
|
||||||
this.find({ }, callback)
|
this.find({ }, callback)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function remainingMilliSeconds () {
|
||||||
|
if (timer === null) return -1
|
||||||
|
|
||||||
|
return constants.REQUESTS_INTERVAL - (Date.now() - lastRequestTimestamp)
|
||||||
|
}
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
|
|
||||||
// Make a requests to friends of a certain type
|
// Make a requests to friends of a certain type
|
||||||
|
@ -159,7 +174,7 @@ function makeRequests () {
|
||||||
return callbackEach()
|
return callbackEach()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Maybe the pod is not our friend anymore so simply remove them
|
// Maybe the pod is not our friend anymore so simply remove it
|
||||||
if (!toPod) {
|
if (!toPod) {
|
||||||
removePodOf.call(self, requestToMake.ids, toPodId)
|
removePodOf.call(self, requestToMake.ids, toPodId)
|
||||||
return callbackEach()
|
return callbackEach()
|
||||||
|
|
Loading…
Reference in New Issue