Skip to content
This repository has been archived by the owner on Aug 30, 2021. It is now read-only.

Latest commit

 

History

History
51 lines (39 loc) · 1.76 KB

README.md

File metadata and controls

51 lines (39 loc) · 1.76 KB

airtable-export

This API exporter is deprecated following the introduction of Vial.

Access

  • Github committer team: site-data-committers
  • Discord channels:
    • #data-publishing
    • #operations (infrastructure and production)
  • Google Cloud access managers: @Vallery, @Robert S, @Alex V
    • Logs
    • Monitoring
    • Deployments
    • Storage buckets (for serving the "API")
  • Airtable access
  • Honeycomb access: self-request
  • Pagerduty access managers: @Vallery

How This Works

airtable-export is a worker that periodically fetches data from Airtable, runs it through a sanitization pass (including but not limited to removing superfluous or sensitive keys), then uploads the results. The data is written in multiple formats to multiple places (e.g. https://api.vaccinateca.com/v1/ as well as the legacy https://storage.googleapis.com/cavaccineinventory-sitedata/airtable-sync/Locations.json). A staging and a production deploy exist, which write to different places.

monitoring is a black-box monitoring of the output of that, which is used to page on failures. One is deployed for each of prod and staging; they each monitor all of the URLs which that deploy writes to.

Layout

  • pipeline contains the main pipeline code.
  • monitoring contains directories containing monitoring related code
    • monitoring/freshcf is the freshness monitor and prober.

Linting

We use golangci's linter wrapper.

To run locally, run:

docker run --rm -v $(pwd):/app -w /app \
    golangci/golangci-lint:v1.35.2 golangci-lint run \
    -E golint,goimports,misspell