UNPKG

11.9 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _logger = require('./logger');
8
9var _logger2 = _interopRequireDefault(_logger);
10
11var _bluebird = require('bluebird');
12
13var _bluebird2 = _interopRequireDefault(_bluebird);
14
15var _nodeCache = require('node-cache');
16
17var _nodeCache2 = _interopRequireDefault(_nodeCache);
18
19var _trustedEndpointBase = require('./trusted-endpoint-base');
20
21var _trustedEndpointBase2 = _interopRequireDefault(_trustedEndpointBase);
22
23var _schemas = require('./schemas');
24
25var _trustedCacheSchemas = require('./schemas/trusted-cache-schemas');
26
27var _trustedCacheSchemas2 = _interopRequireDefault(_trustedCacheSchemas);
28
29function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
30
31const logger = (0, _logger2.default)('with-cache');
32
33const CACHE_CHECK_PERIOD_FACTOR = 1.2;
34const DEFA_LOCAL_AUTH_TIMEOUT_SECONDS = 15 * 60; // 15 minutes
35const DEFA_REMOTE_AUTH_TIMEOUT_SECONDS = 5 * 60; // 5 minutes
36
37let $cache = Symbol('cache');
38let $promiseCacheGet = Symbol('promiseCacheGet');
39let $promiseCacheSet = Symbol('promiseCacheSet');
40let $localAuthTimeoutSeconds = Symbol('localAuthTimeoutSeconds');
41let $remoteAuthTimeoutSeconds = Symbol('remoteAuthTimeoutSeconds');
42
43class TrustedEndpointWithCache extends _trustedEndpointBase2.default {
44 constructor(options) {
45 super(options);
46 (0, _schemas.validate)(options, _trustedCacheSchemas2.default);
47
48 this[$localAuthTimeoutSeconds] = options.localAuthTimeoutSeconds || DEFA_LOCAL_AUTH_TIMEOUT_SECONDS;
49 this[$remoteAuthTimeoutSeconds] = options.remoteAuthTimeoutSeconds || DEFA_REMOTE_AUTH_TIMEOUT_SECONDS;
50 this[$cache] = new _nodeCache2.default({
51 stdTtl: this.remoteAuthTimeoutSeconds,
52 checkperiod: Math.round(this.remoteAuthTimeoutSeconds * CACHE_CHECK_PERIOD_FACTOR),
53 useClones: false
54 });
55 this[$promiseCacheGet] = _bluebird2.default.promisify(this[$cache].get);
56 this[$promiseCacheSet] = _bluebird2.default.promisify(this[$cache].set);;
57 }
58
59 get localAuthTimeoutSeconds() {
60 return this[$localAuthTimeoutSeconds];
61 }
62
63 get remoteAuthTimeoutSeconds() {
64 return this[$remoteAuthTimeoutSeconds];
65 }
66
67 resolveAndVerifyClaims(keyId, ttl) {
68 ttl = ttl || this.remoteAuthTimeoutSeconds;
69 let cacheKey = `claims: ${ keyId }`;
70 return this[$promiseCacheGet](cacheKey).then(item => {
71 if (item !== undefined) {
72 if (item.isExpired) {
73 logger.debug(`expired claims evicted from cache: ${ keyId }:${ item.id }`);
74 this.flush(cacheKey);
75 } else {
76 return item;
77 }
78 }
79 return super.resolveAndVerifyClaims(keyId).then(auth => {
80 if (auth.verified && !auth.isExpired) {
81 return this[$promiseCacheSet](cacheKey, auth, ttl).then(() => auth);
82 }
83 return auth;
84 });
85 });
86 }
87
88 resolveEndpointKey(keyId, ttl) {
89 let cacheKey = `key: ${ keyId }`;
90 return this[$promiseCacheGet](cacheKey).then(item => {
91 if (item !== undefined) {
92 return item;
93 }
94 return super.resolveEndpointKey(keyId).then(key => {
95 return this[$promiseCacheSet](cacheKey, key, ttl).then(() => key);
96 });
97 });
98 }
99
100 getLocalAuth() {
101 return this.resolveAndVerifyClaims(this.keyId, this.localAuthTimeoutSeconds);
102 }
103
104 flush(keyId) {
105 let cache = this[$cache];
106 if (cache) {
107 let claimsKey = `claims: ${ keyId }`;
108 let keyKey = `key: ${ keyId }`;
109 cache.del(claimsKey);
110 cache.del(keyKey);
111 }
112 }
113
114 flushAll() {
115 let cache = this[$cache];
116 if (cache) {
117 cache.flushAll();
118 }
119 }
120
121 close() {
122 let cache = this[$cache];
123 if (cache) {
124 cache.close();
125 }
126 }
127
128}
129
130exports.default = TrustedEndpointWithCache;
131module.exports = exports['default'];
132//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../lib/trusted-endpoint-cache.js"],"names":[],"mappings":"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","file":"trusted-endpoint-cache.js","sourcesContent":["import createLogger from './logger';\nimport Promise from 'bluebird';\nimport NodeCache from 'node-cache';\nimport TrustedEndpoint from './trusted-endpoint-base';\nimport { validate } from './schemas';\nimport optionsSchema from './schemas/trusted-cache-schemas';\n\nconst logger = createLogger('with-cache');\n\nconst CACHE_CHECK_PERIOD_FACTOR = 1.2;\nconst DEFA_LOCAL_AUTH_TIMEOUT_SECONDS = 15 * 60; // 15 minutes\nconst DEFA_REMOTE_AUTH_TIMEOUT_SECONDS = 5 * 60; // 5 minutes\n\nlet $cache = Symbol('cache');\nlet $promiseCacheGet = Symbol('promiseCacheGet');\nlet $promiseCacheSet = Symbol('promiseCacheSet');\nlet $localAuthTimeoutSeconds = Symbol('localAuthTimeoutSeconds');\nlet $remoteAuthTimeoutSeconds = Symbol('remoteAuthTimeoutSeconds');\n\nclass TrustedEndpointWithCache extends TrustedEndpoint {\n  constructor(options) {\n    super(options);\n    validate(options, optionsSchema);\n\n    this[$localAuthTimeoutSeconds] = options.localAuthTimeoutSeconds || DEFA_LOCAL_AUTH_TIMEOUT_SECONDS;\n    this[$remoteAuthTimeoutSeconds] = options.remoteAuthTimeoutSeconds || DEFA_REMOTE_AUTH_TIMEOUT_SECONDS;\n    this[$cache] = new NodeCache({\n      stdTtl: this.remoteAuthTimeoutSeconds,\n      checkperiod: Math.round(this.remoteAuthTimeoutSeconds * CACHE_CHECK_PERIOD_FACTOR),\n      useClones: false\n    });\n    this[$promiseCacheGet] = Promise.promisify(this[$cache].get);\n    this[$promiseCacheSet] = Promise.promisify(this[$cache].set);;\n  }\n\n  get localAuthTimeoutSeconds() {\n    return this[$localAuthTimeoutSeconds];\n  }\n\n  get remoteAuthTimeoutSeconds() {\n    return this[$remoteAuthTimeoutSeconds];\n  }\n\n  resolveAndVerifyClaims(keyId, ttl) {\n    ttl = ttl || this.remoteAuthTimeoutSeconds;\n    let cacheKey = `claims: ${keyId}`;\n    return this[$promiseCacheGet](cacheKey)\n      .then(item => {\n        if (item !== undefined) {\n          if (item.isExpired) {\n            logger.debug(`expired claims evicted from cache: ${keyId}:${item.id}`);\n            this.flush(cacheKey);\n          } else {\n            return item;\n          }\n        }\n        return super.resolveAndVerifyClaims(keyId)\n          .then(auth => {\n            if (auth.verified && !auth.isExpired) {\n              return this[$promiseCacheSet](cacheKey, auth, ttl)\n                .then(() => auth);\n            }\n            return auth;\n          });\n\n      });\n  }\n\n  resolveEndpointKey(keyId, ttl) {\n    let cacheKey = `key: ${keyId}`;\n    return this[$promiseCacheGet](cacheKey)\n      .then(item => {\n        if (item !== undefined) {\n          return item;\n        }\n        return super.resolveEndpointKey(keyId)\n          .then(key => {\n            return this[$promiseCacheSet](cacheKey, key, ttl)\n              .then(() => key);\n          });\n      });\n  }\n\n  getLocalAuth() {\n    return this.resolveAndVerifyClaims(this.keyId, this.localAuthTimeoutSeconds);\n  }\n\n  flush(keyId) {\n    let cache = this[$cache];\n    if (cache) {\n      let claimsKey = `claims: ${keyId}`;\n      let keyKey = `key: ${keyId}`;\n      cache.del(claimsKey);\n      cache.del(keyKey);\n    }\n  }\n\n  flushAll() {\n    let cache = this[$cache];\n    if (cache) {\n      cache.flushAll();\n    }\n  }\n\n  close() {\n    let cache = this[$cache];\n    if (cache) {\n      cache.close();\n    }\n  }\n\n}\n\nexport default TrustedEndpointWithCache;\n"]}
\No newline at end of file