"kiwi up", "kiwi down"
This commit is contained in:
parent
8f390bdfa2
commit
973468be6a
2 changed files with 98 additions and 0 deletions
60
kiwi_scp/commands/cmd_down.py
Normal file
60
kiwi_scp/commands/cmd_down.py
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
from typing import List
|
||||||
|
|
||||||
|
import click
|
||||||
|
|
||||||
|
from .cli import KiwiCommand, KiwiCommandType
|
||||||
|
from .decorators import kiwi_command
|
||||||
|
from ..executable import COMPOSE_EXE
|
||||||
|
from ..instance import Instance, Project
|
||||||
|
|
||||||
|
|
||||||
|
@click.option(
|
||||||
|
"-f/-F",
|
||||||
|
"--force/--no-force",
|
||||||
|
help=f"skip confirmation",
|
||||||
|
)
|
||||||
|
@kiwi_command(
|
||||||
|
cmd_type=KiwiCommandType.SERVICE,
|
||||||
|
short_help="Bring down kiwi services",
|
||||||
|
)
|
||||||
|
class DownCommand(KiwiCommand):
|
||||||
|
"""Bring down the whole instance, a project or service(s) inside a project"""
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def run_for_instance(cls, instance: Instance, force: bool = None) -> None:
|
||||||
|
if not force:
|
||||||
|
if not KiwiCommand.danger_confirm(
|
||||||
|
"This will bring down the entire instance.",
|
||||||
|
"",
|
||||||
|
"This may not be what you intended, because:",
|
||||||
|
" - Bringing down the instance stops ALL services in here",
|
||||||
|
):
|
||||||
|
return
|
||||||
|
|
||||||
|
super().run_for_instance(instance)
|
||||||
|
|
||||||
|
# TODO net-down
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def run_for_existing_project(cls, instance: Instance, project: Project, **kwargs) -> None:
|
||||||
|
COMPOSE_EXE.run(["down"], **project.process_kwargs)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def run_for_services(cls, instance: Instance, project: Project, service_names: List[str], **kwargs) -> None:
|
||||||
|
services = project.services.filter_existing(service_names)
|
||||||
|
existing_service_names = [
|
||||||
|
service.name
|
||||||
|
for service in services.content
|
||||||
|
]
|
||||||
|
all_service_names_exist = len(existing_service_names) == len(service_names)
|
||||||
|
|
||||||
|
if not existing_service_names and not all_service_names_exist:
|
||||||
|
if not click.confirm(
|
||||||
|
"Did not find any of those services. \n"
|
||||||
|
f"Bring down the entire project {project.name} instead?",
|
||||||
|
default=True
|
||||||
|
):
|
||||||
|
return
|
||||||
|
|
||||||
|
COMPOSE_EXE.run(["stop", *existing_service_names], **project.process_kwargs)
|
||||||
|
COMPOSE_EXE.run(["rm", "-f", *existing_service_names], **project.process_kwargs)
|
38
kiwi_scp/commands/cmd_up.py
Normal file
38
kiwi_scp/commands/cmd_up.py
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
from typing import List
|
||||||
|
|
||||||
|
import click
|
||||||
|
|
||||||
|
from .cli import KiwiCommand, KiwiCommandType
|
||||||
|
from .decorators import kiwi_command
|
||||||
|
from ..executable import COMPOSE_EXE
|
||||||
|
from ..instance import Instance, Project
|
||||||
|
|
||||||
|
|
||||||
|
@kiwi_command(
|
||||||
|
cmd_type=KiwiCommandType.SERVICE,
|
||||||
|
short_help="Bring up kiwi services",
|
||||||
|
)
|
||||||
|
class UpCommand(KiwiCommand):
|
||||||
|
"""Bring up the whole instance, a project or service(s) inside a project"""
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def run_for_services(cls, instance: Instance, project: Project, service_names: List[str], **kwargs) -> None:
|
||||||
|
# TODO conf-copy
|
||||||
|
# TODO net-up
|
||||||
|
|
||||||
|
services = project.services.filter_existing(service_names)
|
||||||
|
existing_service_names = [
|
||||||
|
service.name
|
||||||
|
for service in services.content
|
||||||
|
]
|
||||||
|
all_service_names_exist = len(existing_service_names) == len(service_names)
|
||||||
|
|
||||||
|
if not existing_service_names and not all_service_names_exist:
|
||||||
|
if not click.confirm(
|
||||||
|
"Did not find any of those services. \n"
|
||||||
|
f"Bring up the entire project {project.name} instead?",
|
||||||
|
default=True
|
||||||
|
):
|
||||||
|
return
|
||||||
|
|
||||||
|
COMPOSE_EXE.run(["up", "-d", *existing_service_names], **project.process_kwargs)
|
Loading…
Reference in a new issue