mirror of
https://github.com/blw1138/Zordon.git
synced 2025-12-17 16:58:12 +00:00
Use local_paths when submitting jobs to localhost
This commit is contained in:
@@ -372,7 +372,7 @@ class NewJobWindow(Frame):
|
|||||||
if renderer == 'blender':
|
if renderer == 'blender':
|
||||||
if self.blender_pack_textures.get():
|
if self.blender_pack_textures.get():
|
||||||
self.progress_label.configure(text="Packing Blender file...")
|
self.progress_label.configure(text="Packing Blender file...")
|
||||||
new_path = Blender.pack_project_file(project_path=input_path)
|
new_path = Blender.pack_project_file(project_path=input_path, timeout=300)
|
||||||
if new_path:
|
if new_path:
|
||||||
logger.info(f"New Path is now {new_path}")
|
logger.info(f"New Path is now {new_path}")
|
||||||
input_path = new_path
|
input_path = new_path
|
||||||
@@ -410,7 +410,7 @@ class NewJobWindow(Frame):
|
|||||||
self.progress_bar['value'] = int(percent)
|
self.progress_bar['value'] = int(percent)
|
||||||
return callback
|
return callback
|
||||||
|
|
||||||
result = self.server_proxy.post_job_to_server(input_path=input_path, job_list=job_list,
|
result = self.server_proxy.post_job_to_server(file_path=input_path, job_list=job_list,
|
||||||
callback=create_callback)
|
callback=create_callback)
|
||||||
|
|
||||||
self.progress_bar.stop()
|
self.progress_bar.stop()
|
||||||
|
|||||||
@@ -286,7 +286,7 @@ def add_job_handler():
|
|||||||
# initial handling of raw data
|
# initial handling of raw data
|
||||||
try:
|
try:
|
||||||
if request.is_json:
|
if request.is_json:
|
||||||
jobs_list = [request.json]
|
jobs_list = [request.json] if not isinstance(request.json, list) else request.json
|
||||||
elif request.form.get('json', None):
|
elif request.form.get('json', None):
|
||||||
jobs_list = json.loads(request.form['json'])
|
jobs_list = json.loads(request.form['json'])
|
||||||
else:
|
else:
|
||||||
@@ -313,7 +313,7 @@ def add_job_handler():
|
|||||||
logger.debug(f"Incoming new job request: {jobs_list}")
|
logger.debug(f"Incoming new job request: {jobs_list}")
|
||||||
uploaded_project = request.files.get('file', None)
|
uploaded_project = request.files.get('file', None)
|
||||||
project_url = jobs_list[0].get('url', None)
|
project_url = jobs_list[0].get('url', None)
|
||||||
input_path = jobs_list[0].get('input_path', None)
|
local_path = jobs_list[0].get('local_path', None)
|
||||||
renderer = jobs_list[0].get('renderer')
|
renderer = jobs_list[0].get('renderer')
|
||||||
|
|
||||||
downloaded_file_url = None
|
downloaded_file_url = None
|
||||||
@@ -329,8 +329,8 @@ def add_job_handler():
|
|||||||
err_msg = f"Error downloading file: {e}"
|
err_msg = f"Error downloading file: {e}"
|
||||||
logger.error(err_msg)
|
logger.error(err_msg)
|
||||||
return err_msg, 406
|
return err_msg, 406
|
||||||
elif input_path and os.path.exists(input_path):
|
elif local_path and os.path.exists(local_path):
|
||||||
referred_name = os.path.basename(input_path)
|
referred_name = os.path.basename(local_path)
|
||||||
else:
|
else:
|
||||||
return "Cannot find any valid project paths", 400
|
return "Cannot find any valid project paths", 400
|
||||||
|
|
||||||
@@ -351,9 +351,9 @@ def add_job_handler():
|
|||||||
loaded_project_local_path = os.path.join(upload_dir, referred_name)
|
loaded_project_local_path = os.path.join(upload_dir, referred_name)
|
||||||
shutil.move(downloaded_file_url, loaded_project_local_path)
|
shutil.move(downloaded_file_url, loaded_project_local_path)
|
||||||
logger.info(f"Download complete for {loaded_project_local_path.split(server.config['UPLOAD_FOLDER'])[-1]}")
|
logger.info(f"Download complete for {loaded_project_local_path.split(server.config['UPLOAD_FOLDER'])[-1]}")
|
||||||
elif input_path:
|
elif local_path:
|
||||||
loaded_project_local_path = os.path.join(upload_dir, referred_name)
|
loaded_project_local_path = os.path.join(upload_dir, referred_name)
|
||||||
shutil.copy(input_path, loaded_project_local_path)
|
shutil.copy(local_path, loaded_project_local_path)
|
||||||
logger.info(f"Import complete for {loaded_project_local_path.split(server.config['UPLOAD_FOLDER'])[-1]}")
|
logger.info(f"Import complete for {loaded_project_local_path.split(server.config['UPLOAD_FOLDER'])[-1]}")
|
||||||
|
|
||||||
# process uploaded zip files
|
# process uploaded zip files
|
||||||
@@ -492,7 +492,7 @@ def create_subjobs(worker, job_data, project_path):
|
|||||||
logger.debug(f"Posting subjob with frames {subjob['start_frame']}-"
|
logger.debug(f"Posting subjob with frames {subjob['start_frame']}-"
|
||||||
f"{subjob['end_frame']} to {server_hostname}")
|
f"{subjob['end_frame']} to {server_hostname}")
|
||||||
post_results = RenderServerProxy(server_hostname).post_job_to_server(
|
post_results = RenderServerProxy(server_hostname).post_job_to_server(
|
||||||
input_path=project_path, job_list=[subjob])
|
file_path=project_path, job_list=[subjob])
|
||||||
if post_results.ok:
|
if post_results.ok:
|
||||||
submission_results[server_hostname] = post_results.json()[0]
|
submission_results[server_hostname] = post_results.json()[0]
|
||||||
else:
|
else:
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import logging
|
|||||||
import os
|
import os
|
||||||
import json
|
import json
|
||||||
import requests
|
import requests
|
||||||
|
import socket
|
||||||
import time
|
import time
|
||||||
import threading
|
import threading
|
||||||
from lib.workers.base_worker import RenderStatus
|
from lib.workers.base_worker import RenderStatus
|
||||||
@@ -115,10 +116,17 @@ class RenderServerProxy:
|
|||||||
timeout=1) or {}
|
timeout=1) or {}
|
||||||
return request_data.get('is_available', False)
|
return request_data.get('is_available', False)
|
||||||
|
|
||||||
def post_job_to_server(self, input_path, job_list, callback=None):
|
def post_job_to_server(self, file_path, job_list, callback=None):
|
||||||
|
|
||||||
|
# bypass uploading file if posting to localhost
|
||||||
|
if self.hostname == socket.gethostname():
|
||||||
|
jobs_with_path = [{**item, "local_path": file_path} for item in job_list]
|
||||||
|
return requests.post(f'http://{self.hostname}:{self.port}/api/add_job', data=json.dumps(jobs_with_path),
|
||||||
|
headers={'Content-Type': 'application/json'})
|
||||||
|
|
||||||
# Prepare the form data
|
# Prepare the form data
|
||||||
encoder = MultipartEncoder({
|
encoder = MultipartEncoder({
|
||||||
'file': (os.path.basename(input_path), open(input_path, 'rb'), 'application/octet-stream'),
|
'file': (os.path.basename(file_path), open(file_path, 'rb'), 'application/octet-stream'),
|
||||||
'json': (None, json.dumps(job_list), 'application/json'),
|
'json': (None, json.dumps(job_list), 'application/json'),
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -130,9 +138,7 @@ class RenderServerProxy:
|
|||||||
|
|
||||||
# Send the request
|
# Send the request
|
||||||
headers = {'Content-Type': monitor.content_type}
|
headers = {'Content-Type': monitor.content_type}
|
||||||
response = requests.post(f'http://{self.hostname}:{self.port}/api/add_job', data=monitor, headers=headers)
|
return requests.post(f'http://{self.hostname}:{self.port}/api/add_job', data=monitor, headers=headers)
|
||||||
|
|
||||||
return response
|
|
||||||
|
|
||||||
def get_job_files(self, job_id, save_path):
|
def get_job_files(self, job_id, save_path):
|
||||||
url = f"http://{self.hostname}:{self.port}/api/job/{job_id}/download_all"
|
url = f"http://{self.hostname}:{self.port}/api/job/{job_id}/download_all"
|
||||||
|
|||||||
Reference in New Issue
Block a user