-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontrol_receiver_thread.py
109 lines (78 loc) · 3.12 KB
/
control_receiver_thread.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
# Copyright (c) 2024 Cloudflare, Inc.
# Licensed under the Apache 2.0 license found in the LICENSE file or at https://www.apache.org/licenses/LICENSE-2.0
import time
from exceptions import PeerDisconnectedException
# falling off the end of this method terminates the process
def run_recv_term_queue(args, stdout_queue, control_conn, results_queue):
if args.verbosity:
stdout_queue.put("starting control receiver process: run_recv_term_queue")
while True:
try:
# blocking
bytes_read = control_conn.recv_a_c_block()
except ConnectionResetError:
if args.verbosity:
stdout_queue.put("connection reset error")
# exit process
break
except PeerDisconnectedException:
if args.verbosity:
stdout_queue.put("peer disconnected (control socket)")
# exit process
break
received_str = bytes_read.decode()
curr_time_str = str(time.time())
new_str = received_str + curr_time_str + " d "
results_queue.put(new_str)
control_conn.close()
if args.verbosity:
stdout_queue.put("exiting control receiver process: run_recv_term_queue")
# falling off the end of this method terminates the process
def run_recv_term_send(args, stdout_queue, control_conn):
if args.verbosity:
stdout_queue.put("starting control receiver process: run_recv_term_send")
while True:
try:
# blocking
bytes_read = control_conn.recv_a_c_block()
except ConnectionResetError:
if args.verbosity:
stdout_queue.put("connection reset error")
# exit process
break
except PeerDisconnectedException:
if args.verbosity:
stdout_queue.put("peer disconnected (control socket)")
# exit process
break
received_str = bytes_read.decode()
curr_time_str = str(time.time())
new_str = received_str + curr_time_str + " d "
control_conn.send(new_str.encode())
control_conn.close()
if args.verbosity:
stdout_queue.put("exiting control receiver process: run_recv_term_send")
# falling off the end of this method terminates the process
def run_recv_queue(args, stdout_queue, control_conn, results_queue):
if args.verbosity:
stdout_queue.put("starting control receiver process: run_recv_queue")
while True:
try:
# blocking
bytes_read = control_conn.recv_a_d_block()
except ConnectionResetError:
if args.verbosity:
stdout_queue.put("connection reset error")
# exit process
break
except PeerDisconnectedException:
if args.verbosity:
stdout_queue.put("peer disconnected (control socket)")
# exit process
break
received_str = bytes_read.decode()
# passthru as is
results_queue.put(received_str)
control_conn.close()
if args.verbosity:
stdout_queue.put("exiting control receiver process: run_recv_queue")