Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
moon-bucket
Advanced tools
A bucket of Lua scripts for Redis.
Shell:
redis-cli eval "$(cat scripts/join.lua)" [args]
var lua = require('moon-bucket');
var redis = require('redis');
var client = redis.createClient();
lua.init(client);
var hashMaps = lua.join('ids', 'things');
join
Redis doesn't have joins. However, we can script them with Lua.
This script lets us get hashes by their id.
Prereqs: our hashes must be namespaced namespace:*
, where namespace
is our namespace (for example, cars
), and *
is an inremental id (which resides in a foreign list of ids, such as 1 2 3 4 5
etc.)
Shell:
# redis-cli eval "$(cat scripts/join.lua)" [2|3] [foreign-key] [namespace] [optional limit]
redis-cli eval "$(cat scripts/join.lua)" 3 ids things 5
JavaScript:
var lua = require('./index.js');
var redis = require('redis');
var client = redis.createClient();
lua.init(client);
/**
* This example requires that there exists an "ids" list of `1, 2, 3`
* and 3 hashmaps --
*
* things:1
* things:2
* things:3
*/
var hashMaps = lua.join('ids', 'things');
/**
* This will return the hashes things:1, things:2, and things:3
*/
console.log(hashMaps);
This will return hashes things:*
, where each things:*
has an ID from the list of ids
with a limit of 5
.
This would return 5 of our hashes, looking like this (maybe JSON, if we're using node.js):
{
"hello": "world",
"some_other": "property",
"_key": "things:1"
}
As you can see, a property called _key
gets automatically embedded into the hash when it is returned to us so we know to which key this object belongs.
Just want to get all of the hashes?
redis-cli eval "$(cat scripts/join.lua)" 2 ids things
By default, our limit is -1
, which is the last item in the list.
Internally when using node.js to call any of the methods available (like join
), we're actually calling node redis' evalsha
method on the corresponding sha1 hash in /sha/index.js
. This is more performant, because we don't have to actually read any files from the file system (in other words, we never make a call to read anything from the scripts
directory directly; instead, we just make redis evaluate the sha1 hash of the script). So, moonBucket.join(/* args */)
actually calls something like redis-cli evalsha b0eff2712326fb5b1cda561a013a0fcc16cb8d85 [...args]
:
// ./sha/index.js
module.exports = {
// this is the hash of the corresponding lua script
"join":"b0eff2712326fb5b1cda561a013a0fcc16cb8d85"
};
If you want to add your own script to scripts
, you'll need to implement the method in ./index.js
and then run ./.bin/compile-sha
in order to re-create the sha map.
"Lua" is the name of the scripting language, and the portuguese word for "moon". "Balde lua" means moon bucket.
© 2015 Josh Beam - MIT License | www.joshbe.am | talk@joshbe.am
FAQs
A bucket of Lua scripts for Redis
We found that moon-bucket demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.