Service - Activity Switchboard: Difference between revisions

From Izara Wiki
Jump to navigation Jump to search
No edit summary
Line 33: Line 33:
; triggerGroupId
; triggerGroupId
: (partition key)
: (partition key)
: comes from: {endpoint}_{unique id given be creating service}
: comes from: {creating service name}_{unique id given be creating service}
: or could be a random uuid
: or could be a random uuid
; triggerIds
; triggerIds
: array (DynamoDB list) of triggerIds
: array (DynamoDB list) of triggerIds
; endpoint
; endpoint
: matches an endpoint record in Config table
: matches an endpoint record in Config table, is set by the creating service
; additionalData
; additionalData
: set by the service that creates this trigger group, gets added to the message sent to the endpoint
: set by the creating service, gets added to the message sent back to the endpoint
: often will include id needed by the receiving endpoing to match the trigger to its entity, eg to a notifcation record in [[Service - Notification Manager|Notification Manager]] service
: often will include id needed by the receiving endpoing to match the trigger to its entity, eg to a notifcation record in [[Service - Notification Manager|Notification Manager]] service


Line 51: Line 51:
; triggerId
; triggerId
: (partition key)
: (partition key)
: comes from: {meta|property}_{hash of property name}_{hash of value}
: comes from: {"meta"|"property"}_{hash of property name}_{hash of value}
: meta is for metadata fields such as the messageTag, message attributes
: meta is for metadata fields such as the messageTag, message attributes
: property is from the data sent inside the message body
: property is from the data sent inside the message body
Line 60: Line 60:
* Service will result in a large number of queries to Triggers table, every message will need to make a query for every field set as an activityTrigger
* Service will result in a large number of queries to Triggers table, every message will need to make a query for every field set as an activityTrigger
* Try to make this as efficient as possible
* Try to make this as efficient as possible
* To reduce number of queries made to Tiggers table we use the MsgCfg for any message received, which sets which properties can be used as triggers
* To reduce number of queries made to Tiggers table we use the MsgCfg for any message received
** MsgCfg sets whether each MsgTag is monitored by the Activity Switchboard, if not then do not subscribe
*** This means Activity Switchboard subscription to MsgIn and MsgOut are not a blanket subscription, will need to create a subscription for each MsgTag
*** If MsgCfg changes would want a way that removes no longer used subscriptions, might need to record subscription arn when create, so can remove them when re-checking MsgCfgs
** MsgCfg sets which properties can be used as triggers, others are not queried


= Ideas =
= Ideas =

Revision as of 03:09, 8 November 2020

Overview

Receives most messages sent within the entire project's serverless flow, allows services to register triggers that check if values in each message match the triggers filters, when matches are found the specified endpoint is notified.

Repository

https://bitbucket.org/stb_working/activity-switchboard/src/master/

DynamoDB tables

Standard Config Table Per Service

Configuration tags

configKey = endpoint, configTag = {tag for the endpoint config}
configValue example
{
	"endpoint": {eg: Lambda function name}
	"service_type": {eg: "Lambda"} //service type tag, at the moment only "Lambda"
}
configKey = msgCfg, configTag = {service name}_{msgTag}
propogated from Message Config Manager service
see Standard MsgIn MsgOut message config

TriggerGroup

  • Groups many triggers, all triggers for a trigger group must pass for the trigger group to notify the endpoint

Fields

triggerGroupId
(partition key)
comes from: {creating service name}_{unique id given be creating service}
or could be a random uuid
triggerIds
array (DynamoDB list) of triggerIds
endpoint
matches an endpoint record in Config table, is set by the creating service
additionalData
set by the creating service, gets added to the message sent back to the endpoint
often will include id needed by the receiving endpoing to match the trigger to its entity, eg to a notifcation record in Notification Manager service

Triggers

  • no sort key

Fields

triggerId
(partition key)
comes from: {"meta"|"property"}_{hash of property name}_{hash of value}
meta is for metadata fields such as the messageTag, message attributes
property is from the data sent inside the message body
triggerGroupId

Notes

  • Service will result in a large number of queries to Triggers table, every message will need to make a query for every field set as an activityTrigger
  • Try to make this as efficient as possible
  • To reduce number of queries made to Tiggers table we use the MsgCfg for any message received
    • MsgCfg sets whether each MsgTag is monitored by the Activity Switchboard, if not then do not subscribe
      • This means Activity Switchboard subscription to MsgIn and MsgOut are not a blanket subscription, will need to create a subscription for each MsgTag
      • If MsgCfg changes would want a way that removes no longer used subscriptions, might need to record subscription arn when create, so can remove them when re-checking MsgCfgs
    • MsgCfg sets which properties can be used as triggers, others are not queried

Ideas

  • If more efficient can use cache for regular DynamoDB queries
  • Could add other matching methods such as greater than or less than, in DynamoDB this might be more efficient to add as separate table with its own structure, eg: partition key is the field reference, sort key is the amount, then use sort key to return matching triggers. Danger of bad partitioning in DynamoDB (or hitting limits) due to large numbers of sort keys associated with one partition key
  • Might be able to optimise by using SNS > stream instead of SNS > SQS for all incomming messages
  • One system level endpoint could be specialized logs, eg service per user/per product/etc logs

Working documents

Working_documents - Activity Switchboard