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
use colored::*;
use std::collections::BTreeMap;
use std::path::Path;
use serde_yaml::{Mapping, Value, Error};
pub struct ComposeYaml {
map: BTreeMap<String, Value>
}
impl ComposeYaml {
pub fn new(yaml: &str) -> Result<ComposeYaml, Error> {
let map = serde_yaml::from_str(&yaml)?;
Ok(ComposeYaml { map })
}
pub fn get_root_element(&self, element_name: &str) -> Option<&Mapping> {
let value = self.map.get(element_name);
value.map(|v| v.as_mapping()).unwrap_or_default()
}
pub fn get_root_element_names(&self, element_name: &str) -> Vec<&str> {
let elements = self.get_root_element(element_name);
match elements {
Some(s) => s.keys().map(|k| k.as_str().unwrap()).collect::<Vec<_>>(),
None => Vec::default()
}
}
}
static COMPOSE_PATHS: [&str; 8] = [
"compose.yaml", "compose.yml",
"docker-compose.yaml", "docker-compose.yml",
"docker/compose.yaml", "docker/compose.yml",
"docker/docker-compose.yaml", "docker/docker-compose.yml",
];
pub fn get_compose_filename(filename: &Option<String>) -> Result<String, String> {
match filename {
Some(name) =>
if Path::new(&name).exists() {
Ok(String::from(name))
} else {
Err(format!("{}: No such file or directory: '{}'", "ERROR".red(), name))
},
None =>
COMPOSE_PATHS
.into_iter()
.filter(|f| Path::new(f).exists())
.map(|name| String::from(name))
.next()
.ok_or(format!(
"{}: Can't find a suitable configuration file in this directory.\n\
Are you in the right directory?\n\n\
Supported filenames: {}",
"ERROR".red(), COMPOSE_PATHS.into_iter().collect::<Vec<&str>>().join(", ")
)),
}
}