-
Notifications
You must be signed in to change notification settings - Fork 2
/
fabfile.py
68 lines (55 loc) · 2.02 KB
/
fabfile.py
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
#
# Copyright 2015 Red Hat, Inc.
#
# 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 2 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, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
#
# Refer to the README and COPYING files for full details of the license
#
import os
import virtdeploy
from fabric.api import cd
from fabric.api import env
from fabric.api import run
from fabric.api import settings
from fabric.api import task
from fabric.contrib.files import append
from projects import kube
from projects import manageiq
from projects import openshift
from projects import ovirt
@task(name='vm-hosts')
def vm_hosts(*hosts):
"""
specify the instance names instead of hosts
"""
driver = virtdeploy.get_driver('libvirt')
env.hosts.extend((driver.instance_address(x)[0] for x in hosts))
def _read_key_file(key_file='~/.ssh/id_rsa.pub'):
with open(os.path.expanduser(key_file)) as f:
return f.read()
@task(name='init-host')
def host_init():
"""
configure the access to the host
"""
user = env.user
with settings(user='root', no_keys=True):
run('getent passwd {0} > /dev/null || useradd {0}'.format(user))
with cd('~{0}'.format(user)):
run('mkdir -p -m 700 .ssh')
append('.ssh/authorized_keys', _read_key_file())
run('chown -R {0}:{0} .ssh'.format(user))
append('/etc/sudoers', '{0} ALL=(ALL) NOPASSWD: ALL'.format(user))
append('/etc/sudoers', 'Defaults:{0} !requiretty'.format(user))