Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

possible blog post: Caching TUF metadata #2605

Open
jku opened this issue Apr 12, 2024 · 3 comments
Open

possible blog post: Caching TUF metadata #2605

jku opened this issue Apr 12, 2024 · 3 comments

Comments

@jku
Copy link
Member

jku commented Apr 12, 2024

I've spent far too long in the past week looking at CDN logs... I collected some notes from this, and wrote a first draft of a blog post or something. copy-pasting here so I don't lose it

TUF implementation details: Caching and content delivery networks

TUF metadata can be cached at various places during its lifetime, this post aims to describe the useful
methods of caching. The write-up assumes that the "consistent snapshot" feature of TUF is used:
this should be true for all reasonable implementations.

Client metadata cache

A TUF client stores downloaded metadata in an application cache as part of the
TUF Client Workflow. Note that caching metadata is subtly different from caching
artifacts: An artifact cache is a "pure" cache and can be purged at any time without
side-effects (other than possibly having to re-download). Purging the metadata cache
is also possible without service loss but does have minor security implications as
some rollback attack protection is lost.

Client HTTP cache

In addition to the actual metadata, a client could cache the ETag information
included in a timestamp.json response and use the If-None-Match header in
subsequent requests. This is not useful for other metadata or artifacts as they
should never change.

There is a minor information leak if this is done (as the server could now respond
maliciously to only some clients based on the content of the If-None-Match
header). Current client implementations are not known to cache ETag.

Content Delivery Network caching

One could imagine that caching something as simple as TUF metadata in a Content
Delivery Network (CDN) is a trivial feat but it turns out there are several pitfalls.

These are some of the lessons that have been learned while maintaining TUF repositories:

  • Uploading a new repository version to backend storage should be atomic (the metadata
    versions on the storage backend should always be consistent). If this is not technically possible,
    snapshot and all targets metadata should be uploaded before root and timestamp: this
    minimizes the window of potentially inconsistent metadata.
  • "Old" metadata (or artifact) versions should not be removed from backend storage immediately: this can break clients that are in the middle of an update process
  • CDN frontends should avoid serving any stale responses: TUF requires even 404 responses to
    not be stale, otherwise the repository state may be inconsistent.
  • CDN frontends may cache versioned metadata responses (root, snapshot, targets) with
    long lifetimes.
  • There are two valid alternatives to caching other responses:
    1. CDN frontend may use "negative cache" (caching failure codes) and may cache
      timestamp metadata responses, if it is able to invalidate the cache immediately on
      upload of new repository versions to storage backend.
    2. CDN frontend should not cache timestamp metadata responses or use "negative caching"
      if it is unable to invalidate the cache on upload of new data

At first glance it may seem like the above advice is overly cautious, and that failures
would be rare. In practice especially testing and alerting systems have managed to
consistently find failing combinations of mistakenly cached content.

@JustinCappos
Copy link
Member

JustinCappos commented Apr 15, 2024 via email

@jku
Copy link
Member Author

jku commented Apr 15, 2024

I'm curious why updating targets / targets metadata and then snapshot doesn't work?

Everything after timestamp does work in both the upload order and pretty much all of the caching details: the issue has practically always been with N.root.json and timestamp.json (since timestamp determines the snapshot+targets versions the actual failure may appear while loading other metadata of course).

What this means is that the issues only appear to real users during key changes in root (when user may end up with old root that contains old keys but also new other metadata signed with new keys; or vice versa). In testing and alerting systems the problems appear more easily (e.g. if the system expects specific metadata versions)

@lukpueh
Copy link
Member

lukpueh commented Apr 17, 2024

the issue has practically always been with N.root.json and timestamp.json

FYI:

There is a TUF spec issue about the race between root and timestamp: theupdateframework/specification#223

And there is a request to create deployment recommendations for these findings: theupdateframework/specification#91

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants