A collection of dockerized server-side applications using the Rocketweb Rust Framework to connect CivicActions Gov accessibility scans to the A11yWatch API.
The application is built using Rust's package manager cargo and it can be built and run using Docker. The provided Dockerfile creates a container that includes all of the dependencies, source code, and the built binary of the application. When the container is run, it starts the application and it would be able to connect to the BigQuery using the environment variable GOOGLE_CLOUD_KEY.
The documentation can be found in the docs folder.
We are deploying (another un-related project) the A11yWatch API to perform accessibility scans on websites.
We want to streamline the process of sending requests to that API by utilizing an intermediary solution which
- Sends requests to the A11y API when requests are sent to this program
- Waits for the A11y API/other system to reply
- Apply out custom schema(s) to the reply data
- Record the result in Google BigQuery
- Respond to the requestor as needed
Think of this as a pass-through API. We make calls to it and it forwards those to external services. Those external services respons, it re-maps the data, and handles accordingly.
The API/docs I've started are below, but here is an explination of what we are looking for specifically.
Variables for Docker Container
| Variable | Description | Example |
| -----------------------------: | :---------------------------------------------------------: | :-------------------------------------------------------------------------------------: | --- |
| A11Y_URL | URL of A11yWatch API | https://api.a11ywatch.com/api/
|
| GOOGLE_APPLICATION_CREDENTIALS | JSON Google Key | Google Docs |
| GOOGLE_SERVICE_ACCOUNT | Account Name | someThing@someNamespace.iam.gserviceaccount.com
|
| GOOGLE_PROJECT_ID | project id for google big query |
| port_container | Port exposed by this application | 8080 |
| port_host | Port Docker maps to the Container Port | 80 |
| API_KEY | API key needed to access application. See Main.rs for notes | CGPk5x72BIwcaWVV7RWs
|
| A11Y_JWT | JWT needed to access A11Y_URL
| | ` |
| status_webhook | A webhook to send status updates | https://webhook.com |
User sends POST request to
We ❤️ 🐳
Deploy with Docker
Prerequisites:
-
Set Github Repo Secret:
YOUR_GOOGLE_CLOUD_KEY
with permsbigquery.datasets.get
bigquery.tables.get
bigquery.tables.update
Run The Container
docker run -e GOOGLE_CLOUD_KEY=<YOUR_GOOGLE_CLOUD_KEY> -p 8080:8080 <image-name>
Docker Compose For those of you who prefer compose, here you go...
version: '3'
services:
Rusty-A11y:
build: .
environment:
- GOOGLE_CLOUD_KEY=${GOOGLE_CLOUD_KEY}
ports:
- "8080:8080"
Intro Text
auth: x-token: ${{ secrets.token }}
(required) - The auth token to authenticate the request.
- Check Status
/up
This endpoint is used to check the reachability of websites. It sends a GET request to each domain and returns a JSON object containing a list of "DomainCheckResult" structs, which include the domain name and whether the site_error is true or false.
curl --request POST \
--url http://localhost:8080/up \
--header 'auth: x-token: ${{ secrets.token }}'
-
Crawl Website
/crawl
-
Scan Website
/crawl
-
Inspect Website
/inspect
- Health Check
/health
A way to check the health of the project and its dependencies, to ensure that everything is running as expected.
curl --request GET \
--url http://localhost:8080/health \
If it returns a status code between 200 and 399, the probe is considered successful. If the container returns a status code between 400 and 599, the probe is considered failed.
-
Ready Check | Liveness Probe
/ready
Used to determine if it is ready to receive traffic and responsive. If the liveness probe fails, Kubernetes will restart the container. If the readiness probe fails, Kubernetes will stop sending trafficcurl --request GET \ --url http://localhost:8080/ready \
If it returns a status code between 200 and 399, the probe is considered successful. If the container returns a status code between 400 and 599, the probe is considered failed.