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
use bytesize::ByteSize;
use serde::{Deserialize, Serialize};

use super::Merge;

#[derive(Serialize, Deserialize, PartialEq, Eq, Clone, Debug, schemars::JsonSchema)]
pub struct CapabilityFileSystemV1 {
    #[serde(default)]
    pub volumes: Vec<FileSystemVolumeConfigV1>,
}

impl Merge for CapabilityFileSystemV1 {
    fn merge_extend(mut self, other: &Self) -> Self {
        self.volumes.extend(other.volumes.clone());
        self
    }
}

#[derive(Serialize, Deserialize, PartialEq, Eq, Clone, Debug, schemars::JsonSchema)]
pub struct FileSystemVolumeConfigV1 {
    /// Name for the volume in the context of this workload.
    pub name: String,
    pub source: FileSystemVolumeSourceV1,
    pub mounts: Vec<FileSystemVolumeMountV1>,
}

#[derive(Serialize, Deserialize, PartialEq, Eq, Clone, Debug, schemars::JsonSchema)]
pub enum FileSystemVolumeSourceV1 {
    #[serde(rename = "local")]
    Local(FileSystemVolumeSourceLocalV1),
}

#[derive(Serialize, Deserialize, PartialEq, Eq, Clone, Debug, schemars::JsonSchema)]
pub struct FileSystemVolumeSourceLocalV1 {
    #[schemars(with = "String")]
    pub maximum_size: ByteSize,
}

#[derive(Serialize, Deserialize, PartialEq, Eq, Clone, Debug, schemars::JsonSchema)]
pub struct FileSystemVolumeMountV1 {
    /// The path where the volume should be mounted.
    pub path: String,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub permissions: Option<FileSystemPermissionsV1>,
}

#[derive(Serialize, Deserialize, PartialEq, Eq, Clone, Debug, schemars::JsonSchema)]
pub struct FileSystemPermissionsV1 {
    #[serde(skip_serializing_if = "Option::is_none")]
    pub read: Option<bool>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub write: Option<bool>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub delete: Option<bool>,
}