Add the ability to store secret dev-only env vars in .env.secret.toml (#15557)

Release Notes:

- N/A

---------

Co-authored-by: Marshall <marshall@zed.dev>
This commit is contained in:
Max Brunsfeld 2024-07-31 12:41:09 -07:00 committed by GitHub
parent 86f266d37f
commit 3f1c091b87
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 29 additions and 22 deletions

3
.gitignore vendored
View file

@ -29,3 +29,6 @@ DerivedData/
.vscode .vscode
.wrangler .wrangler
.flatpak-builder .flatpak-builder
# Don't commit any secrets to the repo.
.env.secret.toml

View file

@ -1,20 +1,8 @@
use anyhow::anyhow; use collab::env::get_dotenv_vars;
use std::fs;
fn main() -> anyhow::Result<()> { fn main() -> anyhow::Result<()> {
let env: toml::map::Map<String, toml::Value> = toml::de::from_str( for (key, value) in get_dotenv_vars()? {
&fs::read_to_string("./.env.toml").map_err(|_| anyhow!("no .env.toml file found"))?,
)?;
for (key, value) in env {
let value = match value {
toml::Value::String(value) => value,
toml::Value::Integer(value) => value.to_string(),
toml::Value::Float(value) => value.to_string(),
_ => panic!("unsupported TOML value in .env.toml for key {}", key),
};
println!("export {}=\"{}\"", key, value); println!("export {}=\"{}\"", key, value);
} }
Ok(()) Ok(())
} }

View file

@ -1,12 +1,29 @@
use anyhow::anyhow; use anyhow::{anyhow, Result};
use std::fs; use std::fs;
pub fn load_dotenv() -> anyhow::Result<()> { pub fn get_dotenv_vars() -> Result<Vec<(String, String)>> {
let env: toml::map::Map<String, toml::Value> = toml::de::from_str( let mut vars = Vec::new();
&fs::read_to_string("./crates/collab/.env.toml") let env_content = fs::read_to_string("./crates/collab/.env.toml")
.map_err(|_| anyhow!("no .env.toml file found"))?, .map_err(|_| anyhow!("no .env.toml file found"))?;
)?;
add_vars(env_content, &mut vars)?;
if let Ok(secret_content) = fs::read_to_string("./crates/collab/.env.secret.toml") {
add_vars(secret_content, &mut vars)?;
}
Ok(vars)
}
pub fn load_dotenv() -> Result<()> {
for (key, value) in get_dotenv_vars()? {
std::env::set_var(key, value);
}
Ok(())
}
fn add_vars(env_content: String, vars: &mut Vec<(String, String)>) -> Result<()> {
let env: toml::map::Map<String, toml::Value> = toml::de::from_str(&env_content)?;
for (key, value) in env { for (key, value) in env {
let value = match value { let value = match value {
toml::Value::String(value) => value, toml::Value::String(value) => value,
@ -14,8 +31,7 @@ pub fn load_dotenv() -> anyhow::Result<()> {
toml::Value::Float(value) => value.to_string(), toml::Value::Float(value) => value.to_string(),
_ => panic!("unsupported TOML value in .env.toml for key {}", key), _ => panic!("unsupported TOML value in .env.toml for key {}", key),
}; };
std::env::set_var(key, value); vars.push((key, value));
} }
Ok(()) Ok(())
} }