summaryrefslogtreecommitdiffhomepage
path: root/js/src/config
diff options
context:
space:
mode:
authorDax Raad <[email protected]>2025-05-29 11:58:40 -0400
committerDax Raad <[email protected]>2025-05-29 11:58:40 -0400
commit80597cd3fdf149cef87db55f03a3cc0bfd723a7a (patch)
treeb9332733cca2084a86334eb88fdc5115ab37b922 /js/src/config
parent48f81fe4d3a286ead827888e030f9bd89c864dee (diff)
downloadopencode-80597cd3fdf149cef87db55f03a3cc0bfd723a7a.tar.gz
opencode-80597cd3fdf149cef87db55f03a3cc0bfd723a7a.zip
type error fix
Diffstat (limited to 'js/src/config')
-rw-r--r--js/src/config/config.ts51
1 files changed, 51 insertions, 0 deletions
diff --git a/js/src/config/config.ts b/js/src/config/config.ts
new file mode 100644
index 000000000..76181b792
--- /dev/null
+++ b/js/src/config/config.ts
@@ -0,0 +1,51 @@
+import path from "path";
+import { Log } from "../util/log";
+import { z } from "zod";
+import { App } from "../app/app";
+import { Provider } from "../provider/provider";
+
+export namespace Config {
+ const log = Log.create({ service: "config" });
+
+ export const state = App.state("config", async (app) => {
+ const result = await load(app.root);
+ return result;
+ });
+
+ export const Info = z
+ .object({
+ providers: z.record(z.string(), Provider.Info).optional(),
+ })
+ .strict();
+
+ export type Info = z.output<typeof Info>;
+
+ export function get() {
+ return state();
+ }
+
+ async function load(directory: string) {
+ let result: Info = {};
+ for (const file of ["opencode.jsonc", "opencode.json"]) {
+ const resolved = path.join(directory, file);
+ log.info("searching", { path: resolved });
+ try {
+ result = await import(path.join(directory, file)).then((mod) =>
+ Info.parse(mod.default),
+ );
+ log.info("found", { path: resolved });
+ break;
+ } catch (e) {
+ if (e instanceof z.ZodError) {
+ for (const issue of e.issues) {
+ log.info(issue.message);
+ }
+ throw e;
+ }
+ continue;
+ }
+ }
+ log.info("loaded", result);
+ return result;
+ }
+}