implementing detach_group_policy

This commit is contained in:
Jack Danger 2017-10-01 15:04:59 -07:00
parent cdb1ebf666
commit 353f8387a2
2 changed files with 13 additions and 22 deletions

View File

@ -74,25 +74,13 @@ class ManagedPolicy(Policy):
is_attachable = True is_attachable = True
def attach_to_role(self, role): def attach_to(self, obj):
self.attachment_count += 1 self.attachment_count += 1
role.managed_policies[self.name] = self obj.managed_policies[self.name] = self
def detach_from_role(self, role): def detach_from(self, obj):
self.attachment_count -= 1 self.attachment_count -= 1
del role.managed_policies[self.name] del obj.managed_policies[self.name]
def attach_to_group(self, group):
self.attachment_count += 1
group.managed_policies[self.name] = self
def attach_to_user(self, user):
self.attachment_count += 1
user.managed_policies[self.name] = self
def detach_from_user(self, user):
self.attachment_count -= 1
del user.managed_policies[self.name]
class AWSManagedPolicy(ManagedPolicy): class AWSManagedPolicy(ManagedPolicy):
@ -428,13 +416,13 @@ class IAMBackend(BaseBackend):
def attach_role_policy(self, policy_arn, role_name): def attach_role_policy(self, policy_arn, role_name):
arns = dict((p.arn, p) for p in self.managed_policies.values()) arns = dict((p.arn, p) for p in self.managed_policies.values())
policy = arns[policy_arn] policy = arns[policy_arn]
policy.attach_to_role(self.get_role(role_name)) policy.attach_to(self.get_role(role_name))
def detach_role_policy(self, policy_arn, role_name): def detach_role_policy(self, policy_arn, role_name):
arns = dict((p.arn, p) for p in self.managed_policies.values()) arns = dict((p.arn, p) for p in self.managed_policies.values())
try: try:
policy = arns[policy_arn] policy = arns[policy_arn]
policy.detach_from_role(self.get_role(role_name)) policy.detach_from(self.get_role(role_name))
except KeyError: except KeyError:
raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn)) raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn))
@ -444,7 +432,7 @@ class IAMBackend(BaseBackend):
policy = arns[policy_arn] policy = arns[policy_arn]
except KeyError: except KeyError:
raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn)) raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn))
policy.attach_to_group(self.get_group(group_name)) policy.attach_to(self.get_group(group_name))
def detach_group_policy(self, policy_arn, group_name): def detach_group_policy(self, policy_arn, group_name):
arns = dict((p.arn, p) for p in self.managed_policies.values()) arns = dict((p.arn, p) for p in self.managed_policies.values())
@ -452,7 +440,7 @@ class IAMBackend(BaseBackend):
policy = arns[policy_arn] policy = arns[policy_arn]
except KeyError: except KeyError:
raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn)) raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn))
policy.detach_from_group(self.get_group(group_name)) policy.detach_from(self.get_group(group_name))
def attach_user_policy(self, policy_arn, user_name): def attach_user_policy(self, policy_arn, user_name):
arns = dict((p.arn, p) for p in self.managed_policies.values()) arns = dict((p.arn, p) for p in self.managed_policies.values())
@ -460,7 +448,7 @@ class IAMBackend(BaseBackend):
policy = arns[policy_arn] policy = arns[policy_arn]
except KeyError: except KeyError:
raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn)) raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn))
policy.attach_to_user(self.get_user(user_name)) policy.attach_to(self.get_user(user_name))
def detach_user_policy(self, policy_arn, user_name): def detach_user_policy(self, policy_arn, user_name):
arns = dict((p.arn, p) for p in self.managed_policies.values()) arns = dict((p.arn, p) for p in self.managed_policies.values())
@ -468,7 +456,7 @@ class IAMBackend(BaseBackend):
policy = arns[policy_arn] policy = arns[policy_arn]
except KeyError: except KeyError:
raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn)) raise IAMNotFoundException("Policy {0} was not found.".format(policy_arn))
policy.detach_from_user(self.get_user(user_name)) policy.detach_from(self.get_user(user_name))
def create_policy(self, description, path, policy_document, policy_name): def create_policy(self, description, path, policy_document, policy_name):
policy = ManagedPolicy( policy = ManagedPolicy(

View File

@ -98,6 +98,9 @@ def test_attach_group_policies():
} }
]) ])
conn.detach_group_policy(GroupName='my-group', PolicyArn=policy_arn)
conn.list_attached_group_policies(GroupName='my-group')['AttachedPolicies'].should.be.empty
@mock_iam_deprecated() @mock_iam_deprecated()
def test_get_group_policy(): def test_get_group_policy():