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

can not clone gopkg.in repo #129

Open
driusan opened this issue Sep 13, 2018 · 11 comments
Open

can not clone gopkg.in repo #129

driusan opened this issue Sep 13, 2018 · 11 comments

Comments

@driusan
Copy link
Owner

driusan commented Sep 13, 2018

If you run go get -u gopkg.in/russross/blackfriday.v2 in fails to negotiate the pack file when doing the git clone with dgit. If you add debugging prints to dgit, it does get past the ref discovery, but then stops. If you run dgit clone https://www.github.com/russross/blackfriday (the url that gopkg is proxying to), it's fine. The v2 branch also checks out successfully when you clone in that way.

It's weird and needs investigation.

@driusan
Copy link
Owner Author

driusan commented Sep 13, 2018

Discovered at sirnewton01/ghfs#28

@driusan
Copy link
Owner Author

driusan commented Oct 14, 2018

It seems that gopkg.in transparently adds ".git" to the ref discovery request, but not the following upload-pack request (I'm not entirely sure why it works with the official git client..), which confuses dgit because it expects to derive the canonical url from ref discovery

driusan added a commit to driusan/gopkg that referenced this issue Oct 14, 2018
The refsSuffix used for reference discovery appends ".git" to the repo name, while the upload pack proxying does not. This can result in a 422 response from GitHub instead of a packfile when trying to clone gopkg.in repos (ie driusan/dgit#129), making gopkg.in URLs uncloneable with some third party git clients.

I'm not sure why GitHub doesn't have this issue when cloning with the official git client, but using the same base git url for both /info/refs and /git-upload-pack appears to fix the issue for dgit while not causing any noticeable regressions with real git when I tested this change locally.
@sirnewton01
Copy link
Collaborator

After logging more information on this here is the HTTP response in question:

Unexpected status code for response: got 422 body: <!DOCTYPE html>
<html>
  <head>
    <meta http-equiv="Content-type" content="text/html; charset=utf-8">
    <meta http-equiv="Content-Security-Policy" content="default-src 'none'; base-uri 'self'; connect-src 'self'; form-action 'self'; img-src 'self' data:; script-src 'self'; style-src 'unsafe-inline'">
    <meta content="origin" name="referrer">
    <title>Oh no &middot; GitHub</title>
    <style type="text/css" media="screen">
      body {
        background-color: #f1f1f1;
        margin: 0;
        font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
      }

      .container { margin: 50px auto 40px auto; width: 600px; text-align: center; }

      a { color: #4183c4; text-decoration: none; }
      a:hover { text-decoration: underline; }

      h1 { letter-spacing: -1px; line-height: 60px; font-size: 60px; font-weight: 100; margin: 0px; text-shadow: 0 1px 0 #fff; }
      p { color: rgba(0, 0, 0, 0.5); margin: 20px 0 40px; }

      ul { list-style: none; margin: 25px 0; padding: 0; }
      li { display: table-cell; font-weight: bold; width: 1%; }

      .logo { display: inline-block; margin-top: 35px; }
      .logo-img-2x { display: none; }
      @media
      only screen and (-webkit-min-device-pixel-ratio: 2),
      only screen and (   min--moz-device-pixel-ratio: 2),
      only screen and (     -o-min-device-pixel-ratio: 2/1),
      only screen and (        min-device-pixel-ratio: 2),
      only screen and (                min-resolution: 192dpi),
      only screen and (                min-resolution: 2dppx) {
        .logo-img-1x { display: none; }
        .logo-img-2x { display: inline-block; }
      }

      #suggestions {
        margin-top: 35px;
        color: #ccc;
      }
      #suggestions a {
        color: #666666;
        font-weight: 200;
        font-size: 14px;
        margin: 0 10px;
      }

    </style>
  </head>
  <body>

    <div class="container">

      <h1>What&#8253;</h1>
      <p>Your browser did something unexpected. Please contact us if the problem persists.</p>
      <div id="suggestions">
        <a href="https://github.com/contact">Contact Support</a> &mdash;
        <a href="https://githubstatus.com">GitHub Status</a> &mdash;
        <a href="https://twitter.com/githubstatus">@githubstatus</a>
      </div>

      <a href="/" class="logo logo-img-1x">
        <img width="32" height="32" title="" alt="" src="">
      </a>

      <a href="/" class="logo logo-img-2x">
        <img width="32" height="32" title="" alt="" src="">
      </a>
    </div>
  </body>
</html>

@sirnewton01
Copy link
Collaborator

sirnewton01 commented Feb 28, 2019

Definition of HTTP response code 422: "The request was well-formed but was unable to be followed due to semantic errors."

It looks like the proxy server didn't like something about the request.

Actually, the message seems to be coming back from GitHub itself. So, the proxy is altering the request in a way that GitHub doesn't like and spits out that response. I'm thinking that gopkg.in has some kind of bug or is intolerant of slightly different git implementations.

@driusan
Copy link
Owner Author

driusan commented Feb 28, 2019

It is a bug in their proxy, I even sent a bug fix (niemeyer/gopkg#64), but from what I can tell it's not maintained.. I'm not really sure how it works with the official git client. We might need to add a ".git" suffix to the requests in certain situations where the repo URL doesn't already end in one, but we also need to figure out which situations it's required, and make sure we don't do it in cases that will break other repos.

@sirnewton01
Copy link
Collaborator

Hmm, now I'm getting an error cloning that repo directly from GitHub while working on #149

@sirnewton01
Copy link
Collaborator

Nm, It was just the check to switch to protocol v2.

@sirnewton01
Copy link
Collaborator

My understanding is that this service was provided to work around the lack of go get versioning. I suspect that the service will be going away slowly now that there are modules with semantic versioning provided directly in the "go get" command.

@sirnewton01
Copy link
Collaborator

As soon as we get the modules working with dgit I will probably move ghfs away from using the gpkg.in service. Maybe we should just close this?

@sirnewton01
Copy link
Collaborator

I'm thinking that we should close this now. Go has settled on modules for versioning dependencies.

@driusan
Copy link
Owner Author

driusan commented Mar 7, 2019

I think we should keep it open, I look at it as a type of git repo that isn't working and there's still code in the wild that depends on it

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants