2024-01-14 00:30:15 +08:00
|
|
|
import { KvQuery } from "$sb/types.ts";
|
|
|
|
import { LimitedMap } from "../../common/limited_map.ts";
|
2023-10-03 20:16:33 +08:00
|
|
|
import type { SysCallMapping } from "../../plugos/system.ts";
|
|
|
|
import type { Client } from "../client.ts";
|
2024-01-14 00:30:15 +08:00
|
|
|
import { proxySyscall, proxySyscalls } from "./util.ts";
|
2023-10-03 20:16:33 +08:00
|
|
|
|
|
|
|
export function dataStoreProxySyscalls(client: Client): SysCallMapping {
|
2024-01-14 00:30:15 +08:00
|
|
|
const syscalls = proxySyscalls(client, [
|
2023-10-03 20:16:33 +08:00
|
|
|
"datastore.delete",
|
|
|
|
"datastore.set",
|
|
|
|
"datastore.batchSet",
|
|
|
|
"datastore.batchDelete",
|
|
|
|
"datastore.batchGet",
|
|
|
|
"datastore.get",
|
|
|
|
]);
|
2024-01-14 00:30:15 +08:00
|
|
|
// Add a cache for datastore.query
|
|
|
|
const queryCache = new LimitedMap<any>(5);
|
|
|
|
syscalls["datastore.query"] = async (ctx, query: KvQuery) => {
|
|
|
|
let cacheKey: string | undefined;
|
|
|
|
const cacheSecs = query.cacheSecs;
|
|
|
|
// Should we do caching?
|
|
|
|
if (cacheSecs) {
|
|
|
|
// Remove the cacheSecs from the query
|
|
|
|
query = { ...query, cacheSecs: undefined };
|
|
|
|
cacheKey = JSON.stringify(query);
|
|
|
|
const cachedResult = queryCache.get(cacheKey);
|
|
|
|
if (cachedResult) {
|
|
|
|
// Let's use the cached result
|
|
|
|
return cachedResult;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const result = await proxySyscall(
|
|
|
|
ctx,
|
|
|
|
client.httpSpacePrimitives,
|
|
|
|
"datastore.query",
|
|
|
|
[
|
|
|
|
query,
|
|
|
|
],
|
|
|
|
);
|
|
|
|
if (cacheKey) {
|
|
|
|
// Store in the cache
|
|
|
|
queryCache.set(cacheKey, result, cacheSecs! * 1000);
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
};
|
|
|
|
return syscalls;
|
2023-10-03 20:16:33 +08:00
|
|
|
}
|