-
Notifications
You must be signed in to change notification settings - Fork 19
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
Fix 403 error when using moc compiler version > 0.6.2 #41
Conversation
…iler code to set a User-Agent header
Nice analysis, and the fix looks simple enough and straight forward. Looks good to me, thank you! |
Sorry to bother, need one more approval on this quick bug fix (two approvals required)! |
You need approvals from actual current committees of this repo. It seems not nice that @kritzcreek got his permissions revoked, could someone at dfinity fix that? (Unless Christoph doesn't want them back, of course) |
@nomeata Who should you or I tag to reissue permission. I agree it would be nice to have the original owner of this package manager have the ability to merge in new features. |
Thanks for your perseverance @ByronBecker! Did that do the trick? |
@crusso, it did - but looks like we're somehow failing CI now, which is odd to me considering where it's failing. If you don't mind - I'll take a look at it tomorrow and see if there's anything I can find (fix a hash or something like that) |
@crusso Actually, it looks like the current main fails these same checks. I'm wondering if we can just merge as is then, so I don't have to fix previous issues as well in this pull request except for the bug described above |
I don't have merge capabilities, so it would have to be someone currently working at Dfinity with those permissions |
CI issue fixed here #42 (thanks to handholding by @kritzcreek) |
Fix
TLDR: To fix 403 forbidden compiler release downloads for versions >
0.6.2
that hit GitHub releases, update thedownload_compiler
reqwest.get to set a User-Agent headerMotivation
I was running into issues where locally, I'm able to build my code and use moc version
0.6.20
, but my GitHub CI process runs into this forbidden error when trying to download the binary (note that I started with this template, and just update the compiler version https://github.com/kritzcreek/motoko-library-template).I don't run into this same error when using moc
0.6.2
and below, and I had tried every other version above it, but I run into the same forbidden error with0.6.11
and0.6.19
.I dug into this further and saw that every version up to
0.6.2
was released onhttps://download.dfinity.systems/motoko/{version}/{os_arch}/motoko-{version}.tar.gz
,but since then, from
0.6.3
up to0.6.21
has been released on GitHub via thehttps://github.com/dfinity/motoko/releases/download/{version}/motoko-{os}-{version}.tar.gz
.Since I'm able to both locally (via vessel) and manually download (through the releases page) release binaries
0.6.3
+ from the GitHub releases page, this means there's either a specific download permission setting setting that's blocking the GitHub CI role or the request vessel is making to download the specific moc compiler version was messing up.The code where the vessel package manager is attempting to download the binary can be found here.
For reference, this is the error I was receiving in the CI logs:
Where the
check-strict
command isAnd the ci yaml file looked like this
https://github.com/kritzcreek/motoko-library-template/blob/main/.github/workflows/ci.yml
Since I was receiving the "Failed to download" error mentioned on [this line], I started there and found an issue where if the
User-Agent
header is not specified, the GitHub API will throw this error. You can see on this line that this header is set - and the API does not complain.The Fix (and proof it works)
0.6.20
calledmotoko-color
can be found here. This package is based off of the motoko-library-template package written by @kritzcreek As you can see from the check mark next to the most recent commit, each of the CI are passing (which involve downloading the motoko compiler from GitHub as the version =0.6.20
, which is > 0.6.2, and both the ci.yml and [release.yml] are hitting my this commit of my vessel fork.