Skip to content

Commit

Permalink
feat: add put and delete ops to kv
Browse files Browse the repository at this point in the history
  • Loading branch information
MasterPtato authored and NathanFlurry committed Nov 21, 2024
1 parent c8e700d commit 3d1f602
Show file tree
Hide file tree
Showing 8 changed files with 342 additions and 87 deletions.
12 changes: 11 additions & 1 deletion packages/infra/client/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion packages/infra/client/isolate-v8-runner/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ signal-hook = "0.3.17"
tokio = { version = "1.36.0", features = [ "full" ] }
tokio-tungstenite = "0.23.1"
tracing = "0.1"
tracing-logfmt = "0.3"
tracing-logfmt = { version = "0.3" , features = ["ansi_logs"] }
tracing-subscriber = { version = "0.3", default-features = false, features = [
"ansi",
"fmt",
Expand Down
110 changes: 106 additions & 4 deletions packages/infra/client/isolate-v8-runner/js/40_rivet_kv.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,113 @@
import { op_rivet_kv_get, op_rivet_kv_get_batch } from "ext:core/ops";
import {
op_rivet_kv_get,
op_rivet_kv_get_batch,
op_rivet_kv_put,
op_rivet_kv_put_batch,
op_rivet_kv_delete,
} from "ext:core/ops";
import { core } from "ext:core/mod.js";

/**
* Retrieves a value from the key-value store.
*
* @param {string} key - The key to retrieve the value for.
* @param {Object} [options] - Optional settings.
* @param {('value'|'arrayBuffer')} [options.format] - The format in which to return the data.
* If "arrayBuffer", returns an ArrayBuffer.
* Otherwise, returns the deserialized value.
* @returns {Promise<any|undefined>} The retrieved value, or undefined if the key does not exist.
*/
async function get(key, options) {
return (await op_rivet_kv_get(key, options)) ?? undefined;
let value = (await op_rivet_kv_get(key)) ?? undefined;

return deserializeValue(key, value, options);
}

/**
* Asynchronously retrieves a batch of key-value pairs.
*
* @param {string[]} keys - A list of keys to retrieve.
* @param {Object} [options] - Optional settings.
* @param {('value'|'arrayBuffer')} [options.format] - The format in which to return the data.
* If "arrayBuffer", returns an ArrayBuffer.
* Otherwise, returns the deserialized value.
* @returns {Promise<Map<string, any>>} The retrieved values. Keys that have no value in the key-value store
* will not be present.
*/
async function getBatch(keys, options) {
return (await op_rivet_kv_get_batch(keys, options)) ?? undefined;
let values = await op_rivet_kv_get_batch(keys, options);

let deserializedValues = new Map();

for (let key in values) {
deserializedValues.set(key, deserializeValue(key, values[key], options));
}

return deserializedValues;
}

/**
* Stores a key-value pair in the key-value store.
*
* @param {string} key - The key under which the value will be stored.
* @param {any} value - The value to be stored, which will be serialized.
* @returns {Promise<void>} A promise that resolves when the operation is complete.
*/
async function put(key, value) {
await op_rivet_kv_put(key, core.serialize(value));
}

/**
* Asynchronously stores a batch of key-value pairs.
*
* @param {Object} obj - An object containing key-value pairs to be stored.
* @returns {Promise<void>} A promise that resolves when the batch operation is complete.
*/
async function putBatch(obj) {
let serializedObj = new Map();

for (let key in obj) {
serializedObj.set(key, core.serialize(obj[key]));
}

await op_rivet_kv_put_batch(serializedObj);
}

/**
* Deletes a key-value pair from the key-value store.
*
* @param {string} key - The key of the key-value pair to delete.
* @returns {Promise<void>} A promise that resolves when the operation is complete.
*/
async function delete_(key) {
return await op_rivet_kv_delete(key);
}

async function deleteBatch(keys) {
return await op_rivet_kv_delete_batch(keys);
}

function deserializeValue(key, data, options) {
if (data != undefined) {
let format = options?.format ?? "value";

if (format == "value") {
try {
return core.deserialize(data, { forStorage: true });
} catch (e) {
throw new Error(
`Could not deserialize data in key "${key}". You must use options.format = "arrayBuffer".`,
{ cause: e }
);
}
} else if (format == "arrayBuffer") {
return data.buffer;
} else {
throw Error(`Invalid format: "${options.format}". Expected "value" or "arrayBuffer".`);
}
}

return undefined;
}

export { get, getBatch };
export { get, getBatch, put, putBatch, delete_, deleteBatch };
4 changes: 4 additions & 0 deletions packages/infra/client/isolate-v8-runner/js/90_rivet_ns.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,10 @@ const rivetNs = {
kv: {
get: kv.get,
getBatch: kv.getBatch,
put: kv.put,
putBatch: kv.putBatch,
delete: kv.delete_,
deleteBatch: kv.deleteBatch,
},
};

Expand Down
Loading

0 comments on commit 3d1f602

Please sign in to comment.