On 12/01, Jeff King wrote: > On Thu, Dec 01, 2016 at 10:14:15AM -0800, Brandon Williams wrote: > > > > 1. The new policy config lets you say "only allow this protocol when > > > the user specifies it". But when http.c calls is_transport_allowed(), > > > the latter has no idea that we are asking it about potential > > > redirects (which obviously do _not_ come from the user), and would > > > erroneously allow them. > > > > > > I think this needs fixed before the topic is merged. It's not a > > > regression, as it only comes into play if you use the new policy > > > config. But it is a minor security hole in the new feature. > > > > I agree and it should be an easy fix. We can just add a parameter like > > so: > > > > diff --git a/transport.c b/transport.c > > index 2c0ec76..d38d50f 100644 > > --- a/transport.c > > +++ b/transport.c > > @@ -723,7 +723,7 @@ static enum protocol_allow_config get_protocol_config(const char *type) > > return PROTOCOL_ALLOW_USER_ONLY; > > } > > > > -int is_transport_allowed(const char *type) > > +int is_transport_allowed(const char *type, int redirect) > > { > > const struct string_list *whitelist = protocol_whitelist(); > > if (whitelist) > > @@ -735,7 +735,7 @@ int is_transport_allowed(const char *type) > > case PROTOCOL_ALLOW_NEVER: > > return 0; > > case PROTOCOL_ALLOW_USER_ONLY: > > - return git_env_bool("GIT_PROTOCOL_FROM_USER", 1); > > + return git_env_bool("GIT_PROTOCOL_FROM_USER", !redirect); > > } > > > > die("BUG: invalid protocol_allow_config type"); > > > > That way the libcurl code can say it is asking if it is ok to redirect > > to that protocol. > > I wouldn't expect anyone to ever set GIT_PROTOCOL_FROM_USER=1, but it > does behave in a funny way here, overriding the "redirect" flag. I think > we'd want something more like: > > if (redirect < 0) > redirect = git_env_bool("GIT_PROTOCOL_FROM_USER", 1); > > and then pass in "-1" from transport_check_allowed(). I don't think I quite follow your solution but I came up with this: case PROTOCOL_ALLOW_USER_ONLY: return redirect ? 0 : git_env_bool("GIT_PROTOCOL_FROM_USER", 1); Which should address the same issue. -- Brandon Williams