Source code for creopyson.connection

"""Connection module."""
import requests
import json
import logging
from pathlib import Path
from .exceptions import MissingKey, ErrorJsonDecode

lg = logging.getLogger(__name__)


[docs] class Client(object): """Creates Client object.""" def __init__(self, ip_adress="localhost", port=9056): """Create Client objet. Define server and sessionID vars.""" self.server = "http://{}:{}/creoson".format(ip_adress, port) self.sessionId = ""
[docs] def connect(self): """Connect to CREOSON. Define 'sessionId'. Exit if server not found. """ self.sessionId = self._creoson_post("connection", "connect")
def _creoson_post(self, command, function, data=None, key_data=None): """Send a POST request to creoson server and return waited data. Args: command (str): Command param for creoson. function (str): Function param for creoson. data (dict, optionnal): data params for creson request. key_data (str, optionnal): param name waited in result. Raises: RuntimeError: error message from creoson. ConnectionError: creoson not reachable. MissingKey: Missing arg in creoson return. Returns: (depends request): creoson return. """ request = { "sessionId": self.sessionId, "command": command, "function": function, "data": data, } lg.debug("request: %s", str(request)) try: r = requests.post(self.server, data=json.dumps(request)) except requests.exceptions.RequestException as e: raise ConnectionError(e) if r.status_code != 200: raise ConnectionError("Status code : {}".format(r.status_code)) try: json_result = r.json() lg.debug("response: %s", str(json_result)) except TypeError: raise ErrorJsonDecode("Cannot decode JSON, creoson result invalid.") if "status" not in json_result.keys(): raise MissingKey("Missing `status` in creoson result.") if "error" not in json_result["status"].keys(): raise MissingKey("Missing `error` in status' creoson's result.") status = json_result["status"]["error"] if status: error_msg = json_result["status"]["message"] raise RuntimeError(error_msg) if request["command"] == "connection" and request["function"] == "connect": if "sessionId" not in json_result.keys(): raise MissingKey("Missing `sessionId` in creoson result.") else: return json_result["sessionId"] if key_data is not None: if "data" not in json_result.keys(): raise MissingKey("Missing `data` in creoson return") if key_data not in json_result["data"].keys(): raise MissingKey("Missing `{}` in creoson result".format(key_data)) return json_result["data"][key_data] return json_result.get("data", None)
[docs] def disconnect(self): """Disconnect from CREOSON. Empty sessionId. """ self._creoson_post("connection", "disconnect") self.sessionId = ""
[docs] def is_creo_running(self): """Check whether Creo is running. This function tests whether the current connection is still active; if there is no active connection, then it tries to make a new connection to Creo and returns whether the connection succeeds. The sessionId is optional, and ignored. Raises: Warning: error message from creoson. Returns: (boolean): True if Creo is running, False instead. """ # return self._creoson_post("connection", "is_creo_running")["running"] return self._creoson_post("connection", "is_creo_running", key_data="running")
[docs] def kill_creo(self): """Kill primary Creo processes. This will kill the 'xtop.exe' and 'nmsd.exe' processes by name. The sessionId is optional, and ignored. Raises: Warning: error message from creoson. Returns: None """ return self._creoson_post("connection", "kill_creo")
[docs] def start_creo(self, path, retries=0, use_desktop=False): """Execute an external .bat file to start Creo. Then attempts to connect to Creo. The .bat file is restricted to a specific name to make the function more secure. (nitro_proe_remote.bat) Set retries to 0 to NOT attempt to connect to Creo. The server will pause for 3 seconds before attempting a connection, and will pause for 10 seconds between connection retries. If Creo pops up a message after startup, this function may cause Creo to crash unless retries is set to 0. If use_desktop is set, make sure that your nitro_proe_remote.bat file contains a cd command to change to the directory where you want Creo to start! Args: path (string): path to the .bat file (must be full path) will be split in 'start_command' and 'start_dir' retries (int): Number of retries to make when connecting (default 0) use_desktop (boolean): Whether to use the desktop to start creo rather than the java runtime. Should only be used if the runtime method doesn't work. Default is False. Raises: Warning: error message from creoson. Returns: None """ path_obj = Path(path) start_command = path_obj.name start_dir = str(path_obj.parents[0]) data = { "start_dir": start_dir, "start_command": start_command, "retries": retries, "use_desktop": use_desktop, } return self._creoson_post("connection", "start_creo", data)
[docs] def stop_creo(self): """Disconnect current session from Creo and cause Creo to exit. NOTE that this will cause Creo to exit cleanly. If there is no current connection to Creo, this function will do nothing. Raises: Warning: error message from creoson. Returns: None """ return self._creoson_post("connection", "stop_creo")