mirror of
https://github.com/shishantbiswas/bknd.git
synced 2026-03-16 04:27:21 +00:00
48 lines
2.2 KiB
TypeScript
48 lines
2.2 KiB
TypeScript
/// <reference types="./worker-configuration.d.ts" />
|
|
|
|
import { devFsWrite, type CloudflareBkndConfig } from "bknd/adapter/cloudflare";
|
|
import { hybrid } from "bknd/modes";
|
|
|
|
export default hybrid<CloudflareBkndConfig>({
|
|
// normally you would use e.g. `readFile` from `node:fs/promises`, however, cloudflare using vite plugin removes all Node APIs, therefore we need to use the module system to import the config file
|
|
reader: async () => {
|
|
return (await import("./bknd-config.json").then((module) => module.default)) as any;
|
|
},
|
|
// a writer is required to sync the types and config. We're using a vite plugin that proxies writing files (since Node APIs are not available)
|
|
writer: devFsWrite,
|
|
// the generated types are loaded using our tsconfig, and is automatically available in all bknd APIs
|
|
typesFilePath: "./bknd-types.d.ts",
|
|
// on every change, this config file is updated. When it's time to deploy, this will be inlined into your worker
|
|
configFilePath: "./bknd-config.json",
|
|
// secrets will always be extracted from the configuration, we're writing an example env file to know which secrets we need to provide prior to deploying
|
|
syncSecrets: {
|
|
enabled: true,
|
|
outFile: ".env.example",
|
|
format: "env",
|
|
} as const,
|
|
app: (env) => ({
|
|
// we need to disable the admin controller using the vite plugin, since we want to render our own app
|
|
adminOptions: false,
|
|
// this is important to determine whether configuration should be read-only, or if the database should be automatically synced
|
|
isProduction: env.ENVIRONMENT === "production",
|
|
// we need to inject the secrets that gets merged into the configuration
|
|
secrets: env,
|
|
options: {
|
|
// the seed option is only executed if the database was empty
|
|
seed: async (ctx) => {
|
|
// create some entries
|
|
await ctx.em.mutator("todos").insertMany([
|
|
{ title: "Learn bknd", done: true },
|
|
{ title: "Build something cool", done: false },
|
|
]);
|
|
|
|
// and create a user
|
|
await ctx.app.module.auth.createUser({
|
|
email: "test@bknd.io",
|
|
password: "12345678",
|
|
});
|
|
},
|
|
},
|
|
}),
|
|
});
|