Skip to content

Linux adduser/useradd as a library for your Nim project.

License

Notifications You must be signed in to change notification settings

theAkito/nim-useradd

Repository files navigation

Nimble

Source Language

Last Commit

GitHub Liberapay patrons

What

This is an extended adduser/useradd Nim library with batteries included.

It takes care of password encryption, file locking during user modification and so on.

You don't have to take care of anything. Just add or remove your user and that's it. No effort on your part needed!

Why

Low-level user management without a CLI tool in Linux (and UNIX in general) is a pain. You have to know a lot of stuff. You can very easily break one of the most important parts of the system, if you do one little mistake like fail to hash the password correctly.

Using the native C API to manage users is a huge pain in the way described above. This module intends to take that effort and all those headaches away from you by entirely taking care of the C API bloat.

How

First, install this library.

nimble install useradd

Make sure, you are linking your project during compilation with the crypt(3) library.

nim c --passL="-lcrypt" example

Usage Examples

Add User

Simplest Example:

import useradd

echo "Success: " & $addUser(
  name = "mygenericusername",
  uid = 99121, # No GID provided -> GID will be same as UID.
  home = "/home/testuserapi",
  pw = "myInsecurePassword"
)

A bit more advanced example:

import useradd

echo "Success: " & $addUser(
  name = "mygenericusername",
  uid = 99121,
  gid = 99322,
  home = "/home/testuserapi",
  pw = "myInsecurePassword"
)

An advanced example, with a pre-hashed password:

import useradd

echo "Success: " & $addUser(
  name = "mygenericusername",
  uid = 99121,
  gid = 99322,
  home = "/home/testuserapi",
  pw = "$6$FCIBNRCTLwRrEErx$coMD2oCFWgtH7SzwNQnXo8D3ngexpLVpLkiYmw70zh7/Vc8xIOrpXEMDqgw.890JW2C/IJmIu6tsX/6hC/qBB.",
  pwIsEncrypted = true
)

This is useful for migrating passwords from a Shadow database, where the actual passwords are unknown.

An advanced example, where the file operations are done manually, omitting the C API, in case the C API imposes any arbitrary limitations:

import useradd

echo "Success: " & $addUserMan( # Only the `proc` name changed. The API stays exactly the same!
  name = "mygenericusername",
  uid = 290111,
  gid = 290112,
  home = "/home/testuserapi",
  pw = "$6$FCIBNRCTLwRrEErx$coMD2oCFWgtH7SzwNQnXo8D3ngexpLVpLkiYmw70zh7/Vc8xIOrpXEMDqgw.890JW2C/IJmIu6tsX/6hC/qBB.",
  pwIsEncrypted = true
)

Remove User

import useradd

echo "Success Delete User: " & $deleteUser("mygenericusername") # Deletes from `/etc/passwd`, `/etc/shadow` and `/etc/group` by name!

Live Examples

nimble example_simple
nimble example_custom_salt

Notes on Encryption

If for whatever reason, you do not like the encryption method employed, because the salt uses the, at this time, yet unaudited std/sysrand module, to generate a salt, then you are free to encrypt with your own salt.

import useradd, useradd/crypt

const
  password = "hello"
  salt = "$6$mycustomslt$"
    # Salt itself, i.e. `mycustomslt`, must be 16 characters long.
    # The `6` means, we want a SHA-512 hash (best hash possible, at the time of writing).

echo encrypt(password) # Uses this module's way of generating the salt.

echo encrypt(password, salt) # You provide you own salt according to crypt(3)s specification: $5$salt$

echo "Success: " & $addUser( # Add user with your own self-encrypted password.
  name = "mygenericusername",
  uid = 99121,
  gid = 99322,
  home = "/home/testuserapi",
  pw = $encrypt(password, salt),
  pwIsEncrypted = true
)

See the crypt(3) manual for more information on how to properly create the salt.

Hints

  • root permissions are needed, as we are modifying system files.

Features

  • Automatic File Locking -> Do not worry about corrupting /etc/passwd, /etc/shadow or /etc/group!
  • Automatic Password Encryption -> Do not worry about properly hashing the password, if providing one!
  • Convenient API -> For example, providing a UID but no GID, will assign the UID's value to the GID. It won't break your user creation!
  • Optional Advanced API -> Migrating an existing /etc/shadow database? No, problem, just provide the password hashes and turn on pwIsEncrypted!
  • Optional Advanced API -> Want to omit the C API and modify the databases directly, by reading/writing to the actual files? Just replace your addUser usages with addUserMan (same API)!

Where

Linux.

Other UNIX derivatives might work, but are not officially supported. This project is primarily supposed to work on Linux.

If you want to provide reliable macOS or *BSD support, go ahead I will check it out. But I only will accept it, if it does not reduce the quality of the Linux related implementation. (Hint: using whens is probably the way to go.)

Goals

  • Reliability
  • Convenience

Project Status

Stable Beta.

This library is well tested & works, but needs more testing and feedback from 3rd parties. --> Please help!

TODO

  • Publish on Nimble.
  • Provide runnable Examples
  • Track Project Tests with this Git repository.

License

Copyright © 2022 Akito [email protected]

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/.

About

Linux adduser/useradd as a library for your Nim project.

Resources

License

Stars

Watchers

Forks

Languages