Skip to content

Latest commit

 

History

History
134 lines (83 loc) · 5.35 KB

README.md

File metadata and controls

134 lines (83 loc) · 5.35 KB

Turbo Upload Service

Turbo is a robust, data bundling service that packages ANS-104 "data items" for reliable delivery to Arweave. It is architected to run at scale in AWS, but can be run in smaller scale, Docker-enabled environments via integrations with LocalStack. Additionally, local-development-oriented use cases are supported via integrations with ArLocal.

Turbo is powered by two primary services:

  • Upload Service: accepts incoming data uploads in single request or multipart fashion.
  • Fulfillment Service: facilitates asynchronous back-end operations for reliable data delivery to Arweave

They are composed atop a common set of service dependencies including but not limited to:

  • a PostgreSQL database (containerized locally or running on RDS in AWS)
  • an object store (S3)
  • a collection of durable job queues (SQS) that facilitate various workloads relevant to Arweave ecosystem integrations

Data items accepted by the service can be signed with Arweave, Ethereum, or Solana private keys.

Setting up the development environment

System Package Installation

For a compatible development environment, we require the following packages installed on the system:

  • nvm
  • yarn
  • husky
  • docker
  • aws
  • localstack (optional)

Quick Start: Run all services in Docker

  • Set an escaped, JSON string representation of an Arweave JWK to the ARWEAVE_WALLET environment variable (necessary for bundle signing) in .env.localstack
  • Run docker compose --env-file ./.env.localstack up upload-service

Once all of its dependencies are healthy, the Upload Service will start on port 3000. Visit its /api-docs endpoint for more information on supported HTTP routes.

NOTE: Database and queue state persistence across service runs are the responsibility of the operator.

Running the Upload Service locally

With a compatible system, follow these steps to start the Upload Service on its own on your local system:

  • cp .env.sample .env (and update values)
  • yarn
  • yarn build
  • yarn db:up && yarn db:migrate:latest
  • yarn start

Developers can alternatively use yarn start:watch to run the app in development mode with hot reloading provided by nodemon

Database

Scripts

  • yarn db:up: Starts a local docker PostgreSQL container on port 5432
  • yarn db:down: Tears down local docker PostgreSQL container and deletes the db volume
  • yarn db:migrate:list - lists all the migrations applied to the database
  • yarn db:migrate:up MIGRATION_NAME: Runs a specific migration on a local PostgreSQL database
  • yarn db:migrate:latest: Runs migrations on a local PostgreSQL database
  • yarn db:migrate:new MIGRATION_NAME: Generates a new migration file
  • yarn dotenv -e .env.dev ...: run any of the above commands against a specific environment file

Migrations

Knex is used to create and run migrations. To make a migration follow these steps:

  1. Add migration function and logic to schema.ts

  2. Run the yarn command to stage the migration, which generates a new migration script in migrations/ directory

    • yarn db:migrate:new MIGRATION_NAME (e.g. yarn db:migrate:new add_id_to_table)
  3. Construct the migration queries in src/db/arch/migrator.ts

  4. Update the generated migration file to call the proper migration script.

  5. Run the migration:

    • yarn db:migration:latest or yarn knex migration:up MIGRATION_NAME.TS
  6. Alternatively, run the migration against a specific environment file:

    • yarn dotenv -e .env.dev yarn db:migrate:latest

Rollbacks

You can rollback knex migrations using the following command:

  • yarn db:migrate:rollback - rolls back the most recent migration
  • yarn db:migrate:rollback --all - rolls back all migrations
  • yarn db:migrate:down MIGRATION_NAME - rolls back a specific migration

Additional knex documentation can be found here.

Docker

Building Image

To build the container:

docker build --build-arg NODE_VERSION=$(cat .nvmrc |cut -c2-8) --build-arg NODE_VERSION_SHORT=$(cat .nvmrc |cut -c2-3) .

Docker Compose

Runs this service, against the most recent version of payment-service and arlocal, and local postgres instances.

docker compose up -d

Run just the upload service against migrated local postgres instance.

docker compose up upload-service --build

Tests

Unit and integration tests can be run locally or via docker. For either, you can set environment variables for the service via a .env file:

  • yarn test:local - runs unit and integration tests locally against postgres and arlocal docker containers

Unit Tests

  • yarn test:unit - runs unit tests locally

Integration Tests

  • yarn test:docker - runs integration tests (and unit tests) in an isolated docker container (RECOMMENDED)
  • yarn test:integration:local - runs the integration tests locally against postgres and arlocal docker containers
  • yarn test:integration:local -g "Router" - runs targeted integration tests against postgres and arlocal docker containers
    • watch -n 30 'yarn test:integration:local -g "Router' - runs targeted integration tests on an interval (helpful when actively writing tests)