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
|
module Fog
module AWS
class IAM
class Real
require 'fog/aws/parsers/iam/basic'
# Add or update the account password policy
#
# ==== Parameters
# * MinimumPasswordLength<~integer> Minimum length to require for IAM user passwords.
# * MaxPasswordAge<~integer> The number of days that an IAM user password is valid.
# * PasswordReusePrevention<~integer> Specifies the number of previous passwords that IAM users are prevented from reusing.
# * RequireSymbols<~boolean> Specifies whether to require symbols for IAM user passwords.
# * RequireNumbers<~boolean> Specifies whether to require numbers for IAM user passwords.
# * RequireUppercaseCharacters<~boolean> Specifies whether to require uppercase characters for IAM user passwords.
# * RequireLowercaseCharacters<~boolean> Specifies whether to require lowercase characters for IAM user passwords.
# * AllowUsersToChangePassword<~boolean> Specifies whether IAM users are allowed to change their own password.
# * HardExpiry<~boolean> Specifies whether IAM users are prevented from setting a new password after their password has expired.
# * ExpirePasswords<~boolean> Specifies whether IAM users are required to change their password after a specified number of days.
#
# ==== Returns
# * response<~Excon::Response>:
# * body<~Hash>:
# * 'RequestId'<~String> - Id of the request
#
# ==== See Also
# http://docs.aws.amazon.com/IAM/latest/APIReference/API_UpdateAccountPasswordPolicy.html
#
def update_account_password_policy(minimum_password_length, max_password_age, password_reuse_prevention,require_symbols,require_numbers,require_uppercase_characters, require_lowercase_characters,allow_users_to_change_password, hard_expiry, expire_passwords)
request({
'Action' => 'UpdateAccountPasswordPolicy',
'MinimumPasswordLength' => minimum_password_length,
'MaxPasswordAge' => max_password_age,
'PasswordReusePrevention' => password_reuse_prevention,
'RequireSymbols' => require_symbols,
'RequireNumbers' => require_numbers,
'RequireUppercaseCharacters' => require_uppercase_characters,
'RequireLowercaseCharacters' => require_lowercase_characters,
'AllowUsersToChangePassword' => allow_users_to_change_password,
'HardExpiry' => hard_expiry,
'ExpirePasswords' => expire_passwords,
:parser => Fog::Parsers::AWS::IAM::Basic.new
})
end
end
class Mock
def update_account_password_policy(minimum_password_length, max_password_age, password_reuse_prevention,require_symbols,require_numbers,require_uppercase_characters, require_lowercase_characters,allow_users_to_change_password, hard_expiry, expire_passwords)
Excon::Response.new.tap do |response|
response.body = { 'RequestId' => Fog::AWS::Mock.request_id }
response.status = 200
end
end
end
end
end
end
|