gitea_rs/models/
branch_protection.rs1#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
16pub struct BranchProtection {
17 #[serde(rename = "approvals_whitelist_teams", skip_serializing_if = "Option::is_none")]
18 pub approvals_whitelist_teams: Option<Vec<String>>,
19 #[serde(rename = "approvals_whitelist_username", skip_serializing_if = "Option::is_none")]
20 pub approvals_whitelist_username: Option<Vec<String>>,
21 #[serde(rename = "block_on_official_review_requests", skip_serializing_if = "Option::is_none")]
22 pub block_on_official_review_requests: Option<bool>,
23 #[serde(rename = "block_on_outdated_branch", skip_serializing_if = "Option::is_none")]
24 pub block_on_outdated_branch: Option<bool>,
25 #[serde(rename = "block_on_rejected_reviews", skip_serializing_if = "Option::is_none")]
26 pub block_on_rejected_reviews: Option<bool>,
27 #[serde(rename = "branch_name", skip_serializing_if = "Option::is_none")]
29 pub branch_name: Option<String>,
30 #[serde(rename = "created_at", skip_serializing_if = "Option::is_none")]
31 pub created_at: Option<String>,
32 #[serde(rename = "dismiss_stale_approvals", skip_serializing_if = "Option::is_none")]
33 pub dismiss_stale_approvals: Option<bool>,
34 #[serde(rename = "enable_approvals_whitelist", skip_serializing_if = "Option::is_none")]
35 pub enable_approvals_whitelist: Option<bool>,
36 #[serde(rename = "enable_merge_whitelist", skip_serializing_if = "Option::is_none")]
37 pub enable_merge_whitelist: Option<bool>,
38 #[serde(rename = "enable_push", skip_serializing_if = "Option::is_none")]
39 pub enable_push: Option<bool>,
40 #[serde(rename = "enable_push_whitelist", skip_serializing_if = "Option::is_none")]
41 pub enable_push_whitelist: Option<bool>,
42 #[serde(rename = "enable_status_check", skip_serializing_if = "Option::is_none")]
43 pub enable_status_check: Option<bool>,
44 #[serde(rename = "merge_whitelist_teams", skip_serializing_if = "Option::is_none")]
45 pub merge_whitelist_teams: Option<Vec<String>>,
46 #[serde(rename = "merge_whitelist_usernames", skip_serializing_if = "Option::is_none")]
47 pub merge_whitelist_usernames: Option<Vec<String>>,
48 #[serde(rename = "protected_file_patterns", skip_serializing_if = "Option::is_none")]
49 pub protected_file_patterns: Option<String>,
50 #[serde(rename = "push_whitelist_deploy_keys", skip_serializing_if = "Option::is_none")]
51 pub push_whitelist_deploy_keys: Option<bool>,
52 #[serde(rename = "push_whitelist_teams", skip_serializing_if = "Option::is_none")]
53 pub push_whitelist_teams: Option<Vec<String>>,
54 #[serde(rename = "push_whitelist_usernames", skip_serializing_if = "Option::is_none")]
55 pub push_whitelist_usernames: Option<Vec<String>>,
56 #[serde(rename = "require_signed_commits", skip_serializing_if = "Option::is_none")]
57 pub require_signed_commits: Option<bool>,
58 #[serde(rename = "required_approvals", skip_serializing_if = "Option::is_none")]
59 pub required_approvals: Option<i64>,
60 #[serde(rename = "rule_name", skip_serializing_if = "Option::is_none")]
61 pub rule_name: Option<String>,
62 #[serde(rename = "status_check_contexts", skip_serializing_if = "Option::is_none")]
63 pub status_check_contexts: Option<Vec<String>>,
64 #[serde(rename = "unprotected_file_patterns", skip_serializing_if = "Option::is_none")]
65 pub unprotected_file_patterns: Option<String>,
66 #[serde(rename = "updated_at", skip_serializing_if = "Option::is_none")]
67 pub updated_at: Option<String>,
68}
69
70impl BranchProtection {
71 pub fn new() -> BranchProtection {
73 BranchProtection {
74 approvals_whitelist_teams: None,
75 approvals_whitelist_username: None,
76 block_on_official_review_requests: None,
77 block_on_outdated_branch: None,
78 block_on_rejected_reviews: None,
79 branch_name: None,
80 created_at: None,
81 dismiss_stale_approvals: None,
82 enable_approvals_whitelist: None,
83 enable_merge_whitelist: None,
84 enable_push: None,
85 enable_push_whitelist: None,
86 enable_status_check: None,
87 merge_whitelist_teams: None,
88 merge_whitelist_usernames: None,
89 protected_file_patterns: None,
90 push_whitelist_deploy_keys: None,
91 push_whitelist_teams: None,
92 push_whitelist_usernames: None,
93 require_signed_commits: None,
94 required_approvals: None,
95 rule_name: None,
96 status_check_contexts: None,
97 unprotected_file_patterns: None,
98 updated_at: None,
99 }
100 }
101}
102
103