-
Notifications
You must be signed in to change notification settings - Fork 475
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
What is the disputes procedure for packages? #25367
Comments
The registry doesn't "care" itself who the maintainer is. If you are referring to moving the repository (rename or change the GitHub owner), you can make the transfer and open a PR to change the registry entry to look for the source in the new place. Usually having the original owner comment on the PR acknowledging it is enough for the registry maintainers to approve / merge it. |
What is the situation for the cases where the repository is unmaintained and the original authors do not respond? NPM gives them a few weeks of time, and if there was no answer, it moves the repository to the new authors. |
We can handle this on a case by case basis. Has this ever actually happened in the Julia ecosystem? In my experience, we are usually able to get ahold of the owner of the relevant GitHub repo. The owner then transfers to the GitHub repo to a GitHub organization that has multiple members. Once the transfer is done, we update the URL of the GitHub repo in the relevant So this all seems very theoretical to me. If someone has a specific case that they want to discuss, that might be more helpful. |
Ultimately all decisions about the General registry are made by the maintainers of the General registry. This is documented in the README. That being said, the maintainers always welcome comments from the entire Julia community, whether on GitHub, Discourse, or Slack. |
@DilumAluthge I believe this has happened with EzXML.jl. See this issue. EzXML is a nice package, but it needs a few updates and it appears to be unmaintained. And the package owner has not responded to an email from @aminya. Of course, if worse comes to worst, we can fork the package and register it as a new package. |
Okay, it helps to have a concrete example. |
So, should I just make a PR and change the link of the repo? For EzXML, I should probably make a fork in one of the big open organizations such as JuliaData or JuliaWeb, and then change the link to that fork. |
I've started a discussion in Slack (in the |
@aminya I pinged you on Slack. @CameronBieganek I tried to ping you but I could not figure out your Slack username. You can join the |
I actually don't use Slack, yet... 😬 😂 |
In case it's useful to have one example of a package whose registration now points to a fork, see #3906 . The package https://github.com/AndyGreenwell/GroupSlices.jl had no commits after May 2017 (more than 2 years before), and various PRs to fix it for Julia 0.6 & 0.7 went unanswered. The owner was not active on github at all, and several attempts to contact him (someone had his email) went unanswered. |
Copying my comment from Slack for posterity:
|
Any volunteers to do number 5? |
May I bring your attention to #32416? The original author is not completely missed since he accepted PR a few weeks ago, but he is not responding on email or Github mentions. I am not in a hurry, but I am already waiting for three weeks and I have to use ugly things like embedding code in my repo (https://github.com/Arkoniak/ZulipReminderBot.jl/blob/master/src/dotenv.jl), because otherwise I have issues with CI. By the nature of my work I would like to use dotenv approach in the future, so it would be really great to resolve this situation one way or another:
I am agreed to any resolution, just I do not want this question to hang indefinitely (well, to be honest, if it is not solved, I'll just go with third option, since I need this package). |
Reexport is also such an example, @ararslan is given the write permission but he's not able to set up CI related settings. It would be more convenient if this package gets forked in an organization with proper CI set up. Of course, given that Reexport is a very small and stable package, this issue is not very urgent for Reexport.
I think we also need a fork announcement in the original repo with valid justification. For example, why you fork this repo, will you be the right person to maintain the fork, what's your plan on the future of this fork, and the license. (I just saw a very well-written announcement on fork saitoha/libsixel#154 and I feel it is a good reference.) If the fork is too breaking or even malicious, the entire ecosystem will be affected by redirecting the URL in General without approval from the original author. Personally, I don't want to see a random person, who never has direct communication with the author via PR/issue discussions, fork the package; I'd rather that package die without any further maintenance. |
It can happen. GitHub has procedures for the death of a repository owner, but those only apply in the case of an actual death, not an unexplained disappearance, as has happened at libsixel, thus my overdue fork and self-designation as lead maintainer de facto. |
This is the only remaining task that needs to be done:
If someone wants to take on this task, please:
Please ping me in both the PR and the Discourse post. |
The last bit — updating the documentation — is very important. I think until it's done, this issue should remain opened. |
The general registry of Julia is a centralized registry similar to NPM. NPM has a disputes procedure for the cases where there is an unmaintained package, and new maintainers want to continue developing it.
https://docs.npmjs.com/cli/v6/using-npm/disputes
In other words: NPM allows the new maintainers to email the old owners of the package and ask them to give them write access. If the authors agree, or they do not respond, NPM itself moves the package to the new owners.
Given the fact that General.jl is similar to npm, there should be a similar mechanism for handling such cases.
The text was updated successfully, but these errors were encountered: