import os, io, sys, platform, psutil, json, secrets, string, docker from typing import Any, Callable, Dict, List, Optional, Sequence, Tuple, Type, Union import urllib.request class SmoothUrl: ''' Get the best smooth url for Git or Download''' def __init__(self): pass def res(self, url_list: Tuple): for item in url_list: try: urllib.request.urlopen(item,timeout=3).read() print("Smooth URL is: " + item) return item except: continue print("Necessary resource URL can not reachable, system exit!") sys.exit(0) class GitOp: '''Git operation''' def __init__(self): pass def gitClone(self, cmd: str): '''git clone''' try: print("Command is: "+cmd) os.system(cmd) except: print("Git clone failed, try again and check your URL can be accessed") sys.exit(0) class FileOp: '''File operation''' def __init__(self, path: str): self.path = path def printFile(self): '''output file content''' with open(self.path,newline='') as file: print(file.read()) def fileToString(self): '''read file content''' with open(self.path,'r') as file: return file.read() def stringToFile(self, content: Optional[str] = ""): '''string content to file''' with open(self.path,'w+') as file: return file.write(content) file.close() def fileToDict(self, remark: Optional[str] = "#", separate: Optional[str] = "="): ''' convert file to Json ''' dict = {} with open(self.path) as fh: for line in fh: if line == "\n": continue if line.find(remark) != 0: item, value = line.strip().split(separate, -1) dict[item] = value else: continue fh.close() return dict class NetOp: '''Network and port manage''' def __init__(self): pass def checkPort(self, port: int): '''check the target port's status''' search_key = "port="+str(port) if str(psutil.net_connections()).find(search_key) != -1: print(str(port)+" is used") return False else: return True class SecurityOp: '''Password and security operation''' def __int__(self): pass def randomPass(self, length: Optional[int] = 16): '''set strong password''' alphabet = string.ascii_letters + string.digits while True: password = ''.join(secrets.choice(alphabet) for i in range(length)) if (any(c.islower() for c in password) and any(c.isupper() for c in password) and sum(c.isdigit() for c in password) >= 3): break return password class DockerComposeOp: '''Docker Compose operation''' def __int__(self, path: Optional[str] = ""): self.cmd_up = "docker-compose up -d" self.cmd_stop = "docker-compose stop" self.cmd_down = "docker-compose down" self.path = path try: os.chdir(self.path) except: print("No found project directory") sys.exit(0) def up(self): '''docker-compose up''' try: os.system(cmd_up) except: print("Create failed") os.system(cmd_up) sys.exit(0) def stop(self): '''docker-compose stop''' try: os.system(cmd_stop) except: print("Stop failed, suggest try it again") sys.exit(0) def down(self): '''docker-compose down''' try: os.system(cmd_down) except: print("Down failed, suggest try it again") sys.exit(0) class DockerOp: ''' Docker operation ''' def __init__(self, status: Optional[str] = 'all'): self.client = docker.from_env() self.status = status def lsContainer(self): container_list = [] for container in self.client.containers.list(self.status): container_list.append(container.name) return container_list def getProject(self): project_dict = {} for name in self.lsContainer(): project_dict[self.client.containers.get(name).labels['com.docker.compose.project']] = self.client.containers.get(name).labels['com.docker.compose.project.working_dir'] return project_dict def lsProject(self): '''list all project and path''' for key, value in self.getProject().items(): print(key,value)