Skip to content

Conversation

@Plazmaz
Copy link
Contributor

When cloning a repo, GitPython will leak environment variables in error messages. For instance, this code:

import git repo = git.Repo('https://www.github.com/Plazmaz/${PATH}') repo.clone('testrepo/$PATH') 

will output something like:

Traceback (most recent call last): File "test.py", line 2, in <module> repo = repo.Repo('https://www.github.com/Plazmaz/${PATH}', unsafe=True) File "GitPython/git/repo/base.py", line 133, in __init__ raise NoSuchPathError(epath) git.exc.NoSuchPathError: <THE CONTENTS OF $PATH> 

This behavior has unwanted security implications. To counter this, I've added an unsafe variable, which will allow for environment variables to be expanded, otherwise, this behavior is disabled. By default, this variable is set to True. However, when used with environment variables, a warning is displayed. Hopefully, this will eventually be set to False by default. When running the same code, but with unsafe set to False, here's the output:

Traceback (most recent call last): File "test.py", line 2, in <module> repo = repo.Repo('https://www.github.com/Plazmaz/${PATH}', unsafe=False) File "GitPython/git/repo/base.py", line 133, in __init__ raise NoSuchPathError(epath) git.exc.NoSuchPathError: Documents/https:/www.github.com/Plazmaz/${PATH} 

Copy link
Contributor

@ankostisankostis left a comment

Choose a reason for hiding this comment

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

Isn't this change kind of intrusive?

  • Hooks expect certain variables to function, is this working with new default NOT to expand env-variables at all?
  • Or break BW-compatibility with existing clients?


def_expand_path(p):
returnosp.normpath(osp.abspath(osp.expandvars(osp.expanduser(p))))
def_expand_path(p, unsafe=True):
Copy link
Contributor

Choose a reason for hiding this comment

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

Better call it what it is, expand_vars, and explain the reason for using this flag in the invoking site.

And I would split it, not to have to compare lines to discover the difference:

p=osp.expanduser(p) ifexpand_vars: p=osp.expandvars(p) returnosp.normpath(osp.abspath(p))

GitCommandWrapperType=Git

def__init__(self, path=None, odbt=DefaultDBType, search_parent_directories=False):
def__init__(self, path=None, odbt=DefaultDBType, search_parent_directories=False, unsafe=True):
Copy link
Contributor

Choose a reason for hiding this comment

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

Wouldn't this default break existing clients expecting variable-expansion?
I guess hooks would suffer.

Copy link
ContributorAuthor

Choose a reason for hiding this comment

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

The default is True, meaning variables will be expanded by default. However, this behavior is bad, especially seeing as a standard practice is storing secrets and keys in environment variables. The reason for the flag is to give a bit of a grace period, and allow users to transition.

@codecov-io
Copy link

Codecov Report

Merging #662 into master will increase coverage by 1.8%.
The diff coverage is 92.85%.

Impacted file tree graph

@@ Coverage Diff @@## master #662 +/- ## ========================================= + Coverage 92.57% 94.37% +1.8%  ========================================= Files 61 61 Lines 9968 9976 +8 ========================================= + Hits 9228 9415 +187 + Misses 740 561 -179
Impacted FilesCoverage Δ
git/repo/base.py95.66% <92.85%> (+0.53%)⬆️
git/test/test_remote.py97.82% <0%> (ø)⬆️
git/refs/remote.py91.11% <0%> (ø)⬆️
git/compat.py63.19% <0%> (+0.22%)⬆️
git/refs/symbolic.py96.5% <0%> (+0.31%)⬆️
git/config.py92.76% <0%> (+0.32%)⬆️
git/test/test_submodule.py99.22% <0%> (+0.38%)⬆️
git/test/test_docs.py100% <0%> (+0.39%)⬆️
git/cmd.py85.54% <0%> (+0.47%)⬆️
... and 13 more

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update cf8dc25...67291f0. Read the comment docs.

@Plazmaz
Copy link
ContributorAuthor

Regarding compatibility, this is OFF by default for now. It will work with existing projects just fine.

@ByronByron merged commit 67291f0 into gitpython-developers:masterSep 28, 2017
@Byron
Copy link
Member

Thanks a lot for your contribution!
Without a new major release, this flag can't be OFF by default, and in maintenance mode, GitPython probably is not going to do that.

Sign up for freeto join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Development

Successfully merging this pull request may close these issues.

4 participants

@Plazmaz@codecov-io@Byron@ankostis