Skip to content

Latest commit

 

History

History
266 lines (184 loc) · 8.47 KB

README.md

File metadata and controls

266 lines (184 loc) · 8.47 KB

icon Pecuniary

Build Deploy CodeFactor GitHub issues open GitHub issues closed Chat license

Getting Started | Architecture | Development | Trello | Resources

An event-driven serverless microservices financial investment application built with Next.js and Tailwind CSS on Amazon Web Services

Architecture

Top Level

⚠️Note: the Event Sourcing and CQRS version is no longer maintained. Please see branch and CQRS Architecture for the last release.

Getting Started

This quick start guide describes how to get the application running. An AWS account is required to deploy the infrastructure required for this project.

Configure the app

  1. Clone the project

    $ git clone https://github.com/eric-bach/pecuniary.git
  2. Install dependencies for CDK

    $ cd ./infrastructure
    $ npm install
  3. Install dependencies for the rest of the application using the recursive-install script

    $ cd ./infrastructure
    $ npm cinstall-all
  4. Copy the ./infrastructure/.env.example file to ./infrastructure/.env and fill in the parameter values (if the app has not been deployed to AWS yet, the ARN will be empty for now):

    DLQ_NOTIFICATIONS - email address to send failed event message notifications to.
    AWS_SERVICE_ROLE_ARN - ARN of the GitHub actions role to deploy the stack.
    
  5. Copy the ./frontend/.env.example file to ./frontend/.env and fill in the parameter values from the CDK stack outputs in step 2:

    NEXT_PUBLIC_USER_POOL_ID=
    NEXT_PUBLIC_USER_POOL_CLIENT_ID=
    NEXT_PUBLIC_APPSYNC_API_ENDPOINT=
    NEXT_PUBLIC_APPSYNC_REGION=
    

Deploy the app

  1. Follow the steps in Deployment with CDK CLI

Running the app locally

  1. Start the frontend:

    $ cd frontend
    $ npm run dev

Deployment

Deployment with CDK CLI

The Pecuniary application consists of the CDK backend and React frontend, each of which has an independent method of deploying. The backend is deployed via CDK where the frontend is deployed via SST.

Deploy backend via CDK script

  1. Bootstrap CDK (one-time only)

    $ cdk bootstrap aws://{ACCOUNT_ID}/{REGION} --profile {PROFILE_NAME}}
    
  2. Ensure AWS credentials are up to date. If using AWS SSO, authorize a set of temporary credentials

    aws sso login --profile PROFILE_NAME
  3. Deploy the backend and frontend

    $ npm run deploy dev PROFILE_NAME
    

Deployment via GitHub Actions

  1. Create an AWS role that can be assumed by GitHub Actions

    $ npm run deploy-cicd prod PROFILE_NAME
    
  2. Add the following GitHub Secrets to the repository

    Common

    CDK_DEFAULT_REGION - AWS default region for all resources to be created
    

    Dev environment

    CLOUDFRONT_DOMAIN_DEV - AWS CloudFront Distribution domain name
    COGNITO_USERPOOL_ID_DEV - Cognito User Pool Id
    COGNITO_WEB_CLIENT_ID_DEV - Cognito User Pool Client Id
    APPSYNC_ENDPOINT_DEV - AWS AppSync GraphQL endpoint URL
    CYPRESS_USERNAME - A valid Cognito username for Cypress integration testing
    CYPRESS_PASSWORD - The Cognito password for Cypress integration testing
    

    Production environment

    AWS_SERVICE_ROLE_PROD - AWS ARN of the GitHub Actions Role to Assume (from step 1)
    CERTIFICATE_ARN - ARN to ACM certificate for CloudFront Distribution
    HOSTED_ZONE_ID - Route53 Hosted Zone ID
    HOSTED_ZONE_NAME - Route53 Hosted Zone Name
    DLQ_NOTIFICATIONS - email address to send DLQ messages to
    CLOUDFRONT_DOMAIN_PROD - AWS CloudFront Distribution domain name
    COGNITO_USERPOOL_ID_PROD - Cognito User Pool Id
    COGNITO_WEB_CLIENT_ID_PROD - Cognito User Pool Client Id
    APPSYNC_ENDPOINT_PROD - AWS AppSync GraphQL endpoint URL
    

Testing

Jest

To be added

Cypress

To be added

Locally

Test the frontend using cypress

$ npm run cypress:open

or headless,

$ npm run cypress:run

GitHub Actions

Ensure to configure the GitHub Secrets to include:

```
CYPRESS_USERNAME - A valid Cognito username for Cypress integration testing
CYPRESS_PASSWORD - The Cognito password for Cypress integration testing
```

Troubleshooting

Lambda DLQ

To retry the Lambda function

  1. Get the message from the SQS DLQ
aws sqs receive-message --queue-url https://sqs.us-east-1.amazonaws.com/524849261220/pecuniary-dev-updatePosition-DLQ --profile bach-dev
  1. Save the DLQ message event to a json file
{
  "version": "0",
  "id": "26b8f7d1-b141-9baf-8a01-f625b7c3b0bc",
  "detail-type": "InvestmentTransactionSavedEvent",
  "source": "custom.pecuniary",
  "account": "524849261220",
  "time": "2024-12-31T20:29:49Z",
  "region": "us-east-1",
  "resources": [],
  "detail": {
      "accountId": "c8df14ba-0bf9-43dc-a92f-0185714336a7",
      "transactionDate": "2024-12-31",
      "type": "Buy",
      "symbol": "FNMA",
      "shares": 123.0,
      "price": 12.0,
      "commission": 12.0,
      "userId": "a4e824d8-2021-7008-6807-ec5d9400debb"
  }
}
  1. Run the CLI command to invoke lambda
aws lambda invoke --function-name pecuniary-dev-UpdatePosition --payload fileb://request.json response.json --profile bach-dev
  1. Run the CLI command to remove the message from the SQS DLQ
aws sqs delete-message --queue-url https://sqs.us-east-1.amazonaws.com/524849261220/pecuniary-dev-updatePosition-DLQ --receipt-handle <receipt-handle> --profile bach-dev

Event Sourcing and CQRS Architecture

For more detailed information about the event-driven nature of the Pecuniary application and it's architecture, please see the Architecture.md

Projects References

Links to additional documentation specific to the Application

AppSync

Resources

Various links to additional articles/tutorials used to build this application.

AppSync

Cognito

License

This project is licensed under the terms of the MIT license.