| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
 | <?php
namespace PHPIAC\Modules;
use PHPIAC\Module\Module;
use PHPIAC\Module\State;
use phpseclib3\Net\SSH2;
class UserModule extends Module
{
    /**
     * UserModule constructor.
     *
     * @param string $username
     * @param array $options
     * @param string $state
     */
    public function __construct(
        private string $username,
        private array $options = [],
        private string $state = State::PRESENT
    ) {
        $this->options = array_replace([
            'append' => false,
            'create_home' => true,
            'groups' => [],
            'shell' => '/bin/bash',
        ], $options);
    }
    /**
     * @inheritDoc
     */
    public function checkState(): bool
    {
        global $ssh;
        /**@var SSH2 $ssh*/
        $ssh->enablePTY();
        $ssh->exec("cat /etc/passwd | grep $this->username:");
        $hasUser = $ssh->read();
        $state = match ($this->state) {
            State::PRESENT => str_starts_with($hasUser, "$this->username:"),
            State::ABSENT => empty($hasUser),
        };
        $ssh->disablePTY();
        return $state;
    }
    /**
     * @inheritDoc
     */
    public function getCommands(): array
    {
        return match ($this->state) {
            State::PRESENT => [
                "sudo adduser $this->username --quiet" .
                    " --shell " . $this->options['shell'] .
                    ($this->options['create_home'] ? '' : ' --no-create-home'),
                "sudo usermod -" . ($this->options['append'] ? 'a' : '') . "G " . implode(',', $this->options['groups']) . " $this->username"
            ],
            State::ABSENT => [
                "sudo userdel $this->username",
            ],
        };
    }
}
 |