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
use crate::docker::{Server, ServerConfig, TestInstance};
use dockertest::{waitfor, Composition, DockerOperations, Image, PullPolicy, Source};
#[derive(Clone)]
pub struct VaultServerConfig {
pub handle: String,
pub timeout: u16,
pub token: String,
pub port: u32,
pub version: String,
}
impl ServerConfig for VaultServerConfig {
fn to_comp(&self) -> Composition {
const IMAGE_NAME: &str = "vault";
const IMAGE_PORT: u32 = 8200;
const WAIT_MESSAGE: &str =
"Development mode should NOT be used in production installations!";
const PULL_POLICY: PullPolicy = PullPolicy::IfNotPresent;
const SOURCE: Source = Source::DockerHub(PULL_POLICY);
let image = Image::with_repository(IMAGE_NAME)
.source(SOURCE)
.tag(&self.version);
let wait = Box::new(waitfor::MessageWait {
message: String::from(WAIT_MESSAGE),
source: waitfor::MessageSource::Stdout,
timeout: self.timeout,
});
let mut comp = Composition::with_image(image);
comp.env("VAULT_DEV_ROOT_TOKEN_ID", &self.token);
comp.port_map(IMAGE_PORT, self.port);
comp.with_wait_for(wait).with_container_name(&self.handle)
}
fn to_instance(&self) -> TestInstance {
TestInstance::new(vec![self.to_comp()])
}
}
impl VaultServerConfig {
pub fn new(
handle: &str,
port: u32,
version: &str,
token: &str,
timeout: u16,
) -> VaultServerConfig {
VaultServerConfig {
handle: handle.to_string(),
port,
timeout,
token: token.to_string(),
version: version.to_string(),
}
}
pub fn default(version: Option<&str>) -> VaultServerConfig {
VaultServerConfig {
handle: String::from("vaultrs-vault"),
port: 8300,
timeout: 15,
token: String::from("test"),
version: version
.map(|v| v.to_string())
.unwrap_or_else(|| String::from("latest")),
}
}
}
pub struct VaultServer {
pub address: String,
pub address_internal: String,
pub config: VaultServerConfig,
}
impl Server for VaultServer {
type Config = VaultServerConfig;
fn new(opts: &DockerOperations, config: &Self::Config) -> Self {
let cont = opts.handle(config.handle.as_str());
let address = format!("http://localhost:{}", config.port);
let address_internal = format!("http://{}:{}", cont.ip(), config.port);
VaultServer {
address,
address_internal,
config: config.clone(),
}
}
}