Skip to main content

Mountain/RPC/CocoonService/Secret/
StoreSecret.rs

1#![allow(non_snake_case)]
2
3//! Persist a value to the OS keychain.
4
5use tonic::{Response, Status};
6use CommonLibrary::Secret::SecretProvider::SecretProvider;
7
8use crate::{
9	RPC::CocoonService::CocoonServiceImpl,
10	Vine::Generated::{Empty, StoreSecretRequest},
11	dev_log,
12};
13
14pub async fn Fn(Service:&CocoonServiceImpl, Request:StoreSecretRequest) -> Result<Response<Empty>, Status> {
15	dev_log!("cocoon", "[CocoonService] store_secret: key={}", Request.key);
16
17	match Service
18		.environment
19		.StoreSecret(String::new(), Request.key.clone(), Request.value)
20		.await
21	{
22		Ok(()) => Ok(Response::new(Empty {})),
23		Err(Error) => {
24			dev_log!(
25				"cocoon",
26				"warn: [CocoonService] store_secret failed key={}: {}",
27				Request.key,
28				Error
29			);
30			Err(Status::internal(format!("store_secret: {}", Error)))
31		},
32	}
33}