Obtains snapshots, harvests unique entities, and generates entity events for: Playable Character Classes, Races, and Specializations
- Clone,
npm i
npm run local
to fire the lambda method locallynpm run test
to run through jest tests written- Deploys to lambda on commit push to
main
branch on github
- Blizzard API Developer Account and API Key+Secret
- AWS Account, Access to create Lambda Functions
- Github Account to deploy and use Github Actions
- Mongo database, write access connection string
- Pull Race index from BlizzardAPI then each race listed
- Transform Race to
PlayableRace
array - Pull Spec index from BlizzardAPI then each Spec listed
- Map and reduce
PlayableClass
entries on the spec array - Transform Spec to
PlayableSpec
array - Transmit snapshot to database
- Upsert each item from each enum array in snapshot
- If new, add BlizardEntityEvent row to table
MythicEnumSnapshot
:
{ _id, stamp, type, data: { created, classes: [`PlayableClass`], races: [`PlayableRace`], specs: [`PlayableSpec`] } }}
PlayableClass
:
{ id, name }
PlayableRace
:
{ id, name, faction: int, isAllied: bool }
// Faction Enum >>> 0=HORDE, 1=ALLIANCE, 2=NEUTRAL
PlayableSpec
:
{ id, name, class: int, role: int }
// Role Enum >>> 0=TANK, 1=HEALER, 2=DAMAGE
Lambda Function Using:
- 128MB Memory (~100MB used) ~~- Billable Duration over snapshot: ~4260ms~~
-
Deploy to github to leverage GitHub Actions written in .github\workflows
-
Add projects secrets to github repo
AWS_ACCESS_KEY_ID
,DISCORD_NOTIFICATION_WEBHOOK
, andAWS_SECRET_ACCESS_KEY
-
Will need to have a named lambda function already created by the name in deploy yml.
lmda-enum-scanner
here -
Pre-made lambda is going to need environment variables on board, also make local uncommitted .env with those same values. It'll make sure local runs work
-
Create Event Rule in Amazon EventBridge to kick off the named lambda every day
Much of this will be in a Terraform file so it doesn't need to be done manually
-
Pre-made lambda timeout increased to like 15 seconds
See @dungeoneer-io/nodejs-utils for hints on how to configure environment variables in dotenv