dejsem.1.5/python/dejsem.pycharm/main.py
author hh
Wed, 27 Nov 2019 09:50:16 +0100
changeset 0 676905a3b03c
permissions -rwxr-xr-x
--
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
hh
parents:
diff changeset
     1
#!/usr/bin/python3
hh
parents:
diff changeset
     2
# coding=utf8
hh
parents:
diff changeset
     3
hh
parents:
diff changeset
     4
# hal.hh.cz
hh
parents:
diff changeset
     5
#	/usr/local/bin/dejsem.py
hh
parents:
diff changeset
     6
#	/usr/local/dejsem/ssl
hh
parents:
diff changeset
     7
#
hh
parents:
diff changeset
     8
# FVWM shotcuts	Ctrl-Alt-B	Ctrl-Alt-C	Ctrl-Alt-V
hh
parents:
diff changeset
     9
# Key B	   A   CM  Exec ACT=PUSHCLIP CHAN=N dejsem.py	 # copy local  --> shared clipboard
hh
parents:
diff changeset
    10
# Key C	   A   CM  Exec ACT=PUSHCLIP CHAN=N dejsem.py	 # copy local  --> shared clipboard
hh
parents:
diff changeset
    11
# Key V	   A   CM  Exec ACT=PULLCLIP CHAN=N dejsem.py	 # copy shared --> local  clipboard
hh
parents:
diff changeset
    12
#
hh
parents:
diff changeset
    13
# server side
hh
parents:
diff changeset
    14
#	● akceptuje cmd-connection na základním portu kanálu a přijímá z ní příkazy
hh
parents:
diff changeset
    15
#	● po provedení příkazu
hh
parents:
diff changeset
    16
#		PULLCLIP
hh
parents:
diff changeset
    17
#		PULLHIST
hh
parents:
diff changeset
    18
#		PUSHCLIP
hh
parents:
diff changeset
    19
#		GETPEER
hh
parents:
diff changeset
    20
#		SETPEER
hh
parents:
diff changeset
    21
#		EXPOSE
hh
parents:
diff changeset
    22
#		EXPOSEUP
hh
parents:
diff changeset
    23
#		FREE
hh
parents:
diff changeset
    24
#		LONGTASK 
hh
parents:
diff changeset
    25
#	  se connection uzavře
hh
parents:
diff changeset
    26
#	● po provedení příkazu
hh
parents:
diff changeset
    27
#		PULLFILE
hh
parents:
diff changeset
    28
#		PUSHFILE
hh
parents:
diff changeset
    29
#		PULLLIST
hh
parents:
diff changeset
    30
#		MOVE
hh
parents:
diff changeset
    31
#		DELETE
hh
parents:
diff changeset
    32
#		CREATDIR
hh
parents:
diff changeset
    33
#		RECKON
hh
parents:
diff changeset
    34
#	  zůstává connection otevřená a pokračuje čtením dalšího příkazu, protože tyto příkazy mohou být dávkové
hh
parents:
diff changeset
    35
# timeouts
hh
parents:
diff changeset
    36
#	conn_TO				connection retry wait TO - wait before next connect try (try <connThreshold> times)
hh
parents:
diff changeset
    37
#	block_TO			blocking net operations TO
hh
parents:
diff changeset
    38
#	long_run_accept_TO	accept TO on ports binded dynamicaly for long duration operations
hh
parents:
diff changeset
    39
#	peer_accept_TO		accept TO waiting for connection from peer when receiving peer files (PULLPEER)
hh
parents:
diff changeset
    40
hh
parents:
diff changeset
    41
import sys, os, random, time, signal
hh
parents:
diff changeset
    42
hh
parents:
diff changeset
    43
def stop(sign, frame):
hh
parents:
diff changeset
    44
	for pid in pids:
hh
parents:
diff changeset
    45
		os.kill(pid, signal.SIGTERM)
hh
parents:
diff changeset
    46
hh
parents:
diff changeset
    47
pids = set()	# seznam subthreads pro účely mimořádného ukončení
hh
parents:
diff changeset
    48
hh
parents:
diff changeset
    49
if __name__ == '__main__':
hh
parents:
diff changeset
    50
	from parms import Parms
hh
parents:
diff changeset
    51
	Parms.setup()
hh
parents:
diff changeset
    52
	random.seed(Parms.random_seed) if Parms.random_seed else random.seed()
hh
parents:
diff changeset
    53
hh
parents:
diff changeset
    54
	from d import D
hh
parents:
diff changeset
    55
	D.t0 = time.time()
hh
parents:
diff changeset
    56
	d = D(Parms.applName)
hh
parents:
diff changeset
    57
	d.log("{}, ver. {:.2f}".format(sys.argv[0], Parms.version), sev=1)
hh
parents:
diff changeset
    58
hh
parents:
diff changeset
    59
	if Parms.action == 'SRV':
hh
parents:
diff changeset
    60
		from server import Server
hh
parents:
diff changeset
    61
		pid = os.fork()
hh
parents:
diff changeset
    62
		if not pid:		# child
hh
parents:
diff changeset
    63
			from meter import Meter
hh
parents:
diff changeset
    64
			Meter(d).run()
hh
parents:
diff changeset
    65
			sys.exit(0)
hh
parents:
diff changeset
    66
		else:			# parent
hh
parents:
diff changeset
    67
			pids.add(pid)
hh
parents:
diff changeset
    68
			d.log("Meter spawned in process {}".format(pid), sev=1)
hh
parents:
diff changeset
    69
		for chan in range(1, 99):
hh
parents:
diff changeset
    70
			if "{:02d}".format(chan) in os.listdir(Parms.srv_homedir):
hh
parents:
diff changeset
    71
				pid = os.fork()
hh
parents:
diff changeset
    72
				if not pid:		# child
hh
parents:
diff changeset
    73
					Server(d, chan)
hh
parents:
diff changeset
    74
					sys.exit(0)
hh
parents:
diff changeset
    75
				else:			# parent
hh
parents:
diff changeset
    76
					pids.add(pid)
hh
parents:
diff changeset
    77
					d.log("server node SSL {:02d} started in process {}".format(chan, pid), sev=4)
hh
parents:
diff changeset
    78
		d.log("all server nodes spawned", sev=1)
hh
parents:
diff changeset
    79
		signal.signal(signal.SIGINT, stop)
hh
parents:
diff changeset
    80
		signal.signal(signal.SIGTERM, stop)
hh
parents:
diff changeset
    81
		signal.pthread_sigmask(signal.SIG_UNBLOCK, {signal.SIGINT, signal.SIGTERM})
hh
parents:
diff changeset
    82
		signal.pause()
hh
parents:
diff changeset
    83
		d.log("KeyboardInterrupt")
hh
parents:
diff changeset
    84
	else:
hh
parents:
diff changeset
    85
		from client import Client
hh
parents:
diff changeset
    86
		Client(d)