mirror of
https://github.com/shishantbiswas/bknd.git
synced 2026-03-16 04:27:21 +00:00
template: added cloudflare vite hybrid template
This commit is contained in:
47
examples/cloudflare-vite-hybrid/config.ts
Normal file
47
examples/cloudflare-vite-hybrid/config.ts
Normal file
@@ -0,0 +1,47 @@
|
||||
/// <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",
|
||||
});
|
||||
},
|
||||
},
|
||||
}),
|
||||
});
|
||||
Reference in New Issue
Block a user