-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprinter_simulator.py
113 lines (90 loc) · 3 KB
/
printer_simulator.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import paho.mqtt.client as mqtt
import time
import logging
from logging.handlers import RotatingFileHandler
from logging import handlers
import sys
import os
import select
import json
import datetime
from classes.printer import Printer
from dotenv import load_dotenv
load_dotenv() # Load params from the .env file
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
ch = logging.StreamHandler(sys.stdout)
ch.setLevel(logging.DEBUG)
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
ch.setFormatter(formatter)
logger.addHandler(ch)
host = os.getenv("HOST")
port = int(os.getenv("PORT"))
client_id = os.getenv("CLIENT_ID")
api_key = os.getenv("API_KEY")
status_topic = os.getenv("STATUS_TOPIC")
model = os.getenv("MODEL")
serial = os.getenv("SERIAL")
status = os.getenv("STATUS")
temperature = os.getenv("TEMPERATURE")
progress = os.getenv("PROGRESS")
token = os.getenv("TOKEN")
keep_looping = True
printer = Printer(model, serial, status, progress, temperature)
def received_action(payload):
global printer
logger.debug(str(payload))
paredPayload = json.loads(payload)
if paredPayload['action_code'] == "100":
logger.debug("received prepare 100")
# status = "prepare"
printer.prepare()
if paredPayload['action_code'] == "101":
logger.debug("received print 101")
printer.print()
if paredPayload['action_code'] == "102":
logger.debug("received pause 102")
printer.pause()
if paredPayload['action_code'] == "103":
logger.debug("received cancel 103")
printer.cancel()
if paredPayload['action_code'] == "104":
logger.debug("received resume 104")
printer.resume()
def send_status(client):
global printer
client.loop_start()
while keep_looping:
status_dict = {
'actionCode': '300',
'date': datetime.datetime.utcnow().isoformat(),
'status': printer.status,
'serial_number': printer.serial,
'model': printer.model,
'temperature': printer.temperature,
'progress' : printer.progress
}
status_string = json.dumps(status_dict)
logger.debug("Sending status: " + status_dict['status'])
client.publish(status_topic, status_string)
time.sleep(1)
def on_connect(client, userdata, flags, rc):
global printer
logger.debug("Connected with result code "+str(rc))
topic = "/printers/"+printer.model+"/"+printer.serial
client.subscribe(topic)
logger.debug("subscribed to topic "+ topic)
def on_disconnect(client, userdata, rc):
logger.debug("Disconnect with result code "+str(rc))
def on_message(client, userdata, msg):
logger.debug("Message received")
received_action(msg.payload)
client = mqtt.Client()
client.tls_set()
client.username_pw_set(client_id, api_key)
client.on_connect = on_connect
client.on_disconnect = on_disconnect
client.on_message = on_message
logger.debug("connect")
client.connect(host, port, 60)
send_status(client)