2022-03-23 06:06:13 +00:00
|
|
|
import json
|
|
|
|
import os
|
|
|
|
import logging
|
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
from app.classes.controllers.users_controller import HelperUsers
|
2022-04-12 01:34:46 +00:00
|
|
|
from app.classes.shared.console import Console
|
2022-03-23 06:06:13 +00:00
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2022-04-14 02:10:25 +00:00
|
|
|
class Import3:
|
2022-04-11 05:23:55 +00:00
|
|
|
def __init__(self, helper, controller):
|
|
|
|
self.helper = helper
|
|
|
|
self.controller = controller
|
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
def start_import(self):
|
|
|
|
folder = os.path.normpath(
|
|
|
|
input(
|
|
|
|
"Please input the path to the migrations folder "
|
|
|
|
"in your installation of Crafty 3: "
|
|
|
|
)
|
|
|
|
)
|
|
|
|
if not os.path.exists(folder):
|
2022-04-12 01:34:46 +00:00
|
|
|
Console.info(
|
2022-03-23 06:06:13 +00:00
|
|
|
"Crafty cannot find the path you entered. "
|
|
|
|
"Does Crafty's user have permission to access it?"
|
|
|
|
)
|
2022-04-12 01:34:46 +00:00
|
|
|
Console.info("Please run the import3 command again and enter a valid path.")
|
2022-03-23 06:06:13 +00:00
|
|
|
else:
|
|
|
|
with open(os.path.join(folder, "users.json"), encoding="utf-8") as f:
|
|
|
|
user_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(folder, "mc_settings.json"), encoding="utf-8") as f:
|
|
|
|
servers_json = json.loads(f.read())
|
|
|
|
self.import_users(user_json)
|
|
|
|
self.import_servers(servers_json, self.controller)
|
|
|
|
|
2022-04-11 05:23:55 +00:00
|
|
|
def import_users(self, json_data):
|
2022-03-23 06:06:13 +00:00
|
|
|
# If there is only one user to import json needs to call the data differently
|
|
|
|
if isinstance(json_data, list):
|
|
|
|
for user in json_data:
|
2022-06-13 19:14:41 +00:00
|
|
|
if str(user["username"]).lower() != "admin":
|
2022-06-14 19:43:29 +00:00
|
|
|
HelperUsers.add_rawpass_user(
|
|
|
|
str(user["username"]).lower(), user["password"]
|
|
|
|
)
|
2022-06-13 18:45:01 +00:00
|
|
|
Console.info(f"Imported user {user['username']} from Crafty 3")
|
|
|
|
logger.info(f"Imported user {user['username']} from Crafty 3")
|
|
|
|
else:
|
|
|
|
logger.info("Cannot create duplicate Admin account...skipping.")
|
2022-03-23 06:06:13 +00:00
|
|
|
else:
|
2022-06-13 19:14:41 +00:00
|
|
|
if str(json_data["username"]).lower() != "admin":
|
2022-06-13 19:07:12 +00:00
|
|
|
HelperUsers.add_rawpass_user(
|
2022-06-14 19:43:29 +00:00
|
|
|
str(json_data["username"]).lower(), json_data["password"]
|
2022-06-13 19:07:12 +00:00
|
|
|
)
|
|
|
|
Console.info(f"Imported user {json_data['username']} from Crafty 3")
|
|
|
|
logger.info(f"Imported user {json_data['username']} from Crafty 3")
|
|
|
|
else:
|
|
|
|
Console.info(
|
|
|
|
"There is only one user detected. "
|
|
|
|
"Cannot create duplicate Admin account."
|
|
|
|
)
|
|
|
|
logger.info(
|
|
|
|
"There is only one user detected. "
|
|
|
|
"Cannot create duplicate Admin account."
|
|
|
|
)
|
2022-03-23 06:06:13 +00:00
|
|
|
|
2022-04-11 05:23:55 +00:00
|
|
|
def import_servers(self, json_data, controller):
|
2022-03-23 06:06:13 +00:00
|
|
|
# If there is only one server to import json needs to call the data differently
|
|
|
|
if isinstance(json_data, list):
|
|
|
|
for server in json_data:
|
|
|
|
new_server_id = controller.import_jar_server(
|
|
|
|
server_name=server["server_name"],
|
|
|
|
server_path=server["server_path"],
|
|
|
|
server_jar=server["server_jar"],
|
|
|
|
min_mem=(int(server["memory_min"]) / 1000),
|
|
|
|
max_mem=(int(server["memory_max"]) / 1000),
|
|
|
|
port=server["server_port"],
|
|
|
|
)
|
2022-04-12 01:34:46 +00:00
|
|
|
Console.info(
|
2022-03-23 06:06:13 +00:00
|
|
|
f"Imported server {server['server_name']}[{server['id']}] "
|
|
|
|
f"from Crafty 3 to new server id {new_server_id}"
|
|
|
|
)
|
|
|
|
logger.info(
|
|
|
|
f"Imported server {server['server_name']}[{server['id']}] "
|
|
|
|
f"from Crafty 3 to new server id {new_server_id}"
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
new_server_id = controller.import_jar_server(
|
|
|
|
server_name=json_data["server_name"],
|
|
|
|
server_path=json_data["server_path"],
|
|
|
|
server_jar=json_data["server_jar"],
|
|
|
|
min_mem=(int(json_data["memory_min"]) / 1000),
|
|
|
|
max_mem=(int(json_data["memory_max"]) / 1000),
|
|
|
|
port=json_data["server_port"],
|
|
|
|
)
|
2022-04-12 01:34:46 +00:00
|
|
|
Console.info(
|
2022-03-23 06:06:13 +00:00
|
|
|
f"Imported server {json_data['server_name']}[{json_data['id']}] "
|
|
|
|
f"from Crafty 3 to new server id {new_server_id}"
|
|
|
|
)
|
|
|
|
logger.info(
|
|
|
|
f"Imported server {json_data['server_name']}[{json_data['id']}] "
|
|
|
|
f"from Crafty 3 to new server id {new_server_id}"
|
|
|
|
)
|