summaryrefslogtreecommitdiff
path: root/src/UserModule.php
blob: fcab5a81b4fd0d1f0df4f37bbd4fbee2efc973f5 (plain)
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",
            ],
        };
    }
}