kiwi-scp/kiwi_scp/subcommands/_hidden.py

55 lines
1.5 KiB
Python
Raw Normal View History

2020-08-17 14:47:08 +00:00
# system
import logging
import subprocess
# local
from ..config import LoadedConfig
2021-09-22 01:06:43 +00:00
from ..executable import Executable
from ..subcommand import SubCommand
2020-08-17 14:47:08 +00:00
2020-08-20 12:15:38 +00:00
def _find_net(net_name):
ps = Executable('docker').run([
'network', 'ls', '--filter', f"name={net_name}", '--format', '{{.Name}}'
], stdout=subprocess.PIPE)
2020-08-18 15:49:49 +00:00
2020-08-20 12:15:38 +00:00
net_found = str(ps.stdout, 'utf-8').strip()
2020-08-18 15:49:49 +00:00
2020-08-20 12:15:38 +00:00
return net_found == net_name
2020-08-18 15:49:49 +00:00
2020-08-20 12:15:38 +00:00
class NetUpCommand(SubCommand):
"""kiwi net-up"""
2020-08-18 15:49:49 +00:00
2020-08-20 12:15:38 +00:00
def __init__(self):
super().__init__(
'net-up',
action="Creating the local network hub for", add_parser=False,
description="Create the local network hub for this instance"
)
2020-08-18 15:49:49 +00:00
2020-08-20 12:15:38 +00:00
def _run_instance(self, runner, args):
config = LoadedConfig.get()
net_name = config['network:name']
net_cidr = config['network:cidr']
if _find_net(net_name):
logging.info(f"Network '{net_name}' already exists")
return True
try:
Executable('docker').run([
'network', 'create',
'--driver', 'bridge',
'--internal',
'--subnet', net_cidr,
net_name
], check=True, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
logging.info(f"Network '{net_name}' created")
except subprocess.CalledProcessError:
logging.error(f"Error creating network '{net_name}'")
return False
2020-08-18 15:49:49 +00:00
2020-08-20 12:15:38 +00:00
return True