Skip to content

Latest commit

 

History

History
155 lines (110 loc) · 4.58 KB

README.md

File metadata and controls

155 lines (110 loc) · 4.58 KB

Pillarbox Event Dispatcher

Pillarbox logo

Pillarbox Event Dispatcher is a stateless Go microservice that receives JSON data via HTTP POST requests and broadcasts the received events using Server-Sent Events (SSE) to multiple consumers. This service facilitates real-time event streaming for clients, offering insights into system health and behavior.

Important

What this service doesn't do

  • It does not store events, even temporarily.
  • None of the data is critical, so there's no mechanism for resend events that haven't been received (if the data is being used to monitor products you consider critical, it's probably time to monitor those products instead).

Quick Guide

Prerequisites and Requirements

  • Go 1.23 or higher

Setup

  1. Run the Application:
    go run cmd/event_dispatcher/main.go

Available Endpoints

  • To send events via a POST request with a JSON payload, use the /api/events endpoint:

    curl -X POST http://localhost:8080/api/events \
         -H 'Content-Type: application/json' \
         -d "{\"msg\": \"data\", \"timestamp\": \"$EPOCHSECONDS\"}"
  • To listen to events using SSE, connect to the /events endpoint:

    curl -n http://localhost:8080/events
  • To check the health of the service, use the /health endpoint:

    curl http://localhost:8080/health

Running with Docker

Alternatively, you can build and run the application using Docker:

  1. Build the Docker Image:

    docker build -t pillarbox-event-dispatcher .
  2. Run the Docker Container:

    docker run -p 8080:8080 pillarbox-event-dispatcher

Build Process with Makefile

The project includes a Makefile to simplify building across multiple platforms. To see all available commands, run:

make help

The binaries are output to the dist directory, and the build supports multiple platforms such as linux/amd64, linux/arm64, darwin/amd64, and darwin/arm64.

Documentation

This project is a Go microservice that accepts incoming JSON events via HTTP POST and broadcasts them to clients using SSE. It operates in a stateless manner, without persisting events.

The system is designed to support real-time streaming without data storage or recovery mechanisms.

System Flow Overview

The general flow of the service can be illustrated as follows:

sequenceDiagram
  participant Client
  participant EventDispatcher
  participant SSEConsumer
  SSEConsumer --) EventDispatcher: Connects and listens to events
  Client ->> EventDispatcher: Sends POST request with JSON data
  EventDispatcher ->> SSEConsumer: Broadcasts JSON event via SSE
Loading

Continuous Integration

This project automates its own development workflow using GitHub Actions:

  1. Quality Check for Pull Requests Triggered on every pull request to the main branch, this workflow ensures the code passes static analysis and unit tests. It guarantees that any new code meets quality standards before being merged into the main branch.

  2. Release Workflow When changes are pushed to main, this workflow handles versioning and releases with semantic-release. It automatically bumps the version, generates release notes, creates a tag, and publishes a Docker image to Amazon ECR. This new version is automatically deployed to the development environment.

  3. Production deployment To deploy a specific version to production, manually trigger the Promote Version to Stable workflow from the Actions tab, inputting the desired version number (e.g., 1.0.0). This workflow tags the selected version as stable in the ECR, and forces a new deployment on ECS.

Contributing

Contributions are welcome! Please follow the project’s code style and linting rules when contributing. Here are some commands to help you get started:

Check your code style by running:

gofmt -l .

Apply the code style:

go fmt ./...

Test for common issues by running:

go vet ./...

All commits must follow the Conventional Commits format to ensure compatibility with our automated release system. A pre-commit hook is available to validate commit messages.

You can set up hook to automate these checks before commiting and pushing your changes, to do so update the Git hooks path:

git config core.hooksPath .githooks

Refer to our Contribution Guide for more detailed information.

License

This project is licensed under the MIT License.