JudgeServer/service.py

54 lines
2.0 KiB
Python
Raw Normal View History

2016-10-03 08:13:46 +00:00
# coding=utf-8
from __future__ import unicode_literals
import os
import json
import requests
2016-10-04 06:32:40 +00:00
import hashlib
2016-10-03 08:13:46 +00:00
from exception import JudgeServiceError
2016-10-04 05:24:50 +00:00
from utils import server_info, get_token, logger
2016-10-03 08:13:46 +00:00
class JudgeService(object):
def __init__(self):
# exists if docker link oj_web_server:oj_web_server
self.service_discovery_host = os.environ.get("OJ_WEB_SERVER_PORT_8080_TCP_ADDR")
self.service_discovery_port = os.environ.get("OJ_WEB_SERVER_PORT_8080_TCP_PORT")
self.service_discovery_url = os.environ.get("service_discovery_url", "")
# this container's ip and port, if these are not set, web server will think it's a linked container
2016-10-05 05:38:49 +00:00
self.service_url = os.environ.get("service_url")
2016-10-03 08:13:46 +00:00
if not self.service_discovery_url:
if not (self.service_discovery_host and self.service_discovery_port):
raise JudgeServiceError("service discovery host or port not found")
else:
self.service_discovery_url = "http://" + self.service_discovery_host + ":" + \
str(self.service_discovery_port) + "/api/judge_service/"
def _request(self, data):
try:
r = requests.post(self.service_discovery_url, data=json.dumps(data),
2016-10-05 05:38:49 +00:00
headers={"X-JUDGE-SERVER-TOKEN": hashlib.sha256(get_token()).hexdigest(),
"Content-Type": "application/json"}, timeout=5).json()
2016-10-03 08:13:46 +00:00
except Exception as e:
logger.exception(e)
raise JudgeServiceError(e.message)
if r["err"]:
raise JudgeServiceError(r["data"])
def heartbeat(self):
data = server_info()
data["action"] = "heartbeat"
2016-10-05 05:38:49 +00:00
data["service_url"] = self.service_url
2016-10-03 08:13:46 +00:00
self._request(data)
if __name__ == "__main__":
try:
service = JudgeService()
service.heartbeat()
exit(0)
except Exception as e:
logger.exception(e)
exit(1)