2009-08-29 17:25:22 +00:00
|
|
|
import bpy
|
|
|
|
import sys, os
|
|
|
|
import http, http.client, http.server, urllib
|
|
|
|
import subprocess, shutil, time, hashlib
|
|
|
|
|
2009-09-01 01:09:05 +00:00
|
|
|
import netrender.model
|
2009-08-29 17:25:22 +00:00
|
|
|
|
2009-09-01 01:09:05 +00:00
|
|
|
VERSION = b"0.3"
|
2009-08-29 17:25:22 +00:00
|
|
|
|
|
|
|
QUEUED = 0
|
|
|
|
DISPATCHED = 1
|
|
|
|
DONE = 2
|
|
|
|
ERROR = 3
|
|
|
|
|
|
|
|
def clientConnection(scene):
|
|
|
|
netrender = scene.network_render
|
|
|
|
|
|
|
|
conn = http.client.HTTPConnection(netrender.server_address, netrender.server_port)
|
|
|
|
|
|
|
|
if clientVerifyVersion(conn):
|
|
|
|
return conn
|
|
|
|
else:
|
|
|
|
conn.close()
|
|
|
|
return None
|
|
|
|
|
|
|
|
def clientVerifyVersion(conn):
|
|
|
|
conn.request("GET", "version")
|
|
|
|
response = conn.getresponse()
|
|
|
|
|
|
|
|
if response.status != http.client.OK:
|
|
|
|
conn.close()
|
|
|
|
return False
|
|
|
|
|
|
|
|
server_version = response.read()
|
|
|
|
|
|
|
|
if server_version != VERSION:
|
|
|
|
print("Incorrect server version!")
|
|
|
|
print("expected", VERSION, "received", server_version)
|
|
|
|
return False
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
def clientSendJob(conn, scene, anim = False, chunks = 5):
|
2009-09-01 01:09:05 +00:00
|
|
|
netsettings = scene.network_render
|
|
|
|
job = netrender.model.RenderJob()
|
2009-08-29 17:25:22 +00:00
|
|
|
|
|
|
|
if anim:
|
2009-09-01 01:09:05 +00:00
|
|
|
for f in range(scene.start_frame, scene.end_frame + 1):
|
|
|
|
job.addFrame(f)
|
2009-08-29 17:25:22 +00:00
|
|
|
else:
|
2009-09-01 01:09:05 +00:00
|
|
|
job.addFrame(scene.current_frame)
|
2009-08-29 17:25:22 +00:00
|
|
|
|
|
|
|
filename = bpy.data.filename
|
2009-09-01 01:09:05 +00:00
|
|
|
job.files.append(filename)
|
2009-08-29 17:25:22 +00:00
|
|
|
|
2009-09-01 01:09:05 +00:00
|
|
|
name = netsettings.job_name
|
2009-08-29 17:25:22 +00:00
|
|
|
if name == "[default]":
|
|
|
|
path, name = os.path.split(filename)
|
|
|
|
|
2009-09-01 01:09:05 +00:00
|
|
|
job.name = name
|
|
|
|
|
2009-08-29 17:25:22 +00:00
|
|
|
for slave in scene.network_render.slaves_blacklist:
|
2009-09-01 01:09:05 +00:00
|
|
|
job.blacklist.append(slave.id)
|
2009-08-29 17:25:22 +00:00
|
|
|
|
2009-09-01 01:09:05 +00:00
|
|
|
job.chunks = netsettings.chunks
|
|
|
|
job.priority = netsettings.priority
|
2009-08-29 17:25:22 +00:00
|
|
|
|
|
|
|
# try to send path first
|
2009-09-01 01:09:05 +00:00
|
|
|
conn.request("POST", "job", repr(job.serialize()))
|
2009-08-29 17:25:22 +00:00
|
|
|
response = conn.getresponse()
|
|
|
|
|
2009-09-01 01:09:05 +00:00
|
|
|
job_id = response.getheader("job-id")
|
|
|
|
|
2009-08-29 17:25:22 +00:00
|
|
|
# if not found, send whole file
|
|
|
|
if response.status == http.client.NOT_FOUND:
|
|
|
|
f = open(bpy.data.filename, "rb")
|
2009-09-01 01:09:05 +00:00
|
|
|
conn.request("PUT", "file", f, headers={"job-id": job_id})
|
2009-08-29 17:25:22 +00:00
|
|
|
f.close()
|
|
|
|
response = conn.getresponse()
|
|
|
|
|
2009-09-01 01:09:05 +00:00
|
|
|
# server will reply with NOT_FOUD until all files are found
|
|
|
|
|
|
|
|
return job_id
|
2009-08-29 17:25:22 +00:00
|
|
|
|
|
|
|
def clientRequestResult(conn, scene, job_id):
|
|
|
|
conn.request("GET", "render", headers={"job-id": job_id, "job-frame":str(scene.current_frame)})
|