NXPR-3 Work

This commit is contained in:
Wojciech Janota 2022-11-13 22:12:02 +01:00
parent e93d53b1f2
commit 637b4d88e2
No known key found for this signature in database
GPG Key ID: E83FBD2850CC1F14
2 changed files with 43 additions and 16 deletions

View File

@ -1,7 +1,9 @@
from http.client import NON_AUTHORITATIVE_INFORMATION
from flask import Flask
from flask import Flask, request, jsonify
from utils.database.database import Database
from utils.exceptions import DatabaseException
from utils.models.models import Client
import json
class FlaskAppWrapper(object):
@ -40,11 +42,27 @@ class Server():
return {"server_name": self.name, "server_version": self.version, "host": self.host}
def register_new_client_to_database(self):
# TODO: implement
self.database
request_content_type = request.headers.get('Content-Type')
json_string = ""
if request_content_type == 'application/json':
json_string = request.json
try:
json_object = json.loads(json_string)
new_client_object = Client(mac_address=json_object["mac_address"], ip_address=json_object["ip_address"], hostname=json_object[
"hostname"], client_version=json_object["client_version"], vm_list_on_machine=json_object["vm_list_on_machine"])
self.database.add_client(new_client_object)
response = jsonify(success=True)
response.status_code = 201
return response
except Exception as ex:
response = jsonify(success=False)
response.status_code = 400
return response
def run(self):
self.app.add_endpoint(endpoint="/", endpoint_name="server_data",
handler=self.basic_server_data, methods=["GET"])
self.app.add_endpoint(endpoint="/clients", endpoint_name="register_client",
handler=self.register_new_client_to_database, methods=["POST"])
# TODO: add rest of endpoints
self.app.run()

View File

@ -11,16 +11,17 @@ client_image_table = Table(
Column("image_id", Integer, ForeignKey("vm_images.image_id"))
)
class Client(Base):
__tablename__ = "clients"
mac_address = Column(String, primary_key=True)
ip_address = Column(String)
hostname = Column(String)
client_version = Column(String)
ip_address = Column(String(16), nullable=False)
hostname = Column(String(100), nullable=False)
client_version = Column(String(100), nullable=False)
vm_list_on_machine = relationship(
"VMImages",
secondary = client_image_table,
back_populates = "vm_images"
secondary=client_image_table,
back_populates="vm_images"
)
def has_vm_installed(self, vm_object):
@ -29,15 +30,23 @@ class Client(Base):
return True
return False
class VMImage(Base):
__tablename__ = "vm_images"
image_id = Column(Integer, primary_key=True)
image_name = Column(String)
image_file = Column(String)
image_version = Column(String)
image_hash = Column(String)
image_name = Column(String(100), unique=True, nullable=False)
image_file = Column(String(500), unique=False, nullable=False)
image_version = Column(String(100), nullable=False)
image_hash = Column(String(500), nullalbe=False)
clients = relationship(
"Clients",
secondary = client_image_table,
back_populates = "clients"
secondary=client_image_table,
back_populates="clients"
)
class User(Base):
__tablename__ = "users"
user_id = Column(Integer, primary_key=True)
username = Column(String)
password_hash = Column(String)