// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
    /// Constructs a fluent builder for the [`PutRolePolicy`](crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder) operation.
    ///
    /// - The fluent builder is configurable:
    ///   - [`role_name(impl Into<String>)`](crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder::role_name) / [`set_role_name(Option<String>)`](crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder::set_role_name):<br>required: **true**<br><p>The name of the role to associate the policy with.</p>  <p>This parameter allows (through its <a href="http://wikipedia.org/wiki/regex">regex pattern</a>) a string of characters consisting of upper and lowercase alphanumeric characters with no spaces. You can also include any of the following characters: _+=,.@-</p><br>
    ///   - [`policy_name(impl Into<String>)`](crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder::policy_name) / [`set_policy_name(Option<String>)`](crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder::set_policy_name):<br>required: **true**<br><p>The name of the policy document.</p>  <p>This parameter allows (through its <a href="http://wikipedia.org/wiki/regex">regex pattern</a>) a string of characters consisting of upper and lowercase alphanumeric characters with no spaces. You can also include any of the following characters: _+=,.@-</p><br>
    ///   - [`policy_document(impl Into<String>)`](crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder::policy_document) / [`set_policy_document(Option<String>)`](crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder::set_policy_document):<br>required: **true**<br><p>The policy document.</p>  <p>You must provide policies in JSON format in IAM. However, for CloudFormation templates formatted in YAML, you can provide the policy in JSON or YAML format. CloudFormation always converts a YAML policy to JSON format before submitting it to IAM.</p>  <p>The <a href="http://wikipedia.org/wiki/regex">regex pattern</a> used to validate this parameter is a string of characters consisting of the following:</p>  <ul>   <li> <p>Any printable ASCII character ranging from the space character (<code>\u0020</code>) through the end of the ASCII character range</p> </li>   <li> <p>The printable characters in the Basic Latin and Latin-1 Supplement character set (through <code>\u00FF</code>)</p> </li>   <li> <p>The special characters tab (<code>\u0009</code>), line feed (<code>\u000A</code>), and carriage return (<code>\u000D</code>)</p> </li>  </ul><br>
    /// - On success, responds with [`PutRolePolicyOutput`](crate::operation::put_role_policy::PutRolePolicyOutput)
    /// - On failure, responds with [`SdkError<PutRolePolicyError>`](crate::operation::put_role_policy::PutRolePolicyError)
    pub fn put_role_policy(&self) -> crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder {
        crate::operation::put_role_policy::builders::PutRolePolicyFluentBuilder::new(self.handle.clone())
    }
}