/* eslint-disable handle-callback-err, max-len, no-unused-vars, */ // TODO: This file was created by bulk-decaffeinate. // Fix any style issues and re-enable lint. /* * decaffeinate suggestions: * DS102: Remove unnecessary code created because of implicit returns * DS207: Consider shorter variations of null checks * Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md */ let RateLimiter const settings = require('settings-sharelatex') const Metrics = require('metrics-sharelatex') const RedisWrapper = require('./RedisWrapper') const rclient = RedisWrapper.client('ratelimiter') const RollingRateLimiter = require('rolling-rate-limiter') module.exports = RateLimiter = { addCount(opts, callback) { if (callback == null) { callback = function(err, shouldProcess) {} } const namespace = `RateLimit:${opts.endpointName}:` const k = `{${opts.subjectName}}` const limiter = RollingRateLimiter({ redis: rclient, namespace, interval: opts.timeInterval * 1000, maxInInterval: opts.throttle }) limiter(k, function(err, timeLeft, actionsLeft) { if (err != null) { return callback(err) } const allowed = timeLeft === 0 if (!allowed) { Metrics.inc(`rate-limit-hit.${opts.endpointName}`, 1, { path: opts.endpointName }) } return callback(null, allowed) }) }, clearRateLimit(endpointName, subject, callback) { // same as the key which will be built by RollingRateLimiter (namespace+k) const keyName = `RateLimit:${endpointName}:{${subject}}` rclient.del(keyName, callback) } }