• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

m-lab / token-exchange
70%
main: 70%

Build:
Build:
LAST BUILD BRANCH: dependabot/go_modules/gomod-minor-patch-b3a5c3cfa8
DEFAULT BRANCH: main
Repo Added 12 May 2025 08:35AM UTC
Files 7
Badge
Embed ▾
README BADGES
x

If you need to use a raster PNG badge, change the '.svg' to '.png' in the link

Markdown

Textile

RDoc

HTML

Rst

LAST BUILD ON BRANCH feat/client-integration
branch: feat/client-integration
CHANGE BRANCH
x
Reset
  • feat/client-integration
  • dependabot/github_actions/actions-3a1c37d3b7
  • dependabot/go_modules/gomod-minor-patch-b3a5c3cfa8
  • main
  • sandbox-roberto-client-auth
  • sandbox-roberto-dependabot
  • sandbox-roberto-gh-actions
  • sandbox-roberto-ns-name

07 Nov 2025 03:35PM UTC coverage: 69.504% (+19.1%) from 50.397%
19173233082

Pull #7

github

bassosimone
feat: implement client-integration token exchange

This diff implements token exchange for client integrations.

This is the general design we're implementing:

1. organizations maintaining client integrations (e.g., Acme Inc
embedding m-lab/ndt7-client-js to provide NDT to its users)
register with the system and obtain 1+ API keys

2. Acme Inc provisions a backend `B` that stores its API keys

3. backend `B` receives a query for Acme Inc clients when
they initiate running a NDT test

4. backend `B` queries m-lab/token-exchange to exchange one
of its API keys with a short-lived JWT

5. backend `B` returns the JWT to the client

6. the client queries m-lab/locate including the JWT

7. m-lab/locate uses the JWT to route the client to the proper
NDT server and/or to perform accounting and access control to
prevent a single integration from overloading the platform

8. the JWT is included into the URLs to access m-lab/ndt-server
where it is again used to perform access control

This diff only implements the token-exchange part of this design.

Client-integration keys use a hierarchical format that encodes both
the integration ID and key ID for O(1) datastore lookups:

```
mlabk.cii_<integrationID>.ki_<keyID>.<keySecret>
```

The hierarchical structure enables:

- O(1) lookup via parent-child datastore keys

- No duplication of IDs in entity fields

- Natural cascade deletion

Unlike autojoin tokens (which contain only `org`), client-integration
JWTs contain both integration ID and key ID:

```
{"int_id": "...", "key_id": "...", ...}
```

This allows downstream services (locate, ndt-server) to track which
specific API key was used for each test, enabling per-key metrics
and access control.

Key secrets are not stored in Datastore. We use SHA-256 hashing with
constant-time comparison to verify them against stored hashes. This
provides sufficient security given that API keys are high-entropy
machine-generated secrets, while avoiding the high CPU cost of
bcry... (continued)
Pull Request #7: feat: implement client-integration token exchange

224 of 303 new or added lines in 7 files covered. (73.93%)

294 of 423 relevant lines covered (69.5%)

0.78 hits per line

Relevant lines Covered
Build:
Build:
423 RELEVANT LINES 294 COVERED LINES
0.78 HITS PER LINE
Source Files on feat/client-integration
  • Tree
  • List 7
  • Changed 3
  • Source Changed 0
  • Coverage Changed 3
Coverage ∆ File Lines Relevant Covered Missed Hits/Line

Recent builds

Builds Branch Commit Type Ran Committer Via Coverage
19173233082 feat/client-integration feat: implement client-integration token exchange This diff implements token exchange for client integrations. This is the general design we're implementing: 1. organizations maintaining client integrations (e.g., Acme Inc embedding m-lab/ndt7-... Pull #7 07 Nov 2025 03:38PM UTC bassosimone github
69.5
18950421377 feat/client-integration feat: implement client-integration token exchange This diff implements token exchange for client integrations. This is the general design we're implementing: 1. organizations maintaining client integrations (e.g., Acme Inc embedding m-lab/ndt7-... Pull #7 30 Oct 2025 06:01PM UTC bassosimone github
67.4
18948236857 feat/client-integration feat: implement client-integration token exchange This diff implements token exchange for client integrations. This is the general design we're implementing: 1. organizations maintaining client integrations (e.g., Acme Inc embedding m-lab/ndt7-... Pull #7 30 Oct 2025 04:43PM UTC bassosimone github
65.73
See All Builds (15)
  • Repo on GitHub
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc