move tos-related things to config.rs

This commit is contained in:
b1ek 2024-10-22 11:07:19 +10:00
parent ffa2bc9bd2
commit 39f9e217b2
Signed by: blek
GPG Key ID: A622C22C9BC616B2
2 changed files with 22 additions and 10 deletions

View File

@ -1,4 +1,6 @@
use std::{env, error::Error, fs, io, path::PathBuf};
use crate::{RED, BLUE, WARN, RESET};
use std::{env, error::Error, fs, io, path::PathBuf, process::exit};
use home::home_dir;
use serde::{Deserialize, Serialize};
@ -48,6 +50,23 @@ impl Default for Config {
}
impl Config {
pub fn set_tos(&mut self, tos: bool) -> Result<(), Box<dyn Error>> {
self.tos = tos;
self.save()?;
Ok(())
}
pub fn check_tos(&self) -> () {
if ! self.tos {
eprintln!("{RED}You need to agree to duckduckgo AI chat TOS to continue.{RESET}");
eprintln!("{RED}Visit it on this URL: {RESET}{BLUE}https://duckduckgo.com/?q=duckduckgo+ai+chat&ia=chat{RESET}");
eprintln!("Once you read it, pass --agree-tos parameter to agree.");
eprintln!("{WARN}Note: if you want to, modify `tos` parameter in {}{RESET}", Config::get_path::<PathBuf>().join(Config::get_file_name::<String>()).display());
exit(3);
}
}
pub fn get_path<T: From<String>>() -> T {
match env::var("HEY_CONFIG_PATH") {
Ok(v) => v,

View File

@ -47,18 +47,11 @@ async fn main() {
if ! config.tos {
println!("{GREEN}TOS accepted{RESET}");
}
config.tos = true;
config.save().expect("Error saving config");
config.set_tos(true).expect("Error saving config");
exit(0);
}
if ! config.tos {
eprintln!("{RED}You need to agree to duckduckgo AI chat TOS to continue.{RESET}");
eprintln!("{RED}Visit it on this URL: {RESET}{BLUE}https://duckduckgo.com/?q=duckduckgo+ai+chat&ia=chat{RESET}");
eprintln!("Once you read it, pass --agree-tos parameter to agree.");
eprintln!("{WARN}Note: if you want to, modify `tos` parameter in {}{RESET}", Config::get_path::<PathBuf>().join(Config::get_file_name::<String>()).display());
exit(3);
}
config.check_tos();
println!("{GREEN}Contacting DuckDuckGo chat AI...{RESET}");