aboutsummaryrefslogtreecommitdiff
path: root/common/src/config.rs
blob: a0dc4597a953e5953719a52b99e7935d1db6db45 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/*
    This file is part of jellything (https://codeberg.org/metamuffin/jellything)
    which is licensed under the GNU Affero General Public License (version 3); see /COPYING.
    Copyright (C) 2025 metamuffin <metamuffin.org>
*/

use crate::user::PermissionSet;
use serde::{Deserialize, Serialize};
use std::{collections::HashMap, path::PathBuf};

#[rustfmt::skip]
#[derive(Debug, Deserialize, Serialize, Default)]
pub struct GlobalConfig {
    pub hostname: String,
    pub brand: String,
    pub slogan: String,
    #[serde(default = "return_true" )] pub tls: bool,
    #[serde(default = "default::asset_path")] pub asset_path: PathBuf,
    #[serde(default = "default::database_path")] pub database_path: PathBuf,
    #[serde(default = "default::cache_path")] pub cache_path: PathBuf,
    #[serde(default = "default::media_path")] pub media_path: PathBuf,
    #[serde(default = "default::secrets_path")] pub secrets_path: PathBuf,
    #[serde(default = "default::max_in_memory_cache_size")] pub max_in_memory_cache_size: usize,
    #[serde(default)] pub admin_username: Option<String>,
    #[serde(default = "default::login_expire")] pub login_expire: i64,
    #[serde(default)] pub default_permission_set: PermissionSet,
    #[serde(default)] encoders: EncoderPreferences,
}

#[derive(Debug, Deserialize, Serialize, Default)]
pub struct EncoderPreferences {
    avc: Option<EncoderClass>,
    hevc: Option<EncoderClass>,
    vp8: Option<EncoderClass>,
    vp9: Option<EncoderClass>,
    av1: Option<EncoderClass>,
}

#[derive(Debug, Deserialize, Serialize)]
enum EncoderClass {
    Aom,
    Svt,
    X26n,
    Vpx,
    Vaapi,
    Rkmpp,
}

#[derive(Serialize, Deserialize, Debug, Default)]
pub struct SecretsConfig {
    #[serde(default)]
    pub federation: HashMap<String, FederationAccount>,
    #[serde(default)]
    pub api: ApiSecrets,
    #[serde(default)]
    pub cookie_key: Option<String>,
    #[serde(default)]
    pub session_key: Option<String>,
    #[serde(default)]
    pub admin_password: Option<String>,
}
#[derive(Serialize, Deserialize, Debug)]
pub struct FederationAccount {
    pub username: String,
    pub password: String,
    #[serde(default = "return_true")]
    pub tls: bool,
}

#[derive(Serialize, Deserialize, Debug, Default)]
pub struct ApiSecrets {
    pub tmdb: Option<String>,
    pub tvdb: Option<String>,
    pub imdb: Option<String>,
    pub omdb: Option<String>,
    pub fanart_tv: Option<String>,
    pub trakt: Option<String>,
}

mod default {
    use std::path::PathBuf;

    pub fn login_expire() -> i64 {
        60 * 60 * 24
    }
    pub fn asset_path() -> PathBuf {
        "data/assets".into()
    }
    pub fn database_path() -> PathBuf {
        "data/database".into()
    }
    pub fn cache_path() -> PathBuf {
        "data/cache".into()
    }
    pub fn media_path() -> PathBuf {
        "data/media".into()
    }
    pub fn secrets_path() -> PathBuf {
        "data/secrets.yaml".into()
    }
    pub fn max_in_memory_cache_size() -> usize {
        50_000_000
    }
}

fn return_true() -> bool {
    true
}