Using Secrets in Deco Sites
Secrets are a powerful feature in deco sites that allow you to securely store sensitive information, such as API keys or passwords. By utilizing secrets, you can easily manage and protect your site's confidential data.
Prerequisites
Before you begin, ensure that you have the following:
- A deco site project set up.
- Understanding of props and loaders in deco.
Step 1: Declaring a Secret Prop
To use secrets in your site, you need to declare a secret prop in your components. Here's an example of how to do it in a section using an inline loader:
import { Secret } from "apps/website/loaders/secret.ts";
export interface Props {
secret: Secret;
}
export const loader = async (props: Props) => {
const secretValue = await props?.secret?.get();
// Use secret here
};
In this example, the secret
prop is declared in the Props
interface. The loader
function retrieves the secret value using the get()
method, and then you can use the secret in your code.
Step 2: Configuring Secrets
After declaring the secret prop, users can configure secrets for your site. However, note that testing secrets on localhost won't work. You should point to your production domain, which means you need at least one deployment declaring the secret dependency.
Important note: Secrets cannot be revealed on the Admin UI. They will be hidden by default.
Step 3: Handling Local Development
When developing locally, a secret has a "name" in the admin UI. This name can be fulfilled as an environment variable, which will be used locally instead of the actual key being used in production.
Note: You can set the envvar when running your site by passing before running your actual command, e.g
ENV_VAR=mysecretvalue deno task start
This will make the ENV_VAR
available in runtime with the mysecretvalue
value to be used locally.