summaryrefslogtreecommitdiffstats
path: root/lib/sunhpc/commands/create/security/users/__init__.py
blob: e5cddfaa21e3568beb689724d02da156f122de58 (plain) (blame)
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
#coding:utf-8

import os
import sys
import stat
import time
import base64
import sunhpc
from sunhpc.core.utils import SafeError
class Command(sunhpc.commands.create.security.command):
    """
    Update all user-related files (e.g., /etc/passwd, /etc/shadow, etc.)
    on all known hosts. Also, restart autofs on all known hosts.

    <arg type='string' name='safedir'>
    Provide a path to encrypt, default: /etc/safe.d
    </arg>

    <params type='string' name='safedir'>
    Provide a encrypt file output path, default: /etc/safe.d
    </params>

    <example cmd='create security users'>
    Encrypt sunhpc os all base data.
    </example>
    """
    def run(self, parms, args):
        (self.safedir, salt, quiet) = self.fillParams([
            ('safedir', '/etc/safe.d'),
            ('salt', None),
            ('quiet', 'yes')])

        quiet = self.str2bool(quiet)
        if not os.path.exists(self.safedir):
            os.makedirs(self.safedir)

        userdirs = ['/etc/passwd', '/etc/shadow', '/etc/group']
        services = ['/etc/auto.master', '/etc/auto.home', '/etc/auto.share']
        for i in userdirs + services:
            self.makeEncrypt(i, quiet=quiet)

RollName = "base"