Skip to content
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

Closed
dmulder opened this issue Jan 3, 2025 · 11 comments
Closed

Rust rewrite of the dbus code #52

dmulder opened this issue Jan 3, 2025 · 11 comments

Comments

@dmulder
Copy link

dmulder commented Jan 3, 2025

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.

@jan-kiszka
Copy link
Collaborator

Sound interesting. But what will be the list of additional crates needed for it? What will be the required rust version?

@dmulder
Copy link
Author

dmulder commented Jan 7, 2025

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:

dmulder@dmulder-Standard-PC-i440FX-PIIX-1996:~$ file /usr/bin/linux-entra-sso
/usr/bin/linux-entra-sso: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=92ff4866266ba105b7c201f17b85fdc1c443967f, for GNU/Linux 3.2.0, stripped
dmulder@dmulder-Standard-PC-i440FX-PIIX-1996:~$ ldd /usr/bin/linux-entra-sso
	linux-vdso.so.1 (0x00007ffceb0d7000)
	libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x000070f980ca1000)
	libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x000070f980bb8000)
	libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x000070f980400000)
	/lib64/ld-linux-x86-64.so.2 (0x000070f980ce0000)
dmulder@dmulder-Standard-PC-i440FX-PIIX-1996:~$ ls -lah /usr/bin/linux-entra-sso
-rwxr-xr-x 1 root root 3.7M Jan  6 17:00 /usr/bin/linux-entra-sso

@dmulder
Copy link
Author

dmulder commented Jan 7, 2025

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.

@jan-kiszka
Copy link
Collaborator

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?

@dmulder
Copy link
Author

dmulder commented Jan 7, 2025

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.

@jan-kiszka
Copy link
Collaborator

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.

@dmulder
Copy link
Author

dmulder commented Jan 8, 2025

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 wasn't aware that Debian had distro packages for rust crates. Interesting.

@bluca
Copy link

bluca commented Jan 13, 2025

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
I will immediately abandon that effort if this switches to Rust, as its ecosystem is simply an unmantainable mess.

@fmoessbauer
Copy link
Member

fmoessbauer commented Jan 13, 2025

@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.

@dmulder dmulder closed this as completed Jan 13, 2025
@dmulder
Copy link
Author

dmulder commented Jan 13, 2025

As @fmoessbauer said, I'll just maintain my rust version separately. I was just gauging the interest here. Thanks!

@bluca
Copy link

bluca commented Jan 13, 2025

Having multiple implementations sounds like a good idea, as long as they are alternatives there's no harm

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants