Crates.io | change-user-run |
lib.rs | change-user-run |
version | 0.1.1 |
created_at | 2025-08-08 14:12:26.405146+00 |
updated_at | 2025-08-19 10:49:58.304758+00 |
description | Run commands as other users and create users |
homepage | |
repository | https://gitlab.archlinux.org/dvzrv/change-user-run |
max_upload_size | |
id | 1786826 |
size | 123,528 |
A simple Rust library to aide with the creation of users and running commands as users on Linux systems.
If you have ever had the need to conveniently run commands as other users (e.g. in containerized tests), or to create new users on a Linux system, this is for you!
Refer to https://docs.rs/change_user_run/latest/change_user_run/ for released versions of the crate.
Create a set of users
use change_user_run::create_users;
# fn main() -> testresult::TestResult {
// Create a single user in the default location with the default shell.
create_users(&["testuser1", "testuser2"], None, None)?;
# Ok(())
# }
Run a command using a separate user
use change_user_run::run_command_as_user;
# fn main() -> testresult::TestResult {
// Run `whoami` as the user `testuser1`.
run_command_as_user("whoami", &[], None, &[], None, "testuser1");
# Ok(())
# }
Please refer to the contributing guidelines to learn how to contribute to this project.
Releases are created by the developers of this project.
[OpenPGP certificates] with the following [OpenPGP fingerprints] can be used to verify signed tags:
991F6E3F0765CF6295888586139B09DA5BF0D338
(David Runge <dvzrv@archlinux.org>)653909A2F0E37C106F5FAF546C8857E0D8E8F074
(Wiktor Kwapisiewicz <wiktor@archlinux.org>)Some of the above are part of archlinux-keyring and certified by at least three main signing keys of the distribution. All certificate are cross-signed and can be retrieved from OpenPGP keyservers.
This project can be used under the terms of the Apache-2.0 or MIT. Contributions to this project, unless noted otherwise, are automatically licensed under the terms of both of those licenses.