-
Notifications
You must be signed in to change notification settings - Fork 32
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
Time for a new release? #119
Comments
@vit-zikmund good point and sorry for the slow reply. We definitely should do a new release. If you also have patches or contributions you would like to make PRs are welcome. @anuveyatsu can we push out a new release of this soon? |
@anuveyatsu @demenech tagging you here if we can get a new release out (and/or enable @athornton to push releases). |
hello @rufuspollock I do not have the necessary permissions. @anuveyatsu perhaps you could give me and @athornton higher privilege? |
The problem isn't on the GitHub side, it's on the uploading to PyPi side, if I remember correctly. Someone who's an admin on the PyPi Datopian account could add me and @vit-zikmund , or (I think) they could go through the process to link the GH repository with PyPi as a trusted publisher: https://docs.pypi.org/trusted-publishers/adding-a-publisher/ That's probably both easier and more secure since no one would have to grant additional PyPi privileges. Then we could just bake the PyPi upload into the Github Actions for doing a release. |
hello @athornton letting you know that I have been given the privilege, so I believe I can unblock this now, will try to do it between the end of my day today and tomorrow |
Oh this is sweet! Could I get to squeeze in one little, but rather important security improvement for the github auth? |
hello @athornton The trusted publisher has been added. Can you try it out, please? And is there anything else that I have to do? |
Thanks. I'll see what I can do with the CI and whether I can get it to push. |
Turns out 3.13 support is going to be a little harder than I expected, so I won't be adding that right now. I am adding We should think about what branches should build ghcr containers, too. Currently it's "tickets/*" and releases, which match what we do at Rubin, but the naming of ticket branches is a very specific-to-Rubin convention. If there's something else you prefer we can easily change that. One thing I think you could do, @demenech , is give @vit-zikmund whatever permissions on this repo I've got. He's been doing most of the most recent work. |
Would folks who aren't me, using Docker containers, please try out the image ghcr.io/datopian/giftless:tickets-DM-42598 and ensure it's working as expected? I am going to put it in my dev environment for the afternoon, and then try it in prod. Assuming it looks good, I'll merge it up to main and then cut a 0.6.0 release early next week. That release should trigger the PyPi upload, and hopefully everything works and then we can announce Version 0.6.0 for real. If not, well, there will be some fast follower releases until we DO get it pushing smoothly to PyPi. If Datopian wants to keep hosting at Docker Hub, we'll need to put a push token in the secrets for the repository or the organization and change the CI slightly. Myself, I feel like GitHub is likely to survive longer and in better shape than Docker-the-company and it's probably just appropriate for Datopian, when they announce the new release, to point out that the host for the docker containers has moved. |
Hi @athornton @vit-zikmund thank you for the effort into making the new release possible 🙏🏼 we just invited @vit-zikmund as maintainer of this repo 👍🏼 I don't think we have any constraints regarding the location of the container registry, so a GitHub-based option should work perfectly fine. |
Thank you, @anuveyatsu (and naturally @athornton for the nomination)! It's a big honor. |
The upload did not trigger. The only thing I see wrong is that my GHA environment name is set to EDIT belay that...I think I missed putting the release in the "on" section at the top of CI. |
hello @athornton I'm around if anything has to change in the trusted publisher. |
OK, getting closer:
|
ghcr.io/datopian/giftless:0.6.2 is now available, matching PyPi giftless 0.6.2. I'm going to have to add a setting to our build-and-push action to also tag with latest and push, and that may take a bit (or stop using composite actions and just tackle building and pushing separately, but likewise that will take a bit). In the interim, though, doing a new release will both push to pypi and ghcr.io. |
I'll also write up some docs about how to do a release through GHA, and then we probably should clean up the no-longer-used make targets, and additionally include "how to use scriv" which we've been using for changelog management. It plays nicely with GHA. But the good news is: there's a new Giftless at PyPi, and a corresponding container at ghcr.io. If someone from Datopian wants to upload ghcr.io/datopian/giftless:0.6.2 to docker.io and then tag both those as Datopian should figure out a messaging strategy around "stop using hub.docker.com / docker.io and start using ghcr.io" to tell the users, as well as whatever sort of statement they want to make about a newer giftless. After that it is, alas, almost time for another round of modernization...but it's smaller this time, and the thing I really wanted to do (Python 3.13 support) seems like it's gated behind grpc support, which is probably what's also holding gcloud back from being 3.13 ready, and I'd expect an eventual Google update that fixes all that at once, at which point Giftless is unblocked. |
hey @athornton This sounds great. I have access to Dockerhub. I think it makes sense to push the latest version, I'll do that. Regarding the deprecation of the docker hub repo, I'm thinking about tweaking the README and metadata at https://hub.docker.com/repository/docker/datopian/giftless and maybe echoing some sort of deprecation message at the latest version? Wdyt? |
I think that's a great idea. I should have an updated GitHub Action that will let us tag releases with "latest" as well pretty soon. That can go into the Giftless build that refactors the Makefile. |
hello @athornton Thanks, and sorry for the late reply. I'm working on adding the warnings, but I don't think I'll be able to finish it today. Hoping to have it done tomorrow. CC: @rufuspollock |
hello @athornton and @vit-zikmund Merry Christimas! When you are available, please take a look at #181 Thanks. CC: @rufuspollock |
@demenech amazing job 👏 |
Hello Datopian folks!
I just stumbled upon this great project and hit a blocker in the 0.5.0 release, that's already fixed.
I need to target a private AWS-like object storage, but the
endpoint
setting is missing from the docker image. This year evenboto3
got upgraded to read theAWS_ENDPOINT_URL
env var to override it, but the one included is too old.I see there's been a couple fixes here and there in the last two years from the 0.5.0 release. Would that make sense to carve out a new one? 🙂 I sure can build the stuff myself (thank you for that - making this nice tool opensource), but wanted to ask, before I start the plumbing process.
Thank you so much! 😉
The text was updated successfully, but these errors were encountered: