silverbullet/plugos/bin/plugos-server.ts

72 lines
1.9 KiB
TypeScript
Raw Normal View History

2022-03-27 15:55:29 +08:00
#!/usr/bin/env node
import express from "express";
import yargs from "yargs";
import {hideBin} from "yargs/helpers";
import {DiskPlugLoader} from "../plug_loader";
import {CronHookT, NodeCronHook} from "../hooks/node_cron";
import shellSyscalls from "../syscalls/shell.node";
import {System} from "../system";
import {EndpointHook, EndpointHookT} from "../hooks/endpoint";
import {safeRun} from "../util";
2022-03-27 15:55:29 +08:00
import knex from "knex";
import {
2022-03-30 21:16:22 +08:00
ensureTable,
storeReadSyscalls,
storeWriteSyscalls,
} from "../syscalls/store.knex_node";
import {fetchSyscalls} from "../syscalls/fetch.node";
import {EventHook, EventHookT} from "../hooks/event";
import {eventSyscalls} from "../syscalls/event";
2022-03-27 15:55:29 +08:00
let args = yargs(hideBin(process.argv))
.option("port", {
2022-03-30 21:16:22 +08:00
type: "number",
default: 1337,
})
.parse();
2022-03-27 15:55:29 +08:00
if (!args._.length) {
2022-03-30 21:16:22 +08:00
console.error("Usage: plugos-server <path-to-plugs>");
2022-03-27 15:55:29 +08:00
process.exit(1);
}
const plugPath = args._[0] as string;
const app = express();
type ServerHook = EndpointHookT & CronHookT & EventHookT;
2022-03-27 15:55:29 +08:00
const system = new System<ServerHook>("server");
safeRun(async () => {
const db = knex({
client: "better-sqlite3",
connection: {
2022-03-27 17:31:12 +08:00
filename: "plugos.db",
2022-03-27 15:55:29 +08:00
},
useNullAsDefault: true,
});
await ensureTable(db, "item");
let plugLoader = new DiskPlugLoader(system, plugPath);
await plugLoader.loadPlugs();
plugLoader.watcher();
system.addHook(new NodeCronHook());
let eventHook = new EventHook();
system.addHook(eventHook);
system.registerSyscalls("event", [], eventSyscalls(eventHook));
system.addHook(new EndpointHook(app, ""));
2022-03-27 15:55:29 +08:00
system.registerSyscalls("shell", [], shellSyscalls("."));
system.registerSyscalls("fetch", [], fetchSyscalls());
system.registerSyscalls(
"store",
[],
storeWriteSyscalls(db, "item"),
storeReadSyscalls(db, "item")
);
app.listen(args.port, () => {
console.log(`Plugbox server listening on port ${args.port}`);
});
});