-
Notifications
You must be signed in to change notification settings - Fork 51
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
Support DSSE-style enveloped signatures #628
Comments
xref sigstore/fulcio#1131 for original motivating context. |
Starting on this now -- we'll need it for uploading and retrieving build provenance attestations for Homebrew. |
Thinking about this some more, I think the "right" way to do this is similar to what
|
Will this be based on this work? (Apologies if I should have know that already, the change is spread out across a number of places) |
I haven't had a chance to look at that recently, so I'm not sure 🙂. I'll try and take another look this afternoon/evening. As a roundabout way of answering: the Sigstore clients are generally producing/consuming Sigstore bundles as their top level "unit of work," so signing is likely to continue doing that. For verification, we'll want to support a Sigstore bundle containing a DSSE-formatted signature, but we may also support the inverse form (DSSE containing a Sigstore bundle). (But all of that is entirely up in the air -- first I need to actually get the data models working, followed by adding client-side support for Rekor's DSSE type, etc.) |
I've created https://github.com/trailofbits/sigstore-rekor-types to supply auto-generated models for Rekor's types. |
Could you expand on this and the use case in general -- I assume you want to create attestations over the same content but with different predicate data? I assume we want to implement this inside sigstore-python since rekor supports in-toto attestations, correct? How does this work in the verifying side (e.g. how does the predicate content get verified)? Do you expect this to be done by some intoto verification system? I think cosign has something builtin ( Am I correct that this is more accurately "Support intoto attestation signing" than DSSE -- in-toto just happens to use DSSE? Non-intoto use cases don't make sense here, right? |
I don't have a dog in the race but it feels like embedding DSSE within the bundle and making bundles embeddable in DSSE sound like competing proposals in practice (from an interoperability perspective at the very least). Has this been discussed anywhere? |
Yep, exactly -- I originally opened sigstore#fulcio#1131 because I didn't really understand which "layer" those predicates (I think of them as additional "relying party" metadata) should appear at. My understanding is that Rekor supports in-toto attestations in two forms: there are
Yeah, something like that is what I was thinking. This connects to my larger conceptual concerns around DSSE/in-toto, i.e. that there's an unsolved "policy" layer that end users will need to graple with. (This is part of why I'm only exposing this at the API level for now -- I think a user-friendly CLI for this is going to require a larger design effort/more thinking.)
I think it's accurate to say DSSE here, since the work (at least in #804) will produce and verify (That being said, I'm low confidence on the terminology here.)
It also feels that way to me. I don't think it's been discussed anywhere directly, other than a (brief) discussion to confirm that doing this isn't a priori incompatible with either format. I think it'd be really nice to have just one format here -- having the two be mutually nestable means more conditions/error states for implementing clients. |
Signing is now in, via #804. I'll work on verification next. |
For verification, I'm realizing that |
I'm interested in this feature! I've tested the signing part of the API already. Any idea about the timeline for verification? |
FWIW that matches 100% how we ended up using the API in securesystemslib SigstoreSigner: VerificationMaterials and SigningResult are not used in any way except as intermediate steps to/from Bundle. |
I'll have sometime today and next week to look at it, but no hard promises 🙂 The main complexity here is removing |
Thanks. No urgent rush, just want to have a rough idea. So in ~1 month it should be landed |
Yeah, I'll have a draft PR up well before that. |
Please tag me on the draft PR when you send it. Thank you! |
Will do! Sorry, this got popped off the stack; I'll try and slice some hours for it this coming week. |
Can you also tag me, please? Interested in this for signing ML models (https://github.com/google/model-transparency) |
Just merged #904, which gets the verification APIs into shape for DSSE sigs. I have one more churn/refactor change to work through before actually adding DSSE verification support, but once that's done it should be pretty straightforward. |
After some discussion in the clients channel, I've come to the conclusion that my original design here (fitting DSSE into the current Rather than introduce user confusion by trying to mash the two together, I'm going to separate the DSSE counterparts into |
To round it out, here's what I'm thinking:
CC @jku @laurentsimon @mihaimaruseac for any opinions 🙂 |
General idea makes sense to me: I was also wondering how the verification API can stay consistent -- since it likely can't, the sign APIs can/should be separated as well. On your question: if adding alternatives to intoto statements is going to mean an API change in practice anyway (for verification you can hide the API change behind |
LGTM as well to have separate APIs.
I'm interested in being able to use DSSE with non-intoto statements, e.g. for model manifest signing sigstore/model-transparency#111 (intoto does not fit the use case very well). @mihaimaruseac wdut? This may also allow us to sign other AI types like dataset's croissant in DSSE, without the need to store signatures separately, which means the signature would travel along the content - the flip side is that it's a breaking change for existing users of these data types |
Good point. Given that @laurentsimon has a non-intoto use case, I think I'm going to borrow a technique from PyCA cryptography here and do the following:
|
I think this makes sense. Higher level API for most usecases and lower one for users that want more flexibility and know what they're doing. |
Is there a chance this feature may be landed for OSS@NA? By "landed", I mean a PR and a non-official dev release for testing purposes. We'd like to demo the mode signing work. This is not blocking, so if it's not possible no worries. |
Yes, but only if I can get someone's approving review on #937 and the subsequent PRs that'll need to be built on that 😅 -- I don't have the power to merge my own work, so I'll need someone else to having a relatively tight review cycle with me. |
SG. Let's see if @jku is up for the challenge :) |
sure, working on it. 937 seems good so far, it's just a big patch. |
Just to summarize/update here, here's the current stack:
|
@laurentsimon @mihaimaruseac: FYI: #962 contains the initial verify APIs for DSSE, and there's a sample script for you to try locally in the comments! |
#962 was the last piece of this, so closing! |
Thank you very much for all of this! This is great! |
Thank you so much! I think there's some limitations on what digest types are allowed in the subject. I'll check the merged PR and if still the case, I will create a tracking issue for it. Thanks again for landing this feature! |
Yeah, this wouldn't surprise me 🙂 -- I suspect that SHA2-512, etc. won't currently work. |
In our case we use a custom merkle tree hash. That's fine for the demo zo |
This is part of Sigstore bundle support: we currently only support "raw" signatures, while some users of Sigstore may chose to use enveloped DSSE-style signatures.
From protobuf-specs:
...where
payload
is the to-be-signed attestation statement.xref sigstore/fulcio#1131
Work tracker:
sigstore-rekor-types
(rekor: use sigstore_rekor_types for models #788)sigstore-rekor-types
to provide DSSE creation and retrieval support in our Rekor bindingssigstore
CLIThe text was updated successfully, but these errors were encountered: