node-bloom-control
data:image/s3,"s3://crabby-images/c0179/c0179f872222be4e328a08de4384c07487d0692d" alt="Buy Me A Coffee"
Bloom Control integration for Node. Used in pair with Bloom, the HTTP REST API caching middleware.
Bloom Control lets you control your Bloom cache, from your NodeJS code. Purge API cache on-demand, whenever your API worker updates a database model or performs some action that require cached data to be invalidated.
🇫🇷 Crafted in Brest, France.
Who uses it?
data:image/s3,"s3://crabby-images/a02c5/a02c5db22eaaff40e8ba802f6263351361b4b11f" alt="" |
Crisp |
👋 You use bloom-control and you want to be listed there? Contact me.
How to install?
Include bloom-control
in your package.json
dependencies.
Alternatively, you can run npm install bloom-control --save
.
How to use?
1. Create the connection
node-bloom-control
can be instanciated as such:
var BloomControl = require("bloom-control").BloomControl;
var bloomControl = new BloomControl({
host : "::1",
port : 8811,
shard : 0
}).connect({
connected : function() {
console.info("Bloom Control succeeded to connect to host.");
},
disconnected : function() {
console.error("Bloom Control is now disconnected.");
},
timeout : function() {
console.error("Bloom Control connection timed out.");
},
retrying : function() {
console.error("Trying to reconnect to Bloom Control...");
},
error : function(error) {
console.error("Bloom Control failed to connect to host.", error);
}
});
2. Purge cache collections
Use the same bloomControl
instance to purge cache collections:
bloomControl.purgeBucket(`cache_bucket_id`, function(error) {
});
bloomControl.purgeBucket([
`cache_bucket_id_1`,
`cache_bucket_id_2`
], function(error) {
});
bloomControl.purgeAuth(`auth_identifier`, `auth_token`, function(error) {
});
bloomControl.purgeAuth([
[`auth_identifier_1`, `auth_token_1`],
[`auth_identifier_2`, `auth_token_2`]
], function(error) {
});
3. Listen for processed commands
In the event you need to debug the commands being executed (given the result, either NIL
, OK
, ERR
or PONG
), you can register a listener as:
bloomControl.on("OK", function(command) {
console.log("Command OK:", command);
});
bloomControl.on("ERR", function(command) {
console.log("Command ERR:", command);
});
bloomControl.on("NIL", function(command) {
console.log("Command NIL:", command);
});
bloomControl.on("PONG", function(command) {
console.log("Command PONG:", command);
});
You can stop listening to events as such:
bloomControl.off("OK");
bloomControl.off("ERR");
bloomControl.off("NIL");
bloomControl.off("PONG");
Notice: only 1 handler can be registered at the same time for a given command result.
4. Test connection
You can test your connection to Bloom anytime by sending a ping:
bloomControl.ping(function(error) {
});
The response to your ping will come on the event channel (register a listener for the PONG
event).
Notice: pings are automatically sent to maintain the connection. You will get pong events periodically on the event channel, even if you never sent a ping.
5. Teardown connection
If you need to teardown an ongoing connection to Bloom, use:
bloomControl.close(function(error) {
});
What is Bloom?
ℹ️ Wondering what Bloom is? Check out valeriansaliou/bloom.
How is it linked to Bloom?
node-bloom-control
maintains a persistent TCP connection to the Bloom Control interface that's listening on your running Bloom instance. In case node-bloom-control
gets disconnected from Bloom, it will retry to connect once the connection is established again. Pending cache purge requests that could not be transmitted to Bloom are stacked, up to a certain limit where further cache purge requests will be dropped and not stacked. Once the connection to Bloom Control is established again, stacked cache purge requests are transmitted to Bloom for processing.
You can configure the connection details of your Bloom instance when initializing node-bloom-control
from your code; via the Bloom host and port.