cmd
This commit is contained in:
parent
8e50cb2e15
commit
1e7458a1eb
1 changed files with 168 additions and 0 deletions
168
pidd/cmd.py
Normal file
168
pidd/cmd.py
Normal file
|
@ -0,0 +1,168 @@
|
||||||
|
"""Python Integration, Delivery & Deployment."""
|
||||||
|
|
||||||
|
__version__ = "0.0.1"
|
||||||
|
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
|
import env
|
||||||
|
from rwx import fs, ps
|
||||||
|
from rwx.log import stream as log
|
||||||
|
|
||||||
|
import pidd
|
||||||
|
from pidd.project import Project
|
||||||
|
from pidd.projects import Projects
|
||||||
|
|
||||||
|
COMMANDS_PREFIX = "pidd-"
|
||||||
|
|
||||||
|
projects = Projects()
|
||||||
|
project = Project(projects)
|
||||||
|
|
||||||
|
|
||||||
|
def pidd_browse_workspace() -> None:
|
||||||
|
browse(project.root)
|
||||||
|
|
||||||
|
|
||||||
|
def pidd_build_project() -> None:
|
||||||
|
for extension in ["py", "sh"]:
|
||||||
|
path = Path(project.root) / f"build.{extension}"
|
||||||
|
if path.exists():
|
||||||
|
ps.run(path)
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
def pidd_clone_branch() -> None:
|
||||||
|
log.info(projects)
|
||||||
|
split()
|
||||||
|
log.info(project)
|
||||||
|
split()
|
||||||
|
log.info(f"""\
|
||||||
|
{project.url}
|
||||||
|
↓
|
||||||
|
""")
|
||||||
|
ps.run(
|
||||||
|
"git",
|
||||||
|
"clone",
|
||||||
|
"--branch",
|
||||||
|
project.branch,
|
||||||
|
"--",
|
||||||
|
project.url,
|
||||||
|
project.root,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def pidd_list_environment() -> None:
|
||||||
|
for variable, value in sorted(projects.environment.items()):
|
||||||
|
log.info(f"{variable} = {value}")
|
||||||
|
|
||||||
|
|
||||||
|
def pidd_synchronize() -> None:
|
||||||
|
host = "rwx.work"
|
||||||
|
source = "out"
|
||||||
|
user = "cd"
|
||||||
|
#
|
||||||
|
root = Path(os.sep) / user / project.branch / projects.group / project.name
|
||||||
|
#
|
||||||
|
target = f"{user}@{host}:{root}"
|
||||||
|
ps.run(
|
||||||
|
"rsync",
|
||||||
|
"--archive",
|
||||||
|
"--delete-before",
|
||||||
|
"--verbose",
|
||||||
|
f"{source}/",
|
||||||
|
f"{target}/",
|
||||||
|
"--dry-run",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def browse(root: str) -> None:
|
||||||
|
paths = []
|
||||||
|
for directory, _, files in os.walk(root):
|
||||||
|
for file in files:
|
||||||
|
absolute_path = Path(directory) / file
|
||||||
|
relative_path = os.path.relpath(absolute_path, start=root)
|
||||||
|
paths.append(relative_path)
|
||||||
|
frame(root)
|
||||||
|
for path in sorted(paths):
|
||||||
|
log.info(path)
|
||||||
|
shut(root)
|
||||||
|
|
||||||
|
|
||||||
|
def cat(file: str) -> None:
|
||||||
|
frame(file)
|
||||||
|
log.info(fs.read_file_text(file).rstrip())
|
||||||
|
shut(file)
|
||||||
|
|
||||||
|
|
||||||
|
def install_commands(path: str) -> None:
|
||||||
|
step("Install commands")
|
||||||
|
user = Path("/usr/local/bin")
|
||||||
|
for command in [
|
||||||
|
"browse-workspace",
|
||||||
|
"build-project",
|
||||||
|
"clone-branch",
|
||||||
|
"list-environment",
|
||||||
|
"synchronize",
|
||||||
|
]:
|
||||||
|
log.info(command)
|
||||||
|
(user / f"{COMMANDS_PREFIX}{command}").symlink_to(path)
|
||||||
|
|
||||||
|
|
||||||
|
def main(main: str) -> None:
|
||||||
|
path, *arguments = sys.argv
|
||||||
|
name = Path(path).name
|
||||||
|
if name == "__main__.py":
|
||||||
|
pidd.set_ssh(*arguments)
|
||||||
|
pidd.install_commands(main)
|
||||||
|
else:
|
||||||
|
function = getattr(pidd, name.replace("-", "_"))
|
||||||
|
function(*arguments)
|
||||||
|
|
||||||
|
|
||||||
|
def set_ssh(*arguments: list[str]) -> None:
|
||||||
|
step("Set SSH")
|
||||||
|
#
|
||||||
|
ssh_key, ssh_hosts = arguments
|
||||||
|
#
|
||||||
|
ssh_type = "ed25519"
|
||||||
|
#
|
||||||
|
home = Path("~").expanduser()
|
||||||
|
#
|
||||||
|
ssh = home / ".ssh"
|
||||||
|
ssh.mkdir(exist_ok=True, parents=True)
|
||||||
|
ssh.chmod(0o700)
|
||||||
|
#
|
||||||
|
key = ssh / f"id_{ssh_type}"
|
||||||
|
if ssh_key:
|
||||||
|
fs.write(key, ssh_key)
|
||||||
|
key.chmod(0o400)
|
||||||
|
#
|
||||||
|
known = ssh / "known_hosts"
|
||||||
|
if ssh_hosts:
|
||||||
|
fs.write(known, ssh_hosts)
|
||||||
|
known.chmod(0o400)
|
||||||
|
#
|
||||||
|
browse(ssh)
|
||||||
|
cat(known)
|
||||||
|
|
||||||
|
|
||||||
|
def frame(text: str) -> None:
|
||||||
|
log.info(f"{env.PIDD_OPEN}{text}")
|
||||||
|
|
||||||
|
|
||||||
|
def shut(text: str) -> None:
|
||||||
|
log.info(f"{env.PIDD_SHUT}{text}")
|
||||||
|
|
||||||
|
|
||||||
|
def split() -> None:
|
||||||
|
log.info(env.PIDD_SPLT)
|
||||||
|
|
||||||
|
|
||||||
|
def step(text: str) -> None:
|
||||||
|
env.PIDD_STEP += 1
|
||||||
|
log.info(env.PIDD_DOWN)
|
||||||
|
log.info(f"{env.PIDD_VERT} {env.PIDD_STEP} {text}")
|
||||||
|
log.info(env.PIDD___UP)
|
Loading…
Reference in a new issue