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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
#[allow(missing_docs)] // documentation missing in model
#[non_exhaustive]
#[derive(std::clone::Clone, std::cmp::PartialEq, std::fmt::Debug)]
pub struct RemovePermissionInput {
/// <p>The name of the Lambda function, version, or alias.</p>
/// <p class="title"> <b>Name formats</b> </p>
/// <ul>
/// <li> <p> <b>Function name</b> – <code>my-function</code> (name-only), <code>my-function:v1</code> (with alias).</p> </li>
/// <li> <p> <b>Function ARN</b> – <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p> </li>
/// <li> <p> <b>Partial ARN</b> – <code>123456789012:function:my-function</code>.</p> </li>
/// </ul>
/// <p>You can append a version number or alias to any of the formats. The length constraint applies only to the full ARN. If you specify only the function name, it is limited to 64 characters in length.</p>
#[doc(hidden)]
pub function_name: std::option::Option<std::string::String>,
/// <p>Statement ID of the permission to remove.</p>
#[doc(hidden)]
pub statement_id: std::option::Option<std::string::String>,
/// <p>Specify a version or alias to remove permissions from a published version of the function.</p>
#[doc(hidden)]
pub qualifier: std::option::Option<std::string::String>,
/// <p>Update the policy only if the revision ID matches the ID that's specified. Use this option to avoid modifying a policy that has changed since you last read it.</p>
#[doc(hidden)]
pub revision_id: std::option::Option<std::string::String>,
}
impl RemovePermissionInput {
/// <p>The name of the Lambda function, version, or alias.</p>
/// <p class="title"> <b>Name formats</b> </p>
/// <ul>
/// <li> <p> <b>Function name</b> – <code>my-function</code> (name-only), <code>my-function:v1</code> (with alias).</p> </li>
/// <li> <p> <b>Function ARN</b> – <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p> </li>
/// <li> <p> <b>Partial ARN</b> – <code>123456789012:function:my-function</code>.</p> </li>
/// </ul>
/// <p>You can append a version number or alias to any of the formats. The length constraint applies only to the full ARN. If you specify only the function name, it is limited to 64 characters in length.</p>
pub fn function_name(&self) -> std::option::Option<&str> {
self.function_name.as_deref()
}
/// <p>Statement ID of the permission to remove.</p>
pub fn statement_id(&self) -> std::option::Option<&str> {
self.statement_id.as_deref()
}
/// <p>Specify a version or alias to remove permissions from a published version of the function.</p>
pub fn qualifier(&self) -> std::option::Option<&str> {
self.qualifier.as_deref()
}
/// <p>Update the policy only if the revision ID matches the ID that's specified. Use this option to avoid modifying a policy that has changed since you last read it.</p>
pub fn revision_id(&self) -> std::option::Option<&str> {
self.revision_id.as_deref()
}
}
impl RemovePermissionInput {
/// Creates a new builder-style object to manufacture [`RemovePermissionInput`](crate::operation::remove_permission::RemovePermissionInput).
pub fn builder() -> crate::operation::remove_permission::builders::RemovePermissionInputBuilder
{
crate::operation::remove_permission::builders::RemovePermissionInputBuilder::default()
}
}
/// A builder for [`RemovePermissionInput`](crate::operation::remove_permission::RemovePermissionInput).
#[non_exhaustive]
#[derive(std::clone::Clone, std::cmp::PartialEq, std::default::Default, std::fmt::Debug)]
pub struct RemovePermissionInputBuilder {
pub(crate) function_name: std::option::Option<std::string::String>,
pub(crate) statement_id: std::option::Option<std::string::String>,
pub(crate) qualifier: std::option::Option<std::string::String>,
pub(crate) revision_id: std::option::Option<std::string::String>,
}
impl RemovePermissionInputBuilder {
/// <p>The name of the Lambda function, version, or alias.</p>
/// <p class="title"> <b>Name formats</b> </p>
/// <ul>
/// <li> <p> <b>Function name</b> – <code>my-function</code> (name-only), <code>my-function:v1</code> (with alias).</p> </li>
/// <li> <p> <b>Function ARN</b> – <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p> </li>
/// <li> <p> <b>Partial ARN</b> – <code>123456789012:function:my-function</code>.</p> </li>
/// </ul>
/// <p>You can append a version number or alias to any of the formats. The length constraint applies only to the full ARN. If you specify only the function name, it is limited to 64 characters in length.</p>
pub fn function_name(mut self, input: impl Into<std::string::String>) -> Self {
self.function_name = Some(input.into());
self
}
/// <p>The name of the Lambda function, version, or alias.</p>
/// <p class="title"> <b>Name formats</b> </p>
/// <ul>
/// <li> <p> <b>Function name</b> – <code>my-function</code> (name-only), <code>my-function:v1</code> (with alias).</p> </li>
/// <li> <p> <b>Function ARN</b> – <code>arn:aws:lambda:us-west-2:123456789012:function:my-function</code>.</p> </li>
/// <li> <p> <b>Partial ARN</b> – <code>123456789012:function:my-function</code>.</p> </li>
/// </ul>
/// <p>You can append a version number or alias to any of the formats. The length constraint applies only to the full ARN. If you specify only the function name, it is limited to 64 characters in length.</p>
pub fn set_function_name(mut self, input: std::option::Option<std::string::String>) -> Self {
self.function_name = input;
self
}
/// <p>Statement ID of the permission to remove.</p>
pub fn statement_id(mut self, input: impl Into<std::string::String>) -> Self {
self.statement_id = Some(input.into());
self
}
/// <p>Statement ID of the permission to remove.</p>
pub fn set_statement_id(mut self, input: std::option::Option<std::string::String>) -> Self {
self.statement_id = input;
self
}
/// <p>Specify a version or alias to remove permissions from a published version of the function.</p>
pub fn qualifier(mut self, input: impl Into<std::string::String>) -> Self {
self.qualifier = Some(input.into());
self
}
/// <p>Specify a version or alias to remove permissions from a published version of the function.</p>
pub fn set_qualifier(mut self, input: std::option::Option<std::string::String>) -> Self {
self.qualifier = input;
self
}
/// <p>Update the policy only if the revision ID matches the ID that's specified. Use this option to avoid modifying a policy that has changed since you last read it.</p>
pub fn revision_id(mut self, input: impl Into<std::string::String>) -> Self {
self.revision_id = Some(input.into());
self
}
/// <p>Update the policy only if the revision ID matches the ID that's specified. Use this option to avoid modifying a policy that has changed since you last read it.</p>
pub fn set_revision_id(mut self, input: std::option::Option<std::string::String>) -> Self {
self.revision_id = input;
self
}
/// Consumes the builder and constructs a [`RemovePermissionInput`](crate::operation::remove_permission::RemovePermissionInput).
pub fn build(
self,
) -> Result<
crate::operation::remove_permission::RemovePermissionInput,
aws_smithy_http::operation::error::BuildError,
> {
Ok(crate::operation::remove_permission::RemovePermissionInput {
function_name: self.function_name,
statement_id: self.statement_id,
qualifier: self.qualifier,
revision_id: self.revision_id,
})
}
}