# Copyright (c) 2025 Kim Jarvis TPF Software Services S.A. kim.jarvis@tpfsystems.com # This software is licensed under the MIT License. See the LICENSE file for details.#
[docs]classUseradd:""" A class to encapsulate the functionality of adding a user in Unix-like operating systems. It allows creating a new user account with specified password and privilege options. Attributes: user (str): The username to be created. sudo (bool): If `True`, the user will be created with `sudo` privileges. su (bool): If `True`, the user will be created with `su` privileges. **Examples:** .. code:: python yield Useradd(user="john",name="John Smith") Usage: This class is designed to be used in a generator-based workflow where user creation commands are yielded for execution on remote hosts. Notes: - Privilege escalation (sudo/su) is handled based on the respective flags. """def__init__(self,user:str=None,name:str=None,sudo:bool=False,su:bool=False):self.user=userself.name=nameself.sudo=sudoself.su=sudef__repr__(self):return(f"Add_user("f"name={self.name!r}, "f"user={self.user!r}, "f"sudo={self.sudo!r}, "f"su={self.su!r})")defexecute(self):fromreemote.operations.server.shellimportShellyieldShell(f"useradd -m -s /bin/bash -c '{self.name}' {self.user}",sudo=self.sudo,su=self.su)