-
Notifications
You must be signed in to change notification settings - Fork 191
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
git: refactor authentication, checkout and verification #462
Conversation
f7d7c9a
to
e5a548f
Compare
e5a548f
to
bcf83cb
Compare
a3bff1c
to
d9a8004
Compare
d9a8004
to
1f962d3
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
if short := strings.SplitAfterN(c.Reference, "/", 3); len(short) == 3 { | ||
return fmt.Sprintf("%s/%s", short[2], c.Hash) | ||
} | ||
return fmt.Sprintf("HEAD/%s", c.Hash) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we need to document the revision format in docs/docs/spec/v1beta1/common.md
for each source type and give some examples for Git.
6b88b91
to
01aaba5
Compare
35fcb23
to
3290736
Compare
This commit moves the previous `AuthStrategy` wiring to a more generic `AuthOptions`, breaking free from implementation specific details in the `git` package. Signed-off-by: Hidde Beydals <[email protected]>
Signed-off-by: Hidde Beydals <[email protected]>
This commit refactors the previous `Commit` interface into a standardised `Commit` struct. This object contains sufficient information for referencing, observating and (PGP) verification. - `libgit2` commit checkout does now return `HEAD/<SHA1>` as the branch is not taken into account. - `git2go` objects are now properly `Free`d everywhere - `Verify` logic is tested. Signed-off-by: Hidde Beydals <[email protected]>
This commit changes the `gogit` behavior for commit checkouts, now allowing one to reference to just a commit while omitting any branch reference. Doing this creates an Artifact with a `HEAD/<commit>` revision. If both a `branch` and `commit` are defined, the commit is expected to exist within the branch. This results in a more efficient clone of just the target branch, and also makes this change backwards compatible. Fixes #407 Fixes #315 Signed-off-by: Hidde Beydals <[email protected]>
Main requirement for this is the image-automation-controller depending on being able to get a working auth configuration. Once the package is moved, we should add push logic to it, so that the controller is able to use that instead. Signed-off-by: Hidde Beydals <[email protected]>
Adds more test cases for Validate() and an error for unknown transport. Signed-off-by: Sunny <[email protected]>
Adds tests for git.CheckoutStrategy to check if both the git implementations work with all the authentication methods. Signed-off-by: Sunny <[email protected]>
As we properly nest errors. Signed-off-by: Hidde Beydals <[email protected]>
Signed-off-by: Hidde Beydals <[email protected]>
This changes the logic of `credentialsCallback` so that it takes the `allowedTypes` passed on by `git2go` into account. Reason for this change is because this prepares it to work with `v33`, but also because it can provide better guidance when `libgit2` has been compiled with a different configuration, which e.g. doesn't allow for "in-memory SSH keys". Because `AuthOptions#Identity` now gets validated by the callback and go-git does its own validaiton, the check has been removed from `Validate` (and now does a simple check if the fields are set). Signed-off-by: Hidde Beydals <[email protected]>
Adds tests for git.CheckoutStrategy to check if both the git implementations follow the same SemVer tag selection rules. Signed-off-by: Sunny <[email protected]>
For ssh, Host field is required in AuthOptions. Signed-off-by: Sunny <[email protected]>
New gittestserver fixes the issue with custom branch in an initialized repo. Signed-off-by: Sunny <[email protected]>
b7ac89c
to
0110664
Compare
Update GitRepositoryReconciler to use a nil authOpts unless it's configured. Signed-off-by: Sunny <[email protected]>
Signed-off-by: Hidde Beydals <[email protected]>
054bb19
to
d0ca107
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
💯
This PR refactors the
git
package, so that the interface and generics no longer depend on implementation specifics. Commit metadata, (PGP) commit verification, and authentication options have been standardized into various structs and methods.User-facing Changes
Commit reference without branch
In the previous iteration it was not possible to define a Git commit reference without defining a branch. This limitation has been removed. However, using a branch if the information is available is beneficial for the
go-git
Git implementation, as this allows for a shallow clone. Forlibgit2
, the branch is no longer taken into account.If just a Git commit reference is defined, the Artifact revision becomes
HEAD/<commit>
Fixes #407
Fixes #315