-
Notifications
You must be signed in to change notification settings - Fork 141
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
Community building #414
Comments
I see that e.g. @AiyionPrime contributed recently and has open merge requests. Maybe you would be a good candidate? Also @svanharmelen, you were contributing quite a bit. Just a shoutout trying to get people involved ;) |
Hi @HerrMuellerluedenscheid, thanks for the shoutout 👍🏻 I indeed have a (both personal and professional) interest and motivation in both using and contributing to this crate. So if @locka99 would be open to accept any help, I would be more then happy to step up and help out! I think that maybe in addition to myself, @einarmo would be a good candidate as an additional maintainer as he did the recent client rewrite (to make it fully async) and also has (still pending a PR) a rewritten version the server (to also make the server fully async). In addition we've been in good contact for any changes and bugs resulting from that recent client rewrite lately, discussing any additional changes and fixes. But I feel like we are somewhat jumping the gun here, as this is all really up to the discretion of @locka99! I have no idea how he is doing and what might be going on in his life, so let's be careful with opening issues like this (while asking the question on itself should be fine of course) and/or discussing or assuming things without having heard from @locka99 himself first... |
I've got a fork that I've been working on with a pretty enormous amount of changes, at this point I have touched pretty much every part of the code in one way or another. I'll eventually finish doing everything I want to with this library, at which point I would like to somehow share it. Not sharing it isn't really an option for me, considering the amount of work that has gone into it at this point... What @locka99 has done here is great, and without the foundation he and others built I would've never gotten as far as I have, but at this point I think it's clear that he doesn't want to be involved as deeply in this project as it will require if he is to be the sole maintainer for the only active OPC-UA project in Rust. I only see two real ways forward:
I really don't want to make this an ultimatum, like "make me maintainer or I fork", but I also feel like it's productive to lay the cards on the table. This project is going to keep getting contributions, I'm pretty sure, and it does have issues that needs resolving (I've found and fixed quite a few in my time working on my fork). If you don't want to give away the project, or share influence over it, (a sentiment I can understand...) then perhaps a coordinated fork would be for the best. |
Thanks for both your inputs! Awesome @einarmo that you brought the project forward a lot as it seems! Definately the more pragmatic and sustainable way and clearly my personal favorite:
@locka99 what do you think? Looking really much forward hearing your thoughts! I would love to see a bigger community revolving around this project which really gains traction and is a great replacement for all those overly complex and overprized c++ / c# closed source implementations out there ;) |
While I second @svanharmelen's suggestion to include @einarmo in a list of useful maintainers, I've got a bunch of improvements at our fork as well, of which I promised @locka99 to only open five at a time in order to keep the PR overhead at bay. Anyway, if @locka99 found a way to get this repos development moving again, I'd be quite happy about it as well. Just keep in mind: none of us has a clue how his priorities are at the moment, let alone why; I'd refrain from ultimatums or fork announcements, as they're imo not really the best grounds to have an open discussion about this projects furture and @locka99's visions for it. |
As I wrote earlier I used to maintain some OPC ua c++ stack and now maintain the opcua-asyncio stack using the freeopcua organisation. I can start by proposing a bad name opcua2 or rust-opcua. Anyone has a better idea? |
Also if anyone does not trust me they can just search my record in maintaining that organization. I have no other motivation than trying to keep projects alive and well functioning |
Now that was a fast reaction :) All I wanted to express above was my urgent wish that we all keep our heads down for a moment and do not rush to possible solutions, before we have not even heard @locka99's current stand on the matter. @oroulet I understand you only want to help here, but it's not that we're not capable of forking this, but do intend to avoid it if possible and work on a solution with the current maintainer and not against him. Thanks for your ongoing interest though, maybe we can just give @locka99 a few days to find time for an answer, before we escalate this further :) |
I am completely clear over that anyone is able to fork the project in an organisation. I was just proposing to do it inside an already existing org which has been working fine for a long time (not mine btw, I just happen to be the current main admin). |
another possibility is to work together with the guys from https://github.com/open62541/open62541 and btw the name open6241 can be a good crate name for an opcua fork since opcua is used. |
Wow! That sparked a discussion. Seems I hit a nerve :) Cool! I saw this discussion which indicates that you would rather not move that project, which I can relate to. (though integrating that into the FreeOpcUa group would probably boost visibility, community adoption and reputation of the project and as a consequence for yourself as well - winwin 🏆 ). But foremost as long as we can spread some workload I would be super happy @locka99 |
Just so I have written it. After having worked with different open source projects for 20 years I think organization is the only way to ensure perennity of a project. Anything else is too much depending on one person who almost always end up disappearing or half disappearing like happening here. |
has any of you created something to facilitate method creation btw? I just looked at the API now and it is quite heavy... Might be worth doing something |
still not ready for doing something @AiyionPrime @einarmo or others? |
I have this: https://github.com/einarmo/opcua/tree/rewrite-master, which is really far ahead of master at this point. If nothing happens here, once I have done everything I want to, I'll probably make the effort to detach the fork and make it official, then we can see about reconciling things later. |
OK I see you changes many things and also stuff I want @einarmo . do you accept MR? Can I send my MR there then? |
Feel free. I have changed pretty much everything, though, and I have my own vision for some of the core stuff. The reason I haven't gone ahead and released is that I would prefer not to split the community, and I don't feel like what I have is completely ready for public consumption yet. There's a certain level of polish and robustness that I don't feel confident I have yet. And I have done a ton of very breaking changes. I'd like to be sure I don't need any more huge breaking changes before I release. Your cancellation token PR is obsolete though, I think. There are ways to set a cancellation token when creating the server in my branch, and a bunch of stuff around cancellation, like logic to correctly shut down a server gracefully, and notifying clients with the |
I do not see publishing a fork as splitting the community. First there is no community here anyway and then there is no problem to merge back things if we want. Yes when I saw your commits I understood my changes were obsolete. Fine, I can have a look at your fork. |
I'd personally favor waiting for @locka99's response. For me there won't be going to much upstream changes until January, so waiting for an answer is not that much trouble anyway. But that's liek I said easy for me to say :) |
@einarmo I looked at your fork. looks very good to me. you splited things, added some more features, added support for async. I could not see much wrong with it. But it is too many changes for anyone to be able to review. It should never haven been done that way, small MR should have been proposed to the current maintainer and he should have reviewed and merged. it was not due to differnet things so now your work is indeed a fork... |
As I said, if nothing happens I'll get around to doing that eventually. There's a little work involved in properly detaching the fork, and I want to go over documentation for all my changes, finish up some of the stuff I've started, and maybe expand on the tests a bit. If I'm going to publish my own fork, then I want to to be high quality. |
Don't be so careful. If you publish you will get help from people to make things good quality. I got help on projects in crazy bad shape |
For the record, my fork is now published under https://github.com/FreeOpcUa/rust-opcua. There is still more work to be done to actually publish a new version to crates.io under a different name. |
Thanks, I'll head over and take a look... Glad to see that its still published under MPL as I was a bit worried about that since most other repo's in that org use LGPL 👍🏻 |
Noticed you already pulled in a few of my PR's (al least the most important ones), will check if the others still make sense and open new PR's for them if needed so I can try to migrate our code base and do a few tests to see if the changes between the current client code here and in the new fork are compatible with how we use the client (we only use the client bits for now). I'll continue our communication at the new repo... |
I'll provide my work at the new repo as well. |
great to see activities. @einarmo is the boss on that repository, but the idea is to add several people who want to help as part of the group. So if you want to contribute, we can invite you so you can help reviewing and merging things. |
Hi @locka99 ,
You've build a truely awesome library which is getting pretty popular given the number of stars and forks! At the same time I see that there is quite a number of open pull requests and I was wondering if you could need some help by the community to review, approve and possibly even merge pull requests. Are there already more reviewers then yourself on board for that? Would you be willing to share the workload? I think that the iteration of developments would benefit from that.
Also, I'm always a bit worried about software legacy. I've seen too many packages with single maintainers that for unknown reasons suddenly were not to be seen anymore leaving unmaintained packages in package managers (which is really a pitty but can also become quite dangerous if people continue relying on that). Yes, you can always branch, upload a crate
opcua-new
oropcua-2
to crates.io but that's never an elegant solution.What are your thoughts about that?
ps.: I know, nobody wants to talk about the real end, but you might also consider setting up a successor for your github account. I don't want to be gaslighting. It's just nice to have things in order :)
The text was updated successfully, but these errors were encountered: