-
Notifications
You must be signed in to change notification settings - Fork 5
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
Prepare for Yotta Registry deprecation #6
Comments
@jaustin So a user would have to clone the target repository and run yotta link-target in that target repository? |
Did you mean "only required for private repos"? GitHub Auth goes via Yotta servers, and it trigger after reaching a number of fetches from the GitHub API without authenticating. So if the "login with GH" Yotta service goes away then people won't be able to continue fetching dependencies. On the other hand git@url should just work, as that is just a normal git clone. I guess yotta could be updated to fallback into git@urls when the GitHub API starts to rate-limit. Also, although less discoverable, and less "new developer friendly", it would also be useful if yotta could fetch a Github token from something like an environmental variable, this way a developer can generate one and continue using yotta with GitHub HTTPS URLs without issue. |
Only in option one, which I don't like much as option 2.
Whoops, I do. Edited. Thanks
I think that makes git@ superior here. Also clearer what the actual source is. The format I showed is a bit 'magic' I'd say then, preference is option 2 with git@URLs all the way down (up?) the dependency chain. This would still require breaking up this repo. |
Yes, also I think (I might be wrong, so take this with a pinch of salt) the It's probably safe to assume that current Yotta will be able to deal correctly with 400 or 500 errors from the Yotta registry when it disapears, but git@ should bypass all that anyway. |
git@ sounds good @jaustin! |
Thanks all. Yes, agree, git@... looks like the best option. |
How about: lancaster-university/yotta-target-bbc-microbit-classic-gcc |
Okay, a bit of testing here shows that if you've never configured ssh for Github access, using the git@ URLS means you have have to do that. Even for public repositories it fails for a user with a blank .ssh directory. I think we should use the API for now, for a much smoother experience. I have used |
Do you have a PR to test?
How many times were you able to git clone and build before requiring login? |
I've just been applying the following diff diff --git a/bbc-microbit-classic-gcc/target.json b/bbc-microbit-classic-gcc/target.json
index beb35e2..06680d0 100644
--- a/bbc-microbit-classic-gcc/target.json
+++ b/bbc-microbit-classic-gcc/target.json
@@ -9,8 +9,8 @@
}
],
"inherits": {
- "mbed-gcc": "0.1.3"
- },
+ "mbed-gcc": "git@github.com:microbit-foundation/target-mbed-gcc.git#v0.1.3"
+},
"keywords": [
"mbed-target:nrf51822",
"mbed-official", Then I'm using
I'll try next, but based on https://docs.github.com/en/free-pro-team@latest/github/using-git/which-remote-url-should-i-use#cloning-with-ssh-urls I think that confirms that they expect SSH URLs require a key pair. I don't know how it's working for you in places where you don't have keys? Perhaps SSH forwarding with SSH agent? If that's the case, what other options do you think we have? I've tried with HTTPS and that gets converted to API requests. |
As the yotta registry is deprecated (as per #6) we need to move away from using it. All of these targets have a dependency on the mbed-gcc target, which was being fetched by the registry (defined through 'inherits'). This patch changes the reference to explicitly use GitHub as the source for the dependency. This uses an HTTPS URL, which yotta will fetch with the GitHub API, while this can cause some issues with rate limiting, it also means a user doesn't need to setup SSH at all, which is required for git@ URLS
Okay @abchatra and @pelikhan I've just done the following
Done a clean build of microbit-samples. Where you would previously have done This built for me. |
In order to make life easy for users of these targets once the yotta registry goes away, we need to change the way people use them.
This requires at least two changes...
The most simple change is that that target 'inheritance' on mbed-gcc needs to move to a GitHub link - for example!
This works fine
Secondly, we need to change how people select the target.
Yotta supports (at least) two ways to specify targets without using the registry
yotta link-target
- this is really intended for local devyotta target targetname@location
where location can be GitHub (yt target mbed-gcc@ARMmbed/target-mbed-gcc#0.1.3
) or I believe a git@URL too which might be more resilient to GitHub auth going away (although, auth is only required forpublicprivate repos, I think?)I've just tested method one with the patch above and it builds fine, as far as I can tell without touching the registry, but once we've picked an option I'll kill the registry in my hosts file to check.
The former is more involved as it requires checking out more than just microbit-samples. The latter would require splitting up this repo.
I would prefer to split this repo. I'd consider also creating a standalone bbc-microibit-classic-gcc and bbc-microbit-classic-gcc-nosd as standalones and then renaming this to microbit-extra-targets and require yt link-target with these (removing the now-standalone targets and leaving pointers). FWIW I don't think the armcc one builds.
@jamesadevine @finneyj @carlosperate thoughts? Other projects that will need to change their build instructions are MicroPython and MakeCode. I think the minimal change for them is changing the string input to yt target
CC @mmoskal @thegecko @dpgeorge
The text was updated successfully, but these errors were encountered: