mirror of
https://github.com/newnius/YAO-agent.git
synced 2025-06-07 22:01:55 +00:00
bugfix
This commit is contained in:
parent
54f20c0ece
commit
5c90e5a94f
112
server.py
112
server.py
@ -24,25 +24,24 @@ class MyHandler(BaseHTTPRequestHandler):
|
|||||||
self.wfile.write(bytes("pong", "utf-8"))
|
self.wfile.write(bytes("pong", "utf-8"))
|
||||||
|
|
||||||
elif req.path == "/logs":
|
elif req.path == "/logs":
|
||||||
id = query['id'][0]
|
|
||||||
try:
|
try:
|
||||||
|
container_id = query['id'][0]
|
||||||
client = docker.from_env()
|
client = docker.from_env()
|
||||||
container = client.containers.get(id)
|
container = client.containers.get(container_id)
|
||||||
msg = {'code': 0, 'logs': str(container.logs().decode())}
|
msg = {'code': 0, 'logs': str(container.logs().decode())}
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
msg = {'code': 0, 'error': e}
|
msg = {'code': 0, 'error': str(e)}
|
||||||
self.send_response(200)
|
self.send_response(200)
|
||||||
self.send_header('Content-type', 'application/json')
|
self.send_header('Content-type', 'application/json')
|
||||||
self.end_headers()
|
self.end_headers()
|
||||||
self.wfile.write(bytes(json.dumps(msg), "utf-8"))
|
self.wfile.write(bytes(json.dumps(msg), "utf-8"))
|
||||||
|
|
||||||
elif req.path == "/status":
|
elif req.path == "/status":
|
||||||
id = query['id'][0]
|
container_id = query['id'][0]
|
||||||
client = docker.from_env()
|
client = docker.from_env()
|
||||||
container = client.containers.list(all=True, filters={'id': id})
|
container = client.containers.list(all=True, filters={'id': container_id})
|
||||||
if len(container) > 0:
|
if len(container) > 0:
|
||||||
container = container[0]
|
container = container[0]
|
||||||
print(container.image.attrs)
|
|
||||||
status = {
|
status = {
|
||||||
'id': container.short_id,
|
'id': container.short_id,
|
||||||
'image': container.attrs['Config']['Image'],
|
'image': container.attrs['Config']['Image'],
|
||||||
@ -65,68 +64,67 @@ class MyHandler(BaseHTTPRequestHandler):
|
|||||||
else:
|
else:
|
||||||
self.send_error(404, 'File Not Found: %s' % self.path)
|
self.send_error(404, 'File Not Found: %s' % self.path)
|
||||||
|
|
||||||
|
# Handler for the POST requests
|
||||||
|
def do_POST(self):
|
||||||
|
if self.path == "/create":
|
||||||
|
form = cgi.FieldStorage(
|
||||||
|
fp=self.rfile,
|
||||||
|
headers=self.headers,
|
||||||
|
environ={
|
||||||
|
'REQUEST_METHOD': 'POST',
|
||||||
|
'CONTENT_TYPE': self.headers['Content-Type'],
|
||||||
|
})
|
||||||
|
docker_image = form["image"].value
|
||||||
|
docker_cmd = form["cmd"].value
|
||||||
|
|
||||||
# Handler for the POST requests
|
try:
|
||||||
def do_POST(self):
|
client = docker.from_env()
|
||||||
if self.path == "/create":
|
container = client.containers.run(
|
||||||
form = cgi.FieldStorage(
|
image=docker_image,
|
||||||
fp=self.rfile,
|
command=docker_cmd,
|
||||||
headers=self.headers,
|
environment={"key": "value"},
|
||||||
environ={
|
runtime="nvidia",
|
||||||
'REQUEST_METHOD': 'POST',
|
detach=True
|
||||||
'CONTENT_TYPE': self.headers['Content-Type'],
|
)
|
||||||
})
|
msg = {"code": 0, "id": container.id}
|
||||||
docker_image = form["image"].value
|
except Exception as e:
|
||||||
docker_cmd = form["cmd"].value
|
msg = {"code": 1, "error": str(e)}
|
||||||
|
|
||||||
|
self.send_response(200)
|
||||||
|
self.send_header('Content-type', 'application/json')
|
||||||
|
self.end_headers()
|
||||||
|
self.wfile.write(bytes(json.dumps(msg), "utf-8"))
|
||||||
|
|
||||||
|
elif self.path == "/stop":
|
||||||
|
form = cgi.FieldStorage(
|
||||||
|
fp=self.rfile,
|
||||||
|
headers=self.headers,
|
||||||
|
environ={
|
||||||
|
'REQUEST_METHOD': 'POST',
|
||||||
|
'CONTENT_TYPE': self.headers['Content-Type'],
|
||||||
|
})
|
||||||
|
container_id = form["id"].value
|
||||||
|
|
||||||
try:
|
|
||||||
client = docker.from_env()
|
client = docker.from_env()
|
||||||
container = client.containers.run(
|
container = client.containers.get(container_id)
|
||||||
image=docker_image,
|
container.stop()
|
||||||
command=docker_cmd,
|
msg = {"code": 0}
|
||||||
environment={"key": "value"},
|
|
||||||
runtime="nvidia",
|
|
||||||
detach=True
|
|
||||||
)
|
|
||||||
msg = {"code": 0, "id": container.id}
|
|
||||||
except Exception as e:
|
|
||||||
msg = {"code": 1, "error": e}
|
|
||||||
|
|
||||||
self.send_response(200)
|
self.send_response(200)
|
||||||
self.send_header('Content-type', 'application/json')
|
self.send_header('Content-type', 'application/json')
|
||||||
self.end_headers()
|
self.end_headers()
|
||||||
self.wfile.write(bytes(json.dumps(msg), "utf-8"))
|
self.wfile.write(bytes(json.dumps(msg), "utf-8"))
|
||||||
|
else:
|
||||||
elif self.path == "/stop":
|
self.send_error(404, 'File Not Found: %s' % self.path)
|
||||||
form = cgi.FieldStorage(
|
|
||||||
fp=self.rfile,
|
|
||||||
headers=self.headers,
|
|
||||||
environ={
|
|
||||||
'REQUEST_METHOD': 'POST',
|
|
||||||
'CONTENT_TYPE': self.headers['Content-Type'],
|
|
||||||
})
|
|
||||||
id = form["id"].value
|
|
||||||
|
|
||||||
client = docker.from_env()
|
|
||||||
container = client.containers.get(id)
|
|
||||||
container.stop()
|
|
||||||
msg = {"code": 0}
|
|
||||||
|
|
||||||
self.send_response(200)
|
|
||||||
self.send_header('Content-type', 'application/json')
|
|
||||||
self.end_headers()
|
|
||||||
self.wfile.write(bytes(json.dumps(msg), "utf-8"))
|
|
||||||
else:
|
|
||||||
self.send_error(404, 'File Not Found: %s' % self.path)
|
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# Create a web server and define the handler to manage the
|
# Create a web server and define the handler to manage the
|
||||||
# incoming request
|
# incoming request
|
||||||
server = HTTPServer(('', PORT_NUMBER), MyHandler)
|
server = HTTPServer(('', PORT_NUMBER), MyHandler)
|
||||||
print('Started httpserver on port ', PORT_NUMBER)
|
print('Started http server on port ', PORT_NUMBER)
|
||||||
|
|
||||||
# Wait forever for incoming htto requests
|
# Wait forever for incoming http requests
|
||||||
server.serve_forever()
|
server.serve_forever()
|
||||||
|
|
||||||
except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
|
Loading…
Reference in New Issue
Block a user