use serde::Serialize;
use std::cell::RefCell;
use std::rc::Rc;
use terrars::*;
use super::provider::ProviderGithub;
#[derive(Serialize)]
struct ActionsOrganizationPermissionsData {
#[serde(skip_serializing_if = "Vec::is_empty")]
depends_on: Vec<String>,
#[serde(skip_serializing_if = "Option::is_none")]
provider: Option<String>,
#[serde(skip_serializing_if = "SerdeSkipDefault::is_default")]
lifecycle: ResourceLifecycle,
#[serde(skip_serializing_if = "Option::is_none")]
for_each: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
allowed_actions: Option<PrimField<String>>,
enabled_repositories: PrimField<String>,
#[serde(skip_serializing_if = "Option::is_none")]
id: Option<PrimField<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
allowed_actions_config: Option<Vec<ActionsOrganizationPermissionsAllowedActionsConfigEl>>,
#[serde(skip_serializing_if = "Option::is_none")]
enabled_repositories_config: Option<Vec<ActionsOrganizationPermissionsEnabledRepositoriesConfigEl>>,
dynamic: ActionsOrganizationPermissionsDynamic,
}
struct ActionsOrganizationPermissions_ {
shared: StackShared,
tf_id: String,
data: RefCell<ActionsOrganizationPermissionsData>,
}
#[derive(Clone)]
pub struct ActionsOrganizationPermissions(Rc<ActionsOrganizationPermissions_>);
impl ActionsOrganizationPermissions {
fn shared(&self) -> &StackShared {
&self.0.shared
}
pub fn depends_on(self, dep: &impl Referable) -> Self {
self.0.data.borrow_mut().depends_on.push(dep.extract_ref());
self
}
pub fn set_provider(self, provider: &ProviderGithub) -> Self {
self.0.data.borrow_mut().provider = Some(provider.provider_ref());
self
}
pub fn set_create_before_destroy(self, v: bool) -> Self {
self.0.data.borrow_mut().lifecycle.create_before_destroy = v;
self
}
pub fn set_prevent_destroy(self, v: bool) -> Self {
self.0.data.borrow_mut().lifecycle.prevent_destroy = v;
self
}
pub fn ignore_changes_to_all(self) -> Self {
self.0.data.borrow_mut().lifecycle.ignore_changes = Some(IgnoreChanges::All(IgnoreChangesAll::All));
self
}
pub fn ignore_changes_to_attr(self, attr: impl ToString) -> Self {
{
let mut d = self.0.data.borrow_mut();
if match &mut d.lifecycle.ignore_changes {
Some(i) => match i {
IgnoreChanges::All(_) => {
true
},
IgnoreChanges::Refs(r) => {
r.push(attr.to_string());
false
},
},
None => true,
} {
d.lifecycle.ignore_changes = Some(IgnoreChanges::Refs(vec![attr.to_string()]));
}
}
self
}
pub fn replace_triggered_by_resource(self, r: &impl Resource) -> Self {
self.0.data.borrow_mut().lifecycle.replace_triggered_by.push(r.extract_ref());
self
}
pub fn replace_triggered_by_attr(self, attr: impl ToString) -> Self {
self.0.data.borrow_mut().lifecycle.replace_triggered_by.push(attr.to_string());
self
}
#[doc= "Set the field `allowed_actions`.\nThe permissions policy that controls the actions that are allowed to run. Can be one of: 'all', 'local_only', or 'selected'."]
pub fn set_allowed_actions(self, v: impl Into<PrimField<String>>) -> Self {
self.0.data.borrow_mut().allowed_actions = Some(v.into());
self
}
#[doc= "Set the field `id`.\n"]
pub fn set_id(self, v: impl Into<PrimField<String>>) -> Self {
self.0.data.borrow_mut().id = Some(v.into());
self
}
#[doc= "Set the field `allowed_actions_config`.\n"]
pub fn set_allowed_actions_config(
self,
v: impl Into<BlockAssignable<ActionsOrganizationPermissionsAllowedActionsConfigEl>>,
) -> Self {
match v.into() {
BlockAssignable::Literal(v) => {
self.0.data.borrow_mut().allowed_actions_config = Some(v);
},
BlockAssignable::Dynamic(d) => {
self.0.data.borrow_mut().dynamic.allowed_actions_config = Some(d);
},
}
self
}
#[doc= "Set the field `enabled_repositories_config`.\n"]
pub fn set_enabled_repositories_config(
self,
v: impl Into<BlockAssignable<ActionsOrganizationPermissionsEnabledRepositoriesConfigEl>>,
) -> Self {
match v.into() {
BlockAssignable::Literal(v) => {
self.0.data.borrow_mut().enabled_repositories_config = Some(v);
},
BlockAssignable::Dynamic(d) => {
self.0.data.borrow_mut().dynamic.enabled_repositories_config = Some(d);
},
}
self
}
#[doc= "Get a reference to the value of field `allowed_actions` after provisioning.\nThe permissions policy that controls the actions that are allowed to run. Can be one of: 'all', 'local_only', or 'selected'."]
pub fn allowed_actions(&self) -> PrimExpr<String> {
PrimExpr::new(self.shared().clone(), format!("{}.allowed_actions", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `enabled_repositories` after provisioning.\nThe policy that controls the repositories in the organization that are allowed to run GitHub Actions. Can be one of: 'all', 'none', or 'selected'."]
pub fn enabled_repositories(&self) -> PrimExpr<String> {
PrimExpr::new(self.shared().clone(), format!("{}.enabled_repositories", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `id` after provisioning.\n"]
pub fn id(&self) -> PrimExpr<String> {
PrimExpr::new(self.shared().clone(), format!("{}.id", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `allowed_actions_config` after provisioning.\n"]
pub fn allowed_actions_config(&self) -> ListRef<ActionsOrganizationPermissionsAllowedActionsConfigElRef> {
ListRef::new(self.shared().clone(), format!("{}.allowed_actions_config", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `enabled_repositories_config` after provisioning.\n"]
pub fn enabled_repositories_config(&self) -> ListRef<ActionsOrganizationPermissionsEnabledRepositoriesConfigElRef> {
ListRef::new(self.shared().clone(), format!("{}.enabled_repositories_config", self.extract_ref()))
}
}
impl Referable for ActionsOrganizationPermissions {
fn extract_ref(&self) -> String {
format!("{}.{}", self.0.extract_resource_type(), self.0.extract_tf_id())
}
}
impl Resource for ActionsOrganizationPermissions { }
impl ToListMappable for ActionsOrganizationPermissions {
type O = ListRef<ActionsOrganizationPermissionsRef>;
fn do_map(self, base: String) -> Self::O {
self.0.data.borrow_mut().for_each = Some(format!("${{{}}}", base));
ListRef::new(self.0.shared.clone(), self.extract_ref())
}
}
impl Resource_ for ActionsOrganizationPermissions_ {
fn extract_resource_type(&self) -> String {
"github_actions_organization_permissions".into()
}
fn extract_tf_id(&self) -> String {
self.tf_id.clone()
}
fn extract_value(&self) -> serde_json::Value {
serde_json::to_value(&self.data).unwrap()
}
}
pub struct BuildActionsOrganizationPermissions {
pub tf_id: String,
#[doc= "The policy that controls the repositories in the organization that are allowed to run GitHub Actions. Can be one of: 'all', 'none', or 'selected'."]
pub enabled_repositories: PrimField<String>,
}
impl BuildActionsOrganizationPermissions {
pub fn build(self, stack: &mut Stack) -> ActionsOrganizationPermissions {
let out = ActionsOrganizationPermissions(Rc::new(ActionsOrganizationPermissions_ {
shared: stack.shared.clone(),
tf_id: self.tf_id,
data: RefCell::new(ActionsOrganizationPermissionsData {
depends_on: core::default::Default::default(),
provider: None,
lifecycle: core::default::Default::default(),
for_each: None,
allowed_actions: core::default::Default::default(),
enabled_repositories: self.enabled_repositories,
id: core::default::Default::default(),
allowed_actions_config: core::default::Default::default(),
enabled_repositories_config: core::default::Default::default(),
dynamic: Default::default(),
}),
}));
stack.add_resource(out.0.clone());
out
}
}
pub struct ActionsOrganizationPermissionsRef {
shared: StackShared,
base: String,
}
impl Ref for ActionsOrganizationPermissionsRef {
fn new(shared: StackShared, base: String) -> Self {
Self {
shared: shared,
base: base,
}
}
}
impl ActionsOrganizationPermissionsRef {
fn extract_ref(&self) -> String {
self.base.clone()
}
fn shared(&self) -> &StackShared {
&self.shared
}
#[doc= "Get a reference to the value of field `allowed_actions` after provisioning.\nThe permissions policy that controls the actions that are allowed to run. Can be one of: 'all', 'local_only', or 'selected'."]
pub fn allowed_actions(&self) -> PrimExpr<String> {
PrimExpr::new(self.shared().clone(), format!("{}.allowed_actions", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `enabled_repositories` after provisioning.\nThe policy that controls the repositories in the organization that are allowed to run GitHub Actions. Can be one of: 'all', 'none', or 'selected'."]
pub fn enabled_repositories(&self) -> PrimExpr<String> {
PrimExpr::new(self.shared().clone(), format!("{}.enabled_repositories", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `id` after provisioning.\n"]
pub fn id(&self) -> PrimExpr<String> {
PrimExpr::new(self.shared().clone(), format!("{}.id", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `allowed_actions_config` after provisioning.\n"]
pub fn allowed_actions_config(&self) -> ListRef<ActionsOrganizationPermissionsAllowedActionsConfigElRef> {
ListRef::new(self.shared().clone(), format!("{}.allowed_actions_config", self.extract_ref()))
}
#[doc= "Get a reference to the value of field `enabled_repositories_config` after provisioning.\n"]
pub fn enabled_repositories_config(&self) -> ListRef<ActionsOrganizationPermissionsEnabledRepositoriesConfigElRef> {
ListRef::new(self.shared().clone(), format!("{}.enabled_repositories_config", self.extract_ref()))
}
}
#[derive(Serialize)]
pub struct ActionsOrganizationPermissionsAllowedActionsConfigEl {
github_owned_allowed: PrimField<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
patterns_allowed: Option<SetField<PrimField<String>>>,
#[serde(skip_serializing_if = "Option::is_none")]
verified_allowed: Option<PrimField<bool>>,
}
impl ActionsOrganizationPermissionsAllowedActionsConfigEl {
#[doc= "Set the field `patterns_allowed`.\nSpecifies a list of string-matching patterns to allow specific action(s). Wildcards, tags, and SHAs are allowed. For example, 'monalisa/octocat@', 'monalisa/octocat@v2', 'monalisa/'."]
pub fn set_patterns_allowed(mut self, v: impl Into<SetField<PrimField<String>>>) -> Self {
self.patterns_allowed = Some(v.into());
self
}
#[doc= "Set the field `verified_allowed`.\nWhether actions in GitHub Marketplace from verified creators are allowed. Set to 'true' to allow all GitHub Marketplace actions by verified creators."]
pub fn set_verified_allowed(mut self, v: impl Into<PrimField<bool>>) -> Self {
self.verified_allowed = Some(v.into());
self
}
}
impl ToListMappable for ActionsOrganizationPermissionsAllowedActionsConfigEl {
type O = BlockAssignable<ActionsOrganizationPermissionsAllowedActionsConfigEl>;
fn do_map(self, base: String) -> Self::O {
BlockAssignable::Dynamic(DynamicBlock {
for_each: format!("${{{}}}", base),
iterator: "each".into(),
content: self,
})
}
}
pub struct BuildActionsOrganizationPermissionsAllowedActionsConfigEl {
#[doc= "Whether GitHub-owned actions are allowed in the organization."]
pub github_owned_allowed: PrimField<bool>,
}
impl BuildActionsOrganizationPermissionsAllowedActionsConfigEl {
pub fn build(self) -> ActionsOrganizationPermissionsAllowedActionsConfigEl {
ActionsOrganizationPermissionsAllowedActionsConfigEl {
github_owned_allowed: self.github_owned_allowed,
patterns_allowed: core::default::Default::default(),
verified_allowed: core::default::Default::default(),
}
}
}
pub struct ActionsOrganizationPermissionsAllowedActionsConfigElRef {
shared: StackShared,
base: String,
}
impl Ref for ActionsOrganizationPermissionsAllowedActionsConfigElRef {
fn new(shared: StackShared, base: String) -> ActionsOrganizationPermissionsAllowedActionsConfigElRef {
ActionsOrganizationPermissionsAllowedActionsConfigElRef {
shared: shared,
base: base.to_string(),
}
}
}
impl ActionsOrganizationPermissionsAllowedActionsConfigElRef {
fn shared(&self) -> &StackShared {
&self.shared
}
#[doc= "Get a reference to the value of field `github_owned_allowed` after provisioning.\nWhether GitHub-owned actions are allowed in the organization."]
pub fn github_owned_allowed(&self) -> PrimExpr<bool> {
PrimExpr::new(self.shared().clone(), format!("{}.github_owned_allowed", self.base))
}
#[doc= "Get a reference to the value of field `patterns_allowed` after provisioning.\nSpecifies a list of string-matching patterns to allow specific action(s). Wildcards, tags, and SHAs are allowed. For example, 'monalisa/octocat@', 'monalisa/octocat@v2', 'monalisa/'."]
pub fn patterns_allowed(&self) -> SetRef<PrimExpr<String>> {
SetRef::new(self.shared().clone(), format!("{}.patterns_allowed", self.base))
}
#[doc= "Get a reference to the value of field `verified_allowed` after provisioning.\nWhether actions in GitHub Marketplace from verified creators are allowed. Set to 'true' to allow all GitHub Marketplace actions by verified creators."]
pub fn verified_allowed(&self) -> PrimExpr<bool> {
PrimExpr::new(self.shared().clone(), format!("{}.verified_allowed", self.base))
}
}
#[derive(Serialize)]
pub struct ActionsOrganizationPermissionsEnabledRepositoriesConfigEl {
repository_ids: SetField<PrimField<f64>>,
}
impl ActionsOrganizationPermissionsEnabledRepositoriesConfigEl { }
impl ToListMappable for ActionsOrganizationPermissionsEnabledRepositoriesConfigEl {
type O = BlockAssignable<ActionsOrganizationPermissionsEnabledRepositoriesConfigEl>;
fn do_map(self, base: String) -> Self::O {
BlockAssignable::Dynamic(DynamicBlock {
for_each: format!("${{{}}}", base),
iterator: "each".into(),
content: self,
})
}
}
pub struct BuildActionsOrganizationPermissionsEnabledRepositoriesConfigEl {
#[doc= "List of repository IDs to enable for GitHub Actions."]
pub repository_ids: SetField<PrimField<f64>>,
}
impl BuildActionsOrganizationPermissionsEnabledRepositoriesConfigEl {
pub fn build(self) -> ActionsOrganizationPermissionsEnabledRepositoriesConfigEl {
ActionsOrganizationPermissionsEnabledRepositoriesConfigEl { repository_ids: self.repository_ids }
}
}
pub struct ActionsOrganizationPermissionsEnabledRepositoriesConfigElRef {
shared: StackShared,
base: String,
}
impl Ref for ActionsOrganizationPermissionsEnabledRepositoriesConfigElRef {
fn new(shared: StackShared, base: String) -> ActionsOrganizationPermissionsEnabledRepositoriesConfigElRef {
ActionsOrganizationPermissionsEnabledRepositoriesConfigElRef {
shared: shared,
base: base.to_string(),
}
}
}
impl ActionsOrganizationPermissionsEnabledRepositoriesConfigElRef {
fn shared(&self) -> &StackShared {
&self.shared
}
#[doc= "Get a reference to the value of field `repository_ids` after provisioning.\nList of repository IDs to enable for GitHub Actions."]
pub fn repository_ids(&self) -> SetRef<PrimExpr<f64>> {
SetRef::new(self.shared().clone(), format!("{}.repository_ids", self.base))
}
}
#[derive(Serialize, Default)]
struct ActionsOrganizationPermissionsDynamic {
allowed_actions_config: Option<DynamicBlock<ActionsOrganizationPermissionsAllowedActionsConfigEl>>,
enabled_repositories_config: Option<DynamicBlock<ActionsOrganizationPermissionsEnabledRepositoriesConfigEl>>,
}