forked from 51Degrees/pipeline-node
-
Notifications
You must be signed in to change notification settings - Fork 0
/
caching.js
110 lines (93 loc) · 3.61 KB
/
caching.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* *********************************************************************
* This Original Work is copyright of 51 Degrees Mobile Experts Limited.
* Copyright 2023 51 Degrees Mobile Experts Limited, Davidson House,
* Forbury Square, Reading, Berkshire, United Kingdom RG1 3EU.
*
* This Original Work is licensed under the European Union Public Licence
* (EUPL) v.1.2 and is subject to its terms as set out below.
*
* If a copy of the EUPL was not distributed with this file, You can obtain
* one at https://opensource.org/licenses/EUPL-1.2.
*
* The 'Compatible Licences' set out in the Appendix to the EUPL (as may be
* amended by the European Commission) shall be deemed incompatible for
* the purposes of the Work and the provisions of the compatibility
* clause in Article 5 of the EUPL shall not apply.
*
* If using the Work as, or as part of, a network application, by
* including the attribution notice(s) required under Article 5 of the EUPL
* in the end user terms of the application under an appropriate heading,
* such notice(s) shall fulfill the requirements of that article.
* ********************************************************************* */
/**
* @example caching.js
*
* This example demonstrates how to add a cache to an aspect engine.
* The fiftyone.pipeline.engines module comes with an implementation
* of a Least Recently Used (lru) cache that can be used in
* place of the custom cache created in this example.
*
* To construct the lru cache pass in a size (in entries)
* parameter to its constructor.
*
* let lruCache = new engine.lruCache(100);
*
*/
const pipeline = require('fiftyone.pipeline.core');
// Note that this example is designed to be run from within the
// source repository. If this code has been copied to run standalone
// then you'll need to replace the require below with the commented
// out version below it.
const engine = require('..');
// const engine = require("fiftyone.pipeline.engines");
// This is a very simple cache that uses an in memory JavaScript object
class MyCustomCache extends engine.DataKeyedCache {
constructor (size) {
super();
this.cache = {};
}
get (cachekey) {
if (this.cache[cachekey]) {
// Log out whether something has been fetched
// from cache to demonstrate the example
console.log('Fetched from cache');
return this.cache[cachekey];
}
}
put (cachekey, value) {
this.cache[cachekey] = value;
}
}
// A custom engine to test the caching, note the instance of the
// evidenceKeyFilter class which is used to determine which evidence
// is used by the flowElement and in turn the pipeline.
const cacheTest = new engine.Engine({
dataKey: 'cacheTest',
cache: new MyCustomCache(),
evidenceKeyFilter: new pipeline
.BasicListEvidenceKeyFilter(['cookie.my-user-id']),
processInternal: function (flowData) {
const engine = this;
return new Promise(function (resolve, reject) {
const data = new pipeline
.ElementDataDictionary(
{ flowElement: engine, contents: { hello: 'world' } });
flowData.setElementData(data);
resolve();
});
},
properties: {
hello: {
type: 'string'
}
}
});
const cachePipeline = new pipeline.PipelineBuilder().add(cacheTest).build();
const flowData = cachePipeline.createFlowData();
const processFlowDataWithUserId = function (userID) {
flowData.evidence.add('cookie.my-user-id', userID);
return flowData.process();
};
// Run the same evidence through the pipeline twice,
// second time should be fetched from the cache
processFlowDataWithUserId('112').then(() => processFlowDataWithUserId('112'));