update user on konviva

This commit is contained in:
2025-07-18 13:05:03 -03:00
parent 61e7ac0f4b
commit 64946471b9
6 changed files with 94 additions and 6 deletions

View File

@@ -35,10 +35,10 @@ def lambda_handler(event: EventBridgeEvent, context: LambdaContext) -> bool:
except konviva.EmailAlreadyExistsError as exc:
logger.exception(exc, email=new_image['email'])
r = konviva.get_users_by_email(new_image['email'])
user_id = glom(r, '0.IDUsuario')
result = konviva.get_users_by_email(new_image['email'])
user_id = glom(result, '0.IDUsuario')
if not r:
if not result:
raise UserNotFoundError()
except Exception:
raise

View File

@@ -0,0 +1,44 @@
from aws_lambda_powertools import Logger
from aws_lambda_powertools.utilities.data_classes import (
EventBridgeEvent,
event_source,
)
from aws_lambda_powertools.utilities.typing import LambdaContext
from layercake.dynamodb import DynamoDBPersistenceLayer
import konviva
from boto3clients import dynamodb_client
from config import ENROLLMENT_TABLE
logger = Logger(__name__)
enrollment_layer = DynamoDBPersistenceLayer(ENROLLMENT_TABLE, dynamodb_client)
@event_source(data_class=EventBridgeEvent)
@logger.inject_lambda_context
def lambda_handler(event: EventBridgeEvent, context: LambdaContext) -> bool:
new_image = event.detail['new_image']
changes = event.detail['changes']
user_id = new_image['metadata__konviva_user_id']
payload = {}
for attr in changes:
match attr:
case 'name':
payload.update(NomeUsuario=new_image['name'])
case 'email':
payload.update(
Email=new_image['email'],
Login=new_image['email'],
)
case 'cpf':
payload.update(CPF=new_image['cpf'])
try:
result = konviva.update_user(id=user_id, **payload)
except Exception as exc:
logger.exception(exc)
return False
else:
logger.info('User updated', result=result, payload=payload)
return True