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

feat: use git config to read tsa server and include-certs #64

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

bufferoverflow
Copy link

@bufferoverflow bufferoverflow commented Apr 21, 2020

Read configuration parameters timestamp-authority and include-certs from .gitconfig as discussed within #47

@bufferoverflow
Copy link
Author

@mastahyeti WDYT? It adds an additional dependency but people can get rid of wrappers.

@ptoomey3
Copy link
Member

@mastahyeti no longer actively works on this project. I can take a look at this later this week.

@bufferoverflow bufferoverflow marked this pull request as ready for review May 1, 2020 12:38
Copy link
Member

@ptoomey3 ptoomey3 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Initial set of comments/questions/etc. Also, thoughts on the extra needed to get something wired up to be able to test any of this?

@@ -72,6 +73,26 @@ func runCommand() error {
return nil
}

// read tsa and include-certs from gitconfig
path, err := os.Getwd()
if err == nil {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a reason we want to "fail open" here and not return if an error is returned?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

read tsa and include-cert should be optional, so just use the defaults if these are not defined within git config

path, err := os.Getwd()
if err == nil {
repo, err := git.OpenRepository(path)
if err == nil {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same question about failing open. The idiom used throughout is err != nil and returning an error. Is the idea here that we may not be in a repo and hence shouldn't fail? I'm not sure if the libgit2 bindings have helpers for this..but if we determine we aren't in a repo and/or there is no .gitconfig for that repo, wouldn't the most idiomatic thing be to check the user global and then system .gitconfig instead?

if err == nil {
config, err := repo.Config()

tsa, err := config.LookupString("gpg.x509.smimesign.timestamp-authority")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What do we get from LookupString if the config value isn't set? Do we get an empty string (i.e. we match the default value)?

}

includeCerts32, err := config.LookupInt32("gpg.x509.smimesign.include-certs")
if err == nil {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same question here..if no such setting is set..do we get 0 here?

## Standalone usage

```sh
$ smimesign --help
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

❤️

@lgarron lgarron changed the base branch from master to main August 12, 2020 00:57
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

Successfully merging this pull request may close these issues.

4 participants