Using Environment Variables
You may want to allow users to use environment variables set via the Environment
page in your Caido plugin.
data:image/s3,"s3://crabby-images/30703/3070362b99ebb429a89104ddaf2dc9f97eb3685c" alt="Adding environment variables."
Getting the Value: Frontend Call to Backend Function
To securely access environment variables in Caido, the sdk.env.getVar()
method can be used:
/packages/backend/src/index.ts
ts
import type { DefineAPI, SDK } from "caido:plugin";
export type API = DefineAPI<{
getSession: () => Promise<string | undefined>;
}>;
export function init(sdk: SDK<API>) {
// Register an API endpoint that frontend can call.
sdk.api.register("getSession", async () => {
return sdk.env.getVar("User A");
});
}
/packages/frontend/src/index.ts
ts
const button = document.createElement("button");
button.textContent = "Check for Env Variable";
button.classList.add("bg-blue-500", "text-white", "p-2", "rounded");
button.addEventListener("click", async () => {
const apiKey = await sdk.backend.getSession();
// Display the message as text.
statusText.textContent = apiKey ? "SESSION FOUND" : "NO SESSION SET";
});
Getting the Value: Frontend Call
The method is also available to the frontend directly.
/packages/frontend/src/index.ts
ts
const button = document.createElement("button");
button.textContent = "Check for Env Variable";
button.classList.add("bg-blue-500", "text-white", "p-2", "rounded");
button.addEventListener("click", () => {
const value = sdk.env.getVar("User A");
statusText.textContent = value ? "SESSION FOUND" : "NO SESSION SET";
});
The Result
data:image/s3,"s3://crabby-images/e4fd5/e4fd53f01351eec5d34261d2154cadbf52a810bf" alt="Adding environment variables."
data:image/s3,"s3://crabby-images/2d14a/2d14a32f785162689b6acb1bdb800260a71878ff" alt="Adding environment variables."