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
use serde::{Deserialize, Serialize};
use std::env;
/// List of supported CI providers.
#[derive(Clone, Copy, Debug, Default, Deserialize, Serialize)]
pub enum CiProvider {
Agola,
AppCenter,
Appcircle,
AppVeyor,
AwsCodebuild,
Azure,
Bamboo,
Bitbucket,
Bitrise,
Buddy,
Buildkite,
CircleCI,
Cirrus,
Codefresh,
Codemagic,
Codeship,
Drone,
Eas,
GithubActions,
Gitlab,
GoogleCloudBuild,
Harness,
Heroku,
Jenkins,
JenkinsX,
JetbrainsSpace,
Netlify,
Screwdriver,
Scrutinizer,
Semaphore,
TeamCity,
TravisCI,
Vela,
Vercel,
Woodpecker,
XcodeCloud,
XcodeServer,
#[default]
Unknown,
}
pub struct CiOutput {
/// Denotes the closing of a log group.
pub close_log_group: &'static str,
/// Denotes the opening of a log group.
pub open_log_group: &'static str,
}
#[derive(Clone, Debug, Default, Deserialize, Serialize)]
pub struct CiEnvironment {
/// Target branch of the pull/merge request.
pub base_branch: Option<String>,
/// Target revision of the pull/merge request.
pub base_revision: Option<String>,
/// Source branch that triggered the pipeline.
pub branch: String,
/// Prefix that all environment variables use.
pub env_prefix: Option<String>,
/// Source revision of the pull/merge request.
pub head_revision: Option<String>,
/// Unique ID of the current pipeline.
pub id: String,
/// Name of the provider.
pub provider: CiProvider,
/// ID of an associated pull/merge request.
pub request_id: Option<String>,
/// Link to the pull/merge request.
pub request_url: Option<String>,
/// Revision (commit, sha, etc) that triggered the pipeline.
pub revision: String,
/// Link to the pipeline.
pub url: Option<String>,
}
pub fn var(key: &str) -> String {
env::var(key).unwrap_or_default()
}
pub fn opt_var(key: &str) -> Option<String> {
match env::var(key) {
Ok(value) => {
if value == "false" || value.is_empty() {
None
} else {
Some(value)
}
}
Err(_) => None,
}
}