-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Trishank Karthik Kuppusamy <[email protected]>
- Loading branch information
1 parent
afba301
commit 04028e5
Showing
3 changed files
with
159 additions
and
56 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
package tuf | ||
|
||
import ( | ||
"fmt" | ||
"strings" | ||
|
||
"github.com/theupdateframework/notary/client" | ||
"github.com/theupdateframework/notary/tuf/data" | ||
"github.com/theupdateframework/notary/tuf/utils" | ||
) | ||
|
||
// delegationAdd creates a new delegation by adding a public key from a certificate to a specific role in a GUN | ||
// https://github.com/theupdateframework/notary/blob/f255ae779066dc28ae4aee196061e58bb38a2b49/cmd/notary/delegations.go | ||
func delegateToReleases(repo client.Repository, releasesKeyID string) error { | ||
role := data.RoleName("targets/releases") | ||
// How Notary v1 denotes "*"" | ||
// https://github.com/theupdateframework/notary/blob/f255ae779066dc28ae4aee196061e58bb38a2b49/cmd/notary/delegations.go#L367 | ||
allPaths := []string{""} | ||
|
||
pubKeys, err := ingestPublicKeys(args) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
// Add the delegation to the repository | ||
err = repo.AddDelegation(role, pubKeys, allPaths) | ||
if err != nil { | ||
return fmt.Errorf("failed to create delegation: %v", err) | ||
} | ||
|
||
// Make keyID slice for better CLI print | ||
pubKeyIDs := []string{} | ||
for _, pubKey := range pubKeys { | ||
pubKeyID, err := utils.CanonicalKeyID(pubKey) | ||
if err != nil { | ||
return err | ||
} | ||
pubKeyIDs = append(pubKeyIDs, pubKeyID) | ||
} | ||
|
||
fmt.Println("") | ||
addingItems := "" | ||
if len(pubKeyIDs) > 0 { | ||
addingItems = addingItems + fmt.Sprintf("with keys %s, ", pubKeyIDs) | ||
} | ||
if d.paths != nil || d.allPaths { | ||
addingItems = addingItems + fmt.Sprintf( | ||
"with paths [%s], ", | ||
strings.Join(prettyPaths(d.paths), "\n"), | ||
) | ||
} | ||
fmt.Printf( | ||
"Addition of delegation role %s %sto repository \"%s\" staged for next publish.\n", | ||
role, addingItems, gun) | ||
fmt.Println("") | ||
|
||
return maybeAutoPublish(cmd, d.autoPublish, gun, config, d.retriever) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters