-
Notifications
You must be signed in to change notification settings - Fork 10
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
Rust rewrite of the dbus code #52
Comments
Sound interesting. But what will be the list of additional crates needed for it? What will be the required rust version? |
It requires Rust version 1.70, and the crates clap, serde, serde_json, tokio, uuid, and zbus. The advantage is that it dramatically decreases the installation dependencies. You're left with a single, less than 4MB, standalone binary:
|
The primary reason I'm doing this is because the enterprise distros (RHEL/Rocky and SLE) don't have the Python dependencies required for the current linux-entra-sso. |
And I thought you are switching the programming language for its own properties, not its packaging model... Vendoring dependencies into a package may only shift maintenance responsibilities into the latter, in the worst case multiplying them this way - the "modern" development model. Anyway, we cannot fix that here. What we should keep an eye on is whether those crates are already common enough for recent distros so that we only get duplication of binary code, not of maintenance. And that looks ok to me from a quick check of current Debian. 1.70 is a bit too fresh there, though. And the zbus crate 5.2.0 is as well. We likely don't want to maintain two versions of the same logic, just because some distros are too old to handle the rust variant yet. What would be your proposal to avoid that? |
Debian uses a dirt-old rust toolchain. I always just install it using rustup. Debian isn't really a great standard as far as tool chain versions. Their packages are all far older than the enterprise distros, simply for lack of maintainers, I assume. And actually a customer originally requested I rewrite this in Rust because of it's memory safety, but then I also ran into the packaging issue. Also, what does the version of the zbus crate have to do with the distro? Do you realize the distros don't package Rust crate versions (as far as I know)? The crates come from crates.io. |
Debian does package zbus, like all the other deps you mentioned. If you are facing a distro that gave up on managing the Rust ecosystem "classically" and just let each package vendor around, see above. I'm not against going to Rust. We just only to time that step properly. As Rust is still maturing in several ecosystem regards, it may be too early, though. |
I wasn't aware that Debian had distro packages for rust crates. Interesting. |
Please don't, as it will make using this a gigantic pain. I have uploaded the plugin to Debian/Ubuntu, just waiting for review then it will be available for all via apt install: https://ftp-master.debian.org/new/linux-entra-sso_1.2.0-1.html |
@bluca No worries, we (me and @jan-kiszka as maintainers) will stick to the Python implementation as reference implementation and also try our best to maintain compatibility with commonly used Python versions. I'm a Debian maintainer by myself and share the Rust ecosystem pain. @dmulder maintains a rewrite of the native part of the extension as part of the himmelblau project - which is compatible with the browser part. But this is independent work. |
As @fmoessbauer said, I'll just maintain my rust version separately. I was just gauging the interest here. Thanks! |
Having multiple implementations sounds like a good idea, as long as they are alternatives there's no harm |
This is just an FYI, I'm working on porting the dbus code for this plugin to Rust here: himmelblau-idm/himmelblau#335
Would you guys be interested in having this in your codebase? I can submit an MR if so.
The text was updated successfully, but these errors were encountered: