2021-09-26 15:22:38 +08:00
|
|
|
|
|
2021-10-17 22:47:15 +08:00
|
|
|
|
import os, io, sys, platform, psutil, json, secrets, string, docker
|
2021-09-26 15:22:38 +08:00
|
|
|
|
from typing import Any, Callable, Dict, List, Optional, Sequence, Tuple, Type, Union
|
|
|
|
|
|
|
|
|
|
import urllib.request
|
|
|
|
|
|
2021-09-28 18:34:18 +08:00
|
|
|
|
|
2021-09-26 15:22:38 +08:00
|
|
|
|
class SmoothUrl:
|
2021-09-28 18:34:18 +08:00
|
|
|
|
''' Get the best smooth url for Git or Download'''
|
2021-09-26 15:22:38 +08:00
|
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
|
pass
|
|
|
|
|
|
2021-10-07 17:36:09 +08:00
|
|
|
|
def res(self, url_list: Tuple):
|
2021-09-26 15:22:38 +08:00
|
|
|
|
|
|
|
|
|
for item in url_list:
|
|
|
|
|
try:
|
|
|
|
|
urllib.request.urlopen(item,timeout=3).read()
|
2021-09-28 18:34:18 +08:00
|
|
|
|
print("Smooth URL is: " + item)
|
2021-09-26 15:22:38 +08:00
|
|
|
|
return item
|
2021-09-28 18:34:18 +08:00
|
|
|
|
except:
|
2021-09-26 15:22:38 +08:00
|
|
|
|
continue
|
|
|
|
|
|
2021-09-28 18:34:18 +08:00
|
|
|
|
print("Necessary resource URL can not reachable, system exit!")
|
|
|
|
|
sys.exit(0)
|
|
|
|
|
|
2021-09-26 15:22:38 +08:00
|
|
|
|
|
2021-09-28 18:34:18 +08:00
|
|
|
|
class GitOp:
|
|
|
|
|
'''Git operation'''
|
2021-09-26 15:22:38 +08:00
|
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
|
pass
|
|
|
|
|
|
2021-09-29 18:24:23 +08:00
|
|
|
|
def gitClone(self, cmd: str):
|
2021-09-28 18:34:18 +08:00
|
|
|
|
'''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)
|
2021-09-26 17:57:34 +08:00
|
|
|
|
|
|
|
|
|
class FileOp:
|
|
|
|
|
'''File operation'''
|
|
|
|
|
|
2021-10-12 19:26:24 +08:00
|
|
|
|
def __init__(self, path: str):
|
|
|
|
|
self.path = path
|
2021-09-26 17:57:34 +08:00
|
|
|
|
|
2021-10-12 19:26:24 +08:00
|
|
|
|
def printFile(self):
|
2021-09-29 18:24:23 +08:00
|
|
|
|
'''output file content'''
|
2021-10-12 19:26:24 +08:00
|
|
|
|
with open(self.path,newline='') as file:
|
2021-09-28 18:34:18 +08:00
|
|
|
|
print(file.read())
|
2021-10-12 19:26:24 +08:00
|
|
|
|
|
|
|
|
|
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()
|
2021-09-28 18:34:18 +08:00
|
|
|
|
|
2021-10-12 19:26:24 +08:00
|
|
|
|
def fileToDict(self, remark: Optional[str] = "#", separate: Optional[str] = "="):
|
2021-09-29 18:24:23 +08:00
|
|
|
|
''' convert file to Json '''
|
|
|
|
|
dict = {}
|
2021-10-12 19:26:24 +08:00
|
|
|
|
with open(self.path) as fh:
|
2021-09-29 18:24:23 +08:00
|
|
|
|
for line in fh:
|
2021-10-07 17:36:09 +08:00
|
|
|
|
if line == "\n":
|
|
|
|
|
continue
|
2021-09-29 18:24:23 +08:00
|
|
|
|
|
|
|
|
|
if line.find(remark) != 0:
|
|
|
|
|
item, value = line.strip().split(separate, -1)
|
2021-10-12 19:26:24 +08:00
|
|
|
|
dict[item] = value
|
2021-09-29 18:24:23 +08:00
|
|
|
|
else:
|
|
|
|
|
continue
|
|
|
|
|
fh.close()
|
2021-10-07 17:36:09 +08:00
|
|
|
|
return dict
|
2021-09-28 18:34:18 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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)
|
2021-10-12 19:26:24 +08:00
|
|
|
|
if str(psutil.net_connections()).find(search_key) != -1:
|
2021-09-28 18:34:18 +08:00
|
|
|
|
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):
|
2021-09-29 18:24:23 +08:00
|
|
|
|
'''set strong password'''
|
2021-09-28 18:34:18 +08:00
|
|
|
|
|
|
|
|
|
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
|
2021-10-16 18:57:11 +08:00
|
|
|
|
return password
|
|
|
|
|
|
|
|
|
|
class DockerComposeOp:
|
|
|
|
|
'''Docker Compose operation'''
|
|
|
|
|
|
2021-11-02 20:54:10 +08:00
|
|
|
|
def __init__(self, command: str, **parameter):
|
2021-10-16 18:57:11 +08:00
|
|
|
|
|
2021-11-02 20:54:10 +08:00
|
|
|
|
self.cmd = "docker-compose "+ command
|
|
|
|
|
|
|
|
|
|
for key, value in parameter.items():
|
|
|
|
|
self.cmd = self.cmd + " --" + key + " " + value
|
2021-10-16 18:57:11 +08:00
|
|
|
|
|
|
|
|
|
try:
|
2021-11-02 20:54:10 +08:00
|
|
|
|
os.chdir(self.parameter[project-directory])
|
2021-10-16 18:57:11 +08:00
|
|
|
|
except:
|
2021-11-01 19:23:17 +08:00
|
|
|
|
print("Not found project directory")
|
2021-10-16 18:57:11 +08:00
|
|
|
|
sys.exit(0)
|
|
|
|
|
|
2021-11-02 20:54:10 +08:00
|
|
|
|
def execute(self):
|
|
|
|
|
'''docker-compose command executing'''
|
2021-10-16 18:57:11 +08:00
|
|
|
|
try:
|
2021-11-02 20:54:10 +08:00
|
|
|
|
os.system(self.cmd)
|
2021-10-16 18:57:11 +08:00
|
|
|
|
except:
|
2021-11-02 20:54:10 +08:00
|
|
|
|
print("This operation execute failed")
|
2021-10-16 18:57:11 +08:00
|
|
|
|
sys.exit(0)
|
2021-11-02 20:54:10 +08:00
|
|
|
|
|
2021-10-16 18:57:11 +08:00
|
|
|
|
class DockerOp:
|
|
|
|
|
''' Docker operation '''
|
2021-10-18 19:07:41 +08:00
|
|
|
|
def __init__(self, status: Optional[str] = 'all'):
|
2021-10-17 22:47:15 +08:00
|
|
|
|
self.client = docker.from_env()
|
2021-10-18 19:07:41 +08:00
|
|
|
|
self.status = status
|
2021-10-16 18:57:11 +08:00
|
|
|
|
|
2021-10-17 22:47:15 +08:00
|
|
|
|
def lsContainer(self):
|
|
|
|
|
container_list = []
|
|
|
|
|
|
2021-10-18 19:07:41 +08:00
|
|
|
|
for container in self.client.containers.list(self.status):
|
2021-10-17 22:47:15 +08:00
|
|
|
|
container_list.append(container.name)
|
|
|
|
|
return container_list
|
|
|
|
|
|
2021-10-18 19:07:41 +08:00
|
|
|
|
def getProject(self):
|
2021-10-17 22:47:15 +08:00
|
|
|
|
project_dict = {}
|
|
|
|
|
|
|
|
|
|
for name in self.lsContainer():
|
2021-10-18 19:07:41 +08:00
|
|
|
|
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)
|