./bin/ddb/schem-load
- When you write a query you have provide a Primary Key (equality) eg. pk = 'andrew'
- Are you allowed to "update" the Hash and Range?
- No, whenever you change a key (simple or composite) eg. pk or sk you have to create a new item.
- you have to delete the old one
- No, whenever you change a key (simple or composite) eg. pk or sk you have to create a new item.
- Key condition expressions for query only for RANGE, HASH is only equality
- Don't create UUID for entity if you don't have an access pattern for it
3 Access Patterns
A user wants to see a list of messages that belong to a message group The messages must be ordered by the created_at timestamp from newest to oldest (DESC)
SELECT
messages.uuid,
messages.display_name,
messages.message,
messages.handle,
messages.created_at -- sk
FROM messages
WHERE
messages.message_group_uuid = {{message_group_uuid}} -- pk
ORDER BY messages.created_at DESC
message_group_uuid comes from Pattern B
A user wants to see a list of previous conversations. These conversations are listed from newest to oldest (DESC) We want to see the other person we are talking to. We want to see the last message (from whomever) in summary.
SELECT
message_groups.uuid,
message_groups.other_user_uuid,
message_groups.other_user_display_name,
message_groups.other_user_handle,
message_groups.last_message,
message_groups.last_message_at
FROM message_groups
WHERE
message_groups.user_uuid = {{user_uuid}} --pk
ORDER BY message_groups.last_message_at DESC
We need a Global Secondary Index (GSI)
INSERT INTO messages (
user_uuid,
display_name,
handle,
creaed_at
)
VALUES (
{{user_uuid}},
{{display_name}},
{{handle}},
{{created_at}}
);
When a user creates a message we need to update the conversation to display the last message information for the conversation
UPDATE message_groups
SET
other_user_uuid = {{other_user_uuid}}
other_user_display_name = {{other_user_display_name}}
other_user_handle = {{other_user_handle}}
last_message = {{last_message}}
last_message_at = {{last_message_at}}
WHERE
message_groups.uuid = {{message_group_uuid}}
AND message_groups.user_uuid = {{user_uuid}}
In your gitpod.yml file add:
- name: momento
before: |
brew tap momentohq/tap
brew install momento-cli
There is no login
you just have to generate an access token and not lose it.
You cannot rotate out your access token on an existing cache.
If you lost your cache or your cache was comprised you just have to wait for the TTL to expire.
It might be possible to rotate out the key by specifcing the same cache name and email.
momento account signup aws --email andrew@exampro.co --region us-east-1
export MOMENTO_AUTH_TOKEN=""
export MOMENTO_TTL_SECONDS="600"
export MOMENTO_CACHE_NAME="cruddur"
gp env MOMENTO_AUTH_TOKEN=""
gp env MOMENTO_TTL_SECONDS="600"
gp env MOMENTO_CACHE_NAME="cruddur"
you might need to do
momento configure
since it might not pick up the env var in the CLI.
Create the cache:
momento cache create --name cruddur
- create a VPC endpoint for dynamoDB service on your VPC
- create a Python lambda function in your vpc
- enable streams on the table with 'new image' attributes included
- add your function as a trigger on the stream
- grant the lambda IAM role permission to read the DynamoDB stream events
AWSLambdaInvocation-DynamoDB
- grant the lambda IAM role permission to update table items
The Function
import json
import boto3
from boto3.dynamodb.conditions import Key, Attr
dynamodb = boto3.resource(
'dynamodb',
region_name='ca-central-1',
endpoint_url="http://dynamodb.ca-central-1.amazonaws.com"
)
def lambda_handler(event, context):
pk = event['Records'][0]['dynamodb']['Keys']['pk']['S']
sk = event['Records'][0]['dynamodb']['Keys']['sk']['S']
if pk.startswith('MSG#'):
group_uuid = pk.replace("MSG#","")
message = event['Records'][0]['dynamodb']['NewImage']['message']['S']
print("GRUP ===>",group_uuid,message)
table_name = 'cruddur-messages'
index_name = 'message-group-sk-index'
table = dynamodb.Table(table_name)
data = table.query(
IndexName=index_name,
KeyConditionExpression=Key('message_group_uuid').eq(group_uuid)
)
print("RESP ===>",data['Items'])
# recreate the message group rows with new SK value
for i in data['Items']:
delete_item = table.delete_item(Key={'pk': i['pk'], 'sk': i['sk']})
print("DELETE ===>",delete_item)
response = table.put_item(
Item={
'pk': i['pk'],
'sk': sk,
'message_group_uuid':i['message_group_uuid'],
'message':message,
'user_display_name': i['user_display_name'],
'user_handle': i['user_handle'],
'user_uuid': i['user_uuid']
}
)
print("CREATE ===>",response)