From a22c35997bd0b63b21e52160383716a7bf544dbd Mon Sep 17 00:00:00 2001 From: satoshi toyama Date: Tue, 29 Oct 2024 16:51:10 +0900 Subject: [PATCH] feat(flags): Implement local environment flagging mechanism - Add utility function to evaluate flags based on local environment - Replace hardcoded return values with calls to the new function - This enhancement allows better control of feature flags during development --- flags.ts | 36 ++++++++++++++++-------------------- 1 file changed, 16 insertions(+), 20 deletions(-) diff --git a/flags.ts b/flags.ts index 6a0769e4..32baf51f 100644 --- a/flags.ts +++ b/flags.ts @@ -1,17 +1,21 @@ import { unstable_flag as flag } from "@vercel/flags/next"; +function takeLocalEnv(localEnvironemntKey: string) { + if (process.env.NODE_ENV !== "development") { + return false; + } + if ( + process.env[localEnvironemntKey] === undefined || + process.env[localEnvironemntKey] === "false" + ) { + return false; + } + return true; +} export const uploadFileToPromptNodeFlag = flag({ key: "upload-file-to-prompt-node", async decide() { - // You can do async things in here like reading edge config or querying - // your feature flag provider. - // - // You can access data passed in by middleware through unstable_getPrecomputationContext - // const context = unstable_getPrecomputationContext() - // - // This is great for creating a single instance of your flag provider - // and then passing the client down from middleware - return false; + return takeLocalEnv("UPLOAD_FILE_TO_PROMPT_NODE_FLAG"); }, description: "User can upload a file to the prompt node", defaultValue: false, @@ -24,15 +28,7 @@ export const uploadFileToPromptNodeFlag = flag({ export const webSearchNodeFlag = flag({ key: "web-search-node", async decide() { - // You can do async things in here like reading edge config or querying - // your feature flag provider. - // - // You can access data passed in by middleware through unstable_getPrecomputationContext - // const context = unstable_getPrecomputationContext() - // - // This is great for creating a single instance of your flag provider - // and then passing the client down from middleware - return false; + return takeLocalEnv("WEB_SEARCH_NODE_FLAG"); }, description: "User can use a web search node", defaultValue: false, @@ -45,7 +41,7 @@ export const webSearchNodeFlag = flag({ export const debugFlag = flag({ key: "debug", async decide() { - return false; + return takeLocalEnv("DEBUG_FLAG"); }, description: "Enable debug mode", defaultValue: false, @@ -58,7 +54,7 @@ export const debugFlag = flag({ export const viewFlag = flag({ key: "view", async decide() { - return false; + return takeLocalEnv("VIEW_FLAG"); }, description: "Enable view mode", defaultValue: false,