parent
1fd71fd45a
commit
1de9acb7ad
@ -852,7 +852,7 @@
|
|||||||
- [ ] admin_set_user_settings
|
- [ ] admin_set_user_settings
|
||||||
- [ ] admin_update_auth_event_feedback
|
- [ ] admin_update_auth_event_feedback
|
||||||
- [ ] admin_update_device_status
|
- [ ] admin_update_device_status
|
||||||
- [ ] admin_update_user_attributes
|
- [X] admin_update_user_attributes
|
||||||
- [ ] admin_user_global_sign_out
|
- [ ] admin_user_global_sign_out
|
||||||
- [ ] associate_software_token
|
- [ ] associate_software_token
|
||||||
- [X] change_password
|
- [X] change_password
|
||||||
|
@ -287,6 +287,18 @@ class CognitoIdpUser(BaseModel):
|
|||||||
|
|
||||||
return user_json
|
return user_json
|
||||||
|
|
||||||
|
def update_attributes(self, new_attributes):
|
||||||
|
|
||||||
|
def flatten_attrs(attrs):
|
||||||
|
return {attr['Name']: attr['Value'] for attr in attrs}
|
||||||
|
|
||||||
|
def expand_attrs(attrs):
|
||||||
|
return [{'Name': k, 'Value': v} for k, v in attrs.items()]
|
||||||
|
|
||||||
|
flat_attributes = flatten_attrs(self.attributes)
|
||||||
|
flat_attributes.update(flatten_attrs(new_attributes))
|
||||||
|
self.attributes = expand_attrs(flat_attributes)
|
||||||
|
|
||||||
|
|
||||||
class CognitoIdpBackend(BaseBackend):
|
class CognitoIdpBackend(BaseBackend):
|
||||||
|
|
||||||
@ -673,6 +685,17 @@ class CognitoIdpBackend(BaseBackend):
|
|||||||
else:
|
else:
|
||||||
raise NotAuthorizedError(access_token)
|
raise NotAuthorizedError(access_token)
|
||||||
|
|
||||||
|
def admin_update_user_attributes(self, user_pool_id, username, attributes):
|
||||||
|
user_pool = self.user_pools.get(user_pool_id)
|
||||||
|
if not user_pool:
|
||||||
|
raise ResourceNotFoundError(user_pool_id)
|
||||||
|
|
||||||
|
if username not in user_pool.users:
|
||||||
|
raise UserNotFoundError(username)
|
||||||
|
|
||||||
|
user = user_pool.users[username]
|
||||||
|
user.update_attributes(attributes)
|
||||||
|
|
||||||
|
|
||||||
cognitoidp_backends = {}
|
cognitoidp_backends = {}
|
||||||
for region in boto.cognito.identity.regions():
|
for region in boto.cognito.identity.regions():
|
||||||
|
@ -352,6 +352,13 @@ class CognitoIdpResponse(BaseResponse):
|
|||||||
cognitoidp_backends[region].change_password(access_token, previous_password, proposed_password)
|
cognitoidp_backends[region].change_password(access_token, previous_password, proposed_password)
|
||||||
return ""
|
return ""
|
||||||
|
|
||||||
|
def admin_update_user_attributes(self):
|
||||||
|
user_pool_id = self._get_param("UserPoolId")
|
||||||
|
username = self._get_param("Username")
|
||||||
|
attributes = self._get_param("UserAttributes")
|
||||||
|
cognitoidp_backends[self.region].admin_update_user_attributes(user_pool_id, username, attributes)
|
||||||
|
return ""
|
||||||
|
|
||||||
|
|
||||||
class CognitoIdpJsonWebKeyResponse(BaseResponse):
|
class CognitoIdpJsonWebKeyResponse(BaseResponse):
|
||||||
|
|
||||||
|
@ -1162,3 +1162,53 @@ def test_confirm_forgot_password():
|
|||||||
ConfirmationCode=str(uuid.uuid4()),
|
ConfirmationCode=str(uuid.uuid4()),
|
||||||
Password=str(uuid.uuid4()),
|
Password=str(uuid.uuid4()),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@mock_cognitoidp
|
||||||
|
def test_admin_update_user_attributes():
|
||||||
|
conn = boto3.client("cognito-idp", "us-west-2")
|
||||||
|
|
||||||
|
username = str(uuid.uuid4())
|
||||||
|
user_pool_id = conn.create_user_pool(PoolName=str(uuid.uuid4()))["UserPool"]["Id"]
|
||||||
|
|
||||||
|
conn.admin_create_user(
|
||||||
|
UserPoolId=user_pool_id,
|
||||||
|
Username=username,
|
||||||
|
UserAttributes=[
|
||||||
|
{
|
||||||
|
'Name': 'family_name',
|
||||||
|
'Value': 'Doe',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'Name': 'given_name',
|
||||||
|
'Value': 'John',
|
||||||
|
}
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
conn.admin_update_user_attributes(
|
||||||
|
UserPoolId=user_pool_id,
|
||||||
|
Username=username,
|
||||||
|
UserAttributes=[
|
||||||
|
{
|
||||||
|
'Name': 'family_name',
|
||||||
|
'Value': 'Doe',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'Name': 'given_name',
|
||||||
|
'Value': 'Jane',
|
||||||
|
}
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
user = conn.admin_get_user(
|
||||||
|
UserPoolId=user_pool_id,
|
||||||
|
Username=username
|
||||||
|
)
|
||||||
|
attributes = user['UserAttributes']
|
||||||
|
attributes.should.be.a(list)
|
||||||
|
for attr in attributes:
|
||||||
|
val = attr['Value']
|
||||||
|
if attr['Name'] == 'family_name':
|
||||||
|
val.should.equal('Doe')
|
||||||
|
elif attr['Name'] == 'given_name':
|
||||||
|
val.should.equal('Jane')
|
||||||
|
Loading…
Reference in New Issue
Block a user