cgse 2023.38.0__py3-none-any.whl → 2024.1.3__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (653) hide show
  1. README.md +27 -0
  2. bump.py +77 -0
  3. cgse-2024.1.3.dist-info/METADATA +41 -0
  4. cgse-2024.1.3.dist-info/RECORD +5 -0
  5. {cgse-2023.38.0.dist-info → cgse-2024.1.3.dist-info}/WHEEL +1 -2
  6. cgse-2023.38.0.dist-info/COPYING +0 -674
  7. cgse-2023.38.0.dist-info/COPYING.LESSER +0 -165
  8. cgse-2023.38.0.dist-info/METADATA +0 -144
  9. cgse-2023.38.0.dist-info/RECORD +0 -649
  10. cgse-2023.38.0.dist-info/entry_points.txt +0 -75
  11. cgse-2023.38.0.dist-info/top_level.txt +0 -2
  12. egse/__init__.py +0 -12
  13. egse/__main__.py +0 -32
  14. egse/aeu/aeu.py +0 -5235
  15. egse/aeu/aeu_awg.yaml +0 -265
  16. egse/aeu/aeu_crio.yaml +0 -273
  17. egse/aeu/aeu_cs.py +0 -626
  18. egse/aeu/aeu_devif.py +0 -321
  19. egse/aeu/aeu_main_ui.py +0 -912
  20. egse/aeu/aeu_metrics.py +0 -131
  21. egse/aeu/aeu_protocol.py +0 -463
  22. egse/aeu/aeu_psu.yaml +0 -204
  23. egse/aeu/aeu_ui.py +0 -873
  24. egse/aeu/arbdata/FccdRead.arb +0 -2
  25. egse/aeu/arbdata/FccdRead_min_points.arb +0 -2
  26. egse/aeu/arbdata/HeaterSync_FccdRead.arb +0 -2
  27. egse/aeu/arbdata/HeaterSync_ccdRead25.arb +0 -2
  28. egse/aeu/arbdata/HeaterSync_ccdRead31_25.arb +0 -2
  29. egse/aeu/arbdata/HeaterSync_ccdRead37_50.arb +0 -2
  30. egse/aeu/arbdata/HeaterSync_ccdRead43_75.arb +0 -2
  31. egse/aeu/arbdata/HeaterSync_ccdRead50.arb +0 -2
  32. egse/aeu/arbdata/Heater_FccdRead_min_points.arb +0 -2
  33. egse/aeu/arbdata/ccdRead25.arb +0 -2
  34. egse/aeu/arbdata/ccdRead25_150ms.arb +0 -2
  35. egse/aeu/arbdata/ccdRead31_25.arb +0 -2
  36. egse/aeu/arbdata/ccdRead31_25_150ms.arb +0 -2
  37. egse/aeu/arbdata/ccdRead37_50.arb +0 -2
  38. egse/aeu/arbdata/ccdRead37_50_150ms.arb +0 -2
  39. egse/aeu/arbdata/ccdRead43_75.arb +0 -2
  40. egse/aeu/arbdata/ccdRead43_75_150ms.arb +0 -2
  41. egse/aeu/arbdata/ccdRead50.arb +0 -2
  42. egse/aeu/arbdata/ccdRead50_150ms.arb +0 -2
  43. egse/alert/__init__.py +0 -1049
  44. egse/alert/alertman.yaml +0 -37
  45. egse/alert/alertman_cs.py +0 -234
  46. egse/alert/alertman_ui.py +0 -603
  47. egse/alert/gsm/beaglebone.py +0 -138
  48. egse/alert/gsm/beaglebone.yaml +0 -51
  49. egse/alert/gsm/beaglebone_cs.py +0 -108
  50. egse/alert/gsm/beaglebone_devif.py +0 -130
  51. egse/alert/gsm/beaglebone_protocol.py +0 -48
  52. egse/bits.py +0 -318
  53. egse/camera.py +0 -44
  54. egse/collimator/__init__.py +0 -0
  55. egse/collimator/fcul/__init__.py +0 -0
  56. egse/collimator/fcul/ogse.py +0 -1077
  57. egse/collimator/fcul/ogse.yaml +0 -14
  58. egse/collimator/fcul/ogse_cs.py +0 -154
  59. egse/collimator/fcul/ogse_devif.py +0 -358
  60. egse/collimator/fcul/ogse_protocol.py +0 -129
  61. egse/collimator/fcul/ogse_sim.py +0 -431
  62. egse/collimator/fcul/ogse_ui.py +0 -1108
  63. egse/command.py +0 -699
  64. egse/config.py +0 -410
  65. egse/confman/__init__.py +0 -1015
  66. egse/confman/confman.yaml +0 -67
  67. egse/confman/confman_cs.py +0 -239
  68. egse/confman/confman_ui.py +0 -381
  69. egse/confman/setup_ui.py +0 -565
  70. egse/control.py +0 -442
  71. egse/coordinates/__init__.py +0 -531
  72. egse/coordinates/avoidance.py +0 -103
  73. egse/coordinates/cslmodel.py +0 -127
  74. egse/coordinates/laser_tracker_to_dict.py +0 -120
  75. egse/coordinates/point.py +0 -707
  76. egse/coordinates/pyplot.py +0 -195
  77. egse/coordinates/referenceFrame.py +0 -1279
  78. egse/coordinates/refmodel.py +0 -737
  79. egse/coordinates/rotationMatrix.py +0 -85
  80. egse/coordinates/transform3d_addon.py +0 -419
  81. egse/csl/__init__.py +0 -50
  82. egse/csl/commanding.py +0 -78
  83. egse/csl/icons/hexapod-connected-selected.svg +0 -30
  84. egse/csl/icons/hexapod-connected.svg +0 -30
  85. egse/csl/icons/hexapod-homing-selected.svg +0 -68
  86. egse/csl/icons/hexapod-homing.svg +0 -68
  87. egse/csl/icons/hexapod-retract-selected.svg +0 -56
  88. egse/csl/icons/hexapod-retract.svg +0 -51
  89. egse/csl/icons/hexapod-zero-selected.svg +0 -56
  90. egse/csl/icons/hexapod-zero.svg +0 -56
  91. egse/csl/icons/logo-puna.svg +0 -92
  92. egse/csl/icons/stop.svg +0 -1
  93. egse/csl/initialisation.py +0 -102
  94. egse/csl/mech_pos_settings.yaml +0 -18
  95. egse/das.py +0 -1247
  96. egse/das.yaml +0 -7
  97. egse/data/conf/SETUP_CSL_00000_170620_150000.yaml +0 -5
  98. egse/data/conf/SETUP_CSL_00001_170620_151010.yaml +0 -69
  99. egse/data/conf/SETUP_CSL_00002_170620_151020.yaml +0 -69
  100. egse/data/conf/SETUP_CSL_00003_170620_151030.yaml +0 -69
  101. egse/data/conf/SETUP_CSL_00004_170620_151040.yaml +0 -69
  102. egse/data/conf/SETUP_CSL_00005_170620_151050.yaml +0 -69
  103. egse/data/conf/SETUP_CSL_00006_170620_151060.yaml +0 -69
  104. egse/data/conf/SETUP_CSL_00007_170620_151070.yaml +0 -69
  105. egse/data/conf/SETUP_CSL_00008_170620_151080.yaml +0 -75
  106. egse/data/conf/SETUP_CSL_00010_210308_083016.yaml +0 -138
  107. egse/data/conf/SETUP_INTA_00000_170620_150000.yaml +0 -4
  108. egse/data/conf/SETUP_SRON_00000_170620_150000.yaml +0 -4
  109. egse/decorators.py +0 -415
  110. egse/device.py +0 -269
  111. egse/dpu/__init__.py +0 -2681
  112. egse/dpu/ccd_ui.py +0 -508
  113. egse/dpu/dpu.py +0 -786
  114. egse/dpu/dpu.yaml +0 -153
  115. egse/dpu/dpu_cs.py +0 -272
  116. egse/dpu/dpu_ui.py +0 -668
  117. egse/dpu/fitsgen.py +0 -2077
  118. egse/dpu/fitsgen_test.py +0 -752
  119. egse/dpu/fitsgen_ui.py +0 -399
  120. egse/dpu/hdf5_model.py +0 -332
  121. egse/dpu/hdf5_ui.py +0 -277
  122. egse/dpu/hdf5_viewer.py +0 -506
  123. egse/dpu/hk_ui.py +0 -468
  124. egse/dpu_commands.py +0 -81
  125. egse/dsi/constants.py +0 -220
  126. egse/dsi/esl.py +0 -870
  127. egse/dsi/rmap.py +0 -1042
  128. egse/dsi/rmapci.py +0 -37
  129. egse/dsi/spw.py +0 -154
  130. egse/dsi/spw_state.py +0 -29
  131. egse/dummy.py +0 -258
  132. egse/dyndummy.py +0 -179
  133. egse/env.py +0 -278
  134. egse/exceptions.py +0 -88
  135. egse/fdir/__init__.py +0 -28
  136. egse/fdir/fdir_manager.py +0 -85
  137. egse/fdir/fdir_manager.yaml +0 -51
  138. egse/fdir/fdir_manager_controller.py +0 -228
  139. egse/fdir/fdir_manager_cs.py +0 -164
  140. egse/fdir/fdir_manager_interface.py +0 -25
  141. egse/fdir/fdir_remote.py +0 -73
  142. egse/fdir/fdir_remote.yaml +0 -37
  143. egse/fdir/fdir_remote_controller.py +0 -50
  144. egse/fdir/fdir_remote_cs.py +0 -97
  145. egse/fdir/fdir_remote_interface.py +0 -14
  146. egse/fdir/fdir_remote_popup.py +0 -31
  147. egse/fee/__init__.py +0 -114
  148. egse/fee/f_fee_register.yaml +0 -43
  149. egse/fee/fee.py +0 -631
  150. egse/fee/feesim.py +0 -750
  151. egse/fee/n_fee_hk.py +0 -761
  152. egse/fee/nfee.py +0 -187
  153. egse/filterwheel/__init__.py +0 -4
  154. egse/filterwheel/eksma/__init__.py +0 -24
  155. egse/filterwheel/eksma/fw8smc4.py +0 -661
  156. egse/filterwheel/eksma/fw8smc4.yaml +0 -121
  157. egse/filterwheel/eksma/fw8smc4_cs.py +0 -144
  158. egse/filterwheel/eksma/fw8smc4_devif.py +0 -473
  159. egse/filterwheel/eksma/fw8smc4_protocol.py +0 -81
  160. egse/filterwheel/eksma/fw8smc4_ui.py +0 -940
  161. egse/filterwheel/eksma/fw8smc5.py +0 -111
  162. egse/filterwheel/eksma/fw8smc5.yaml +0 -105
  163. egse/filterwheel/eksma/fw8smc5_controller.py +0 -307
  164. egse/filterwheel/eksma/fw8smc5_cs.py +0 -141
  165. egse/filterwheel/eksma/fw8smc5_interface.py +0 -65
  166. egse/filterwheel/eksma/fw8smc5_simulator.py +0 -29
  167. egse/filterwheel/eksma/fw8smc5_ui.py +0 -1068
  168. egse/filterwheel/eksma/testpythonfw.py +0 -215
  169. egse/fov/__init__.py +0 -65
  170. egse/fov/fov_hk.py +0 -712
  171. egse/fov/fov_ui.py +0 -861
  172. egse/fov/fov_ui_controller.py +0 -140
  173. egse/fov/fov_ui_model.py +0 -200
  174. egse/fov/fov_ui_view.py +0 -345
  175. egse/gimbal/__init__.py +0 -32
  176. egse/gimbal/symetrie/__init__.py +0 -26
  177. egse/gimbal/symetrie/alpha.py +0 -586
  178. egse/gimbal/symetrie/generic_gimbal_ui.py +0 -1521
  179. egse/gimbal/symetrie/gimbal.py +0 -877
  180. egse/gimbal/symetrie/gimbal.yaml +0 -168
  181. egse/gimbal/symetrie/gimbal_cs.py +0 -183
  182. egse/gimbal/symetrie/gimbal_protocol.py +0 -135
  183. egse/gimbal/symetrie/gimbal_ui.py +0 -361
  184. egse/gimbal/symetrie/pmac.py +0 -1006
  185. egse/gimbal/symetrie/pmac_regex.py +0 -83
  186. egse/graph.py +0 -132
  187. egse/gui/__init__.py +0 -47
  188. egse/gui/buttons.py +0 -378
  189. egse/gui/focalplane.py +0 -1281
  190. egse/gui/formatter.py +0 -10
  191. egse/gui/led.py +0 -162
  192. egse/gui/limitswitch.py +0 -143
  193. egse/gui/mechanisms.py +0 -588
  194. egse/gui/states.py +0 -148
  195. egse/gui/stripchart.py +0 -729
  196. egse/gui/switch.py +0 -112
  197. egse/h5.py +0 -274
  198. egse/help/__init__.py +0 -0
  199. egse/help/help_ui.py +0 -126
  200. egse/hexapod/__init__.py +0 -32
  201. egse/hexapod/symetrie/__init__.py +0 -138
  202. egse/hexapod/symetrie/alpha.py +0 -874
  203. egse/hexapod/symetrie/dynalpha.py +0 -1387
  204. egse/hexapod/symetrie/hexapod_ui.py +0 -1516
  205. egse/hexapod/symetrie/pmac.py +0 -1010
  206. egse/hexapod/symetrie/pmac_regex.py +0 -83
  207. egse/hexapod/symetrie/puna.py +0 -1167
  208. egse/hexapod/symetrie/puna.yaml +0 -193
  209. egse/hexapod/symetrie/puna_cs.py +0 -196
  210. egse/hexapod/symetrie/puna_protocol.py +0 -131
  211. egse/hexapod/symetrie/puna_ui.py +0 -434
  212. egse/hexapod/symetrie/punaplus.py +0 -107
  213. egse/hexapod/symetrie/zonda.py +0 -872
  214. egse/hexapod/symetrie/zonda.yaml +0 -337
  215. egse/hexapod/symetrie/zonda_cs.py +0 -172
  216. egse/hexapod/symetrie/zonda_devif.py +0 -415
  217. egse/hexapod/symetrie/zonda_protocol.py +0 -119
  218. egse/hexapod/symetrie/zonda_ui.py +0 -449
  219. egse/hk.py +0 -765
  220. egse/icons/aeu-cs-start.svg +0 -117
  221. egse/icons/aeu-cs-stop.svg +0 -118
  222. egse/icons/aeu-cs.svg +0 -107
  223. egse/icons/aeu_cs-started.svg +0 -112
  224. egse/icons/aeu_cs-stopped.svg +0 -112
  225. egse/icons/aeu_cs.svg +0 -55
  226. egse/icons/alert.svg +0 -1
  227. egse/icons/arrow-double-left.png +0 -0
  228. egse/icons/arrow-double-right.png +0 -0
  229. egse/icons/arrow-up.svg +0 -11
  230. egse/icons/backward.svg +0 -1
  231. egse/icons/busy.svg +0 -1
  232. egse/icons/cleaning.svg +0 -115
  233. egse/icons/color-scheme.svg +0 -1
  234. egse/icons/cs-connected-alert.svg +0 -91
  235. egse/icons/cs-connected-disabled.svg +0 -43
  236. egse/icons/cs-connected.svg +0 -89
  237. egse/icons/cs-not-connected.svg +0 -44
  238. egse/icons/double-left-arrow.svg +0 -1
  239. egse/icons/double-right-arrow.svg +0 -1
  240. egse/icons/erase-disabled.svg +0 -19
  241. egse/icons/erase.svg +0 -59
  242. egse/icons/fitsgen-start.svg +0 -47
  243. egse/icons/fitsgen-stop.svg +0 -48
  244. egse/icons/fitsgen.svg +0 -1
  245. egse/icons/forward.svg +0 -1
  246. egse/icons/fov-hk-start.svg +0 -33
  247. egse/icons/fov-hk-stop.svg +0 -37
  248. egse/icons/fov-hk.svg +0 -1
  249. egse/icons/front-desk.svg +0 -1
  250. egse/icons/home-actioned.svg +0 -15
  251. egse/icons/home-disabled.svg +0 -15
  252. egse/icons/home.svg +0 -13
  253. egse/icons/info.svg +0 -1
  254. egse/icons/invalid.png +0 -0
  255. egse/icons/led-green.svg +0 -20
  256. egse/icons/led-grey.svg +0 -20
  257. egse/icons/led-orange.svg +0 -20
  258. egse/icons/led-red.svg +0 -20
  259. egse/icons/led-square-green.svg +0 -134
  260. egse/icons/led-square-grey.svg +0 -134
  261. egse/icons/led-square-orange.svg +0 -134
  262. egse/icons/led-square-red.svg +0 -134
  263. egse/icons/limit-switch-all-green.svg +0 -115
  264. egse/icons/limit-switch-all-red.svg +0 -117
  265. egse/icons/limit-switch-el+.svg +0 -116
  266. egse/icons/limit-switch-el-.svg +0 -117
  267. egse/icons/location-marker.svg +0 -1
  268. egse/icons/logo-dpu.svg +0 -48
  269. egse/icons/logo-gimbal.svg +0 -112
  270. egse/icons/logo-huber.svg +0 -23
  271. egse/icons/logo-ogse.svg +0 -31
  272. egse/icons/logo-puna.svg +0 -92
  273. egse/icons/logo-tcs.svg +0 -29
  274. egse/icons/logo-zonda.svg +0 -66
  275. egse/icons/maximize.svg +0 -1
  276. egse/icons/meter.svg +0 -1
  277. egse/icons/more.svg +0 -45
  278. egse/icons/n-fee-hk-start.svg +0 -24
  279. egse/icons/n-fee-hk-stop.svg +0 -25
  280. egse/icons/n-fee-hk.svg +0 -83
  281. egse/icons/observing-off.svg +0 -46
  282. egse/icons/observing-on.svg +0 -46
  283. egse/icons/open-document-hdf5.png +0 -0
  284. egse/icons/open-document-hdf5.svg +0 -21
  285. egse/icons/ops-mode.svg +0 -1
  286. egse/icons/play-green.svg +0 -17
  287. egse/icons/plugged-disabled.svg +0 -27
  288. egse/icons/plugged.svg +0 -21
  289. egse/icons/pm_ui.svg +0 -1
  290. egse/icons/power-button-green.svg +0 -27
  291. egse/icons/power-button-red.svg +0 -27
  292. egse/icons/power-button.svg +0 -27
  293. egse/icons/radar.svg +0 -1
  294. egse/icons/radioactive.svg +0 -2
  295. egse/icons/reload.svg +0 -1
  296. egse/icons/remote-control-off.svg +0 -28
  297. egse/icons/remote-control-on.svg +0 -28
  298. egse/icons/repeat-blue.svg +0 -15
  299. egse/icons/repeat.svg +0 -1
  300. egse/icons/settings.svg +0 -1
  301. egse/icons/shrink.svg +0 -1
  302. egse/icons/shutter.svg +0 -1
  303. egse/icons/sign-off.svg +0 -1
  304. egse/icons/sign-on.svg +0 -1
  305. egse/icons/sim-mode.svg +0 -1
  306. egse/icons/small-buttons-go.svg +0 -20
  307. egse/icons/small-buttons-minus.svg +0 -51
  308. egse/icons/small-buttons-plus.svg +0 -51
  309. egse/icons/sponge.svg +0 -220
  310. egse/icons/start-button-disabled.svg +0 -84
  311. egse/icons/start-button.svg +0 -50
  312. egse/icons/stop-button-disabled.svg +0 -84
  313. egse/icons/stop-button.svg +0 -50
  314. egse/icons/stop-red.svg +0 -17
  315. egse/icons/stop.svg +0 -1
  316. egse/icons/switch-disabled-square.svg +0 -87
  317. egse/icons/switch-disabled.svg +0 -15
  318. egse/icons/switch-off-square.svg +0 -87
  319. egse/icons/switch-off.svg +0 -72
  320. egse/icons/switch-on-square.svg +0 -87
  321. egse/icons/switch-on.svg +0 -61
  322. egse/icons/temperature-control.svg +0 -44
  323. egse/icons/th_ui_logo.svg +0 -1
  324. egse/icons/unplugged.svg +0 -23
  325. egse/icons/unvalid.png +0 -0
  326. egse/icons/user-interface.svg +0 -1
  327. egse/icons/vacuum.svg +0 -1
  328. egse/icons/valid.png +0 -0
  329. egse/icons/zoom-to-pixel-dark.svg +0 -64
  330. egse/icons/zoom-to-pixel-white.svg +0 -36
  331. egse/images/big-rotation-stage.png +0 -0
  332. egse/images/connected-100.png +0 -0
  333. egse/images/cross.svg +0 -6
  334. egse/images/disconnected-100.png +0 -0
  335. egse/images/gui-icon.png +0 -0
  336. egse/images/home.svg +0 -6
  337. egse/images/info-icon.png +0 -0
  338. egse/images/led-black.svg +0 -89
  339. egse/images/led-green.svg +0 -85
  340. egse/images/led-orange.svg +0 -85
  341. egse/images/led-red.svg +0 -85
  342. egse/images/load-icon.png +0 -0
  343. egse/images/load-setup.png +0 -0
  344. egse/images/load.png +0 -0
  345. egse/images/pause.png +0 -0
  346. egse/images/play-button.svg +0 -8
  347. egse/images/play.png +0 -0
  348. egse/images/process-status.png +0 -0
  349. egse/images/restart.png +0 -0
  350. egse/images/search.png +0 -0
  351. egse/images/sma.png +0 -0
  352. egse/images/start.png +0 -0
  353. egse/images/stop-button.svg +0 -8
  354. egse/images/stop.png +0 -0
  355. egse/images/switch-off.svg +0 -48
  356. egse/images/switch-on.svg +0 -48
  357. egse/images/undo.png +0 -0
  358. egse/images/update-button.svg +0 -11
  359. egse/imageviewer/exposureselection.py +0 -475
  360. egse/imageviewer/imageviewer.py +0 -198
  361. egse/imageviewer/matchfocalplane.py +0 -179
  362. egse/imageviewer/subfieldposition.py +0 -133
  363. egse/lampcontrol/__init__.py +0 -4
  364. egse/lampcontrol/beaglebone/beaglebone.py +0 -178
  365. egse/lampcontrol/beaglebone/beaglebone.yaml +0 -62
  366. egse/lampcontrol/beaglebone/beaglebone_cs.py +0 -106
  367. egse/lampcontrol/beaglebone/beaglebone_devif.py +0 -150
  368. egse/lampcontrol/beaglebone/beaglebone_protocol.py +0 -73
  369. egse/lampcontrol/energetiq/__init__.py +0 -22
  370. egse/lampcontrol/energetiq/eq99.yaml +0 -98
  371. egse/lampcontrol/energetiq/lampEQ99.py +0 -283
  372. egse/lampcontrol/energetiq/lampEQ99_cs.py +0 -128
  373. egse/lampcontrol/energetiq/lampEQ99_devif.py +0 -158
  374. egse/lampcontrol/energetiq/lampEQ99_encode_decode_errors.py +0 -73
  375. egse/lampcontrol/energetiq/lampEQ99_protocol.py +0 -69
  376. egse/lampcontrol/energetiq/lampEQ99_ui.py +0 -465
  377. egse/lib/CentOS-7/EtherSpaceLink_v34_86.dylib +0 -0
  378. egse/lib/CentOS-8/ESL-RMAP_v34_86.dylib +0 -0
  379. egse/lib/CentOS-8/EtherSpaceLink_v34_86.dylib +0 -0
  380. egse/lib/Debian/ESL-RMAP_v34_86.dylib +0 -0
  381. egse/lib/Debian/EtherSpaceLink_v34_86.dylib +0 -0
  382. egse/lib/Debian/libetherspacelink_v35_21.dylib +0 -0
  383. egse/lib/Linux/ESL-RMAP_v34_86.dylib +0 -0
  384. egse/lib/Linux/EtherSpaceLink_v34_86.dylib +0 -0
  385. egse/lib/Ubuntu-20/ESL-RMAP_v34_86.dylib +0 -0
  386. egse/lib/Ubuntu-20/EtherSpaceLink_v34_86.dylib +0 -0
  387. egse/lib/gssw/python3-gssw_2.2.3+31f63c9f-1_all.deb +0 -0
  388. egse/lib/macOS/ESL-RMAP_v34_86.dylib +0 -0
  389. egse/lib/macOS/EtherSpaceLink_v34_86.dylib +0 -0
  390. egse/lib/ximc/__pycache__/pyximc.cpython-38 2.pyc +0 -0
  391. egse/lib/ximc/__pycache__/pyximc.cpython-38.pyc +0 -0
  392. egse/lib/ximc/libximc.framework/Frameworks/libbindy.dylib +0 -0
  393. egse/lib/ximc/libximc.framework/Frameworks/libxiwrapper.dylib +0 -0
  394. egse/lib/ximc/libximc.framework/Headers/ximc.h +0 -5510
  395. egse/lib/ximc/libximc.framework/Resources/Info.plist +0 -42
  396. egse/lib/ximc/libximc.framework/Resources/keyfile.sqlite +0 -0
  397. egse/lib/ximc/libximc.framework/libbindy.so +0 -0
  398. egse/lib/ximc/libximc.framework/libximc +0 -0
  399. egse/lib/ximc/libximc.framework/libximc.so +0 -0
  400. egse/lib/ximc/libximc.framework/libximc.so.7.0.0 +0 -0
  401. egse/lib/ximc/libximc.framework/libxiwrapper.so +0 -0
  402. egse/lib/ximc/pyximc.py +0 -922
  403. egse/listener.py +0 -73
  404. egse/logger/__init__.py +0 -243
  405. egse/logger/log_cs.py +0 -321
  406. egse/metrics.py +0 -98
  407. egse/mixin.py +0 -464
  408. egse/monitoring.py +0 -95
  409. egse/ni/alarms/__init__.py +0 -26
  410. egse/ni/alarms/cdaq9375.py +0 -300
  411. egse/ni/alarms/cdaq9375.yaml +0 -89
  412. egse/ni/alarms/cdaq9375_cs.py +0 -130
  413. egse/ni/alarms/cdaq9375_devif.py +0 -183
  414. egse/ni/alarms/cdaq9375_protocol.py +0 -48
  415. egse/obs_inspection.py +0 -163
  416. egse/observer.py +0 -41
  417. egse/obsid.py +0 -163
  418. egse/powermeter/__init__.py +0 -0
  419. egse/powermeter/ni/__init__.py +0 -38
  420. egse/powermeter/ni/cdaq9184.py +0 -224
  421. egse/powermeter/ni/cdaq9184.yaml +0 -73
  422. egse/powermeter/ni/cdaq9184_cs.py +0 -130
  423. egse/powermeter/ni/cdaq9184_devif.py +0 -201
  424. egse/powermeter/ni/cdaq9184_protocol.py +0 -48
  425. egse/powermeter/ni/cdaq9184_ui.py +0 -544
  426. egse/powermeter/thorlabs/__init__.py +0 -25
  427. egse/powermeter/thorlabs/pm100a.py +0 -380
  428. egse/powermeter/thorlabs/pm100a.yaml +0 -132
  429. egse/powermeter/thorlabs/pm100a_cs.py +0 -136
  430. egse/powermeter/thorlabs/pm100a_devif.py +0 -127
  431. egse/powermeter/thorlabs/pm100a_protocol.py +0 -80
  432. egse/powermeter/thorlabs/pm100a_ui.py +0 -725
  433. egse/process.py +0 -451
  434. egse/procman/__init__.py +0 -811
  435. egse/procman/cannot_start_process_popup.py +0 -43
  436. egse/procman/procman.yaml +0 -49
  437. egse/procman/procman_cs.py +0 -201
  438. egse/procman/procman_ui.py +0 -2081
  439. egse/protocol.py +0 -603
  440. egse/proxy.py +0 -522
  441. egse/randomwalk.py +0 -140
  442. egse/reg.py +0 -585
  443. egse/reload.py +0 -122
  444. egse/reprocess.py +0 -675
  445. egse/resource.py +0 -333
  446. egse/rst.py +0 -135
  447. egse/search.py +0 -182
  448. egse/serialdevice.py +0 -190
  449. egse/services.py +0 -212
  450. egse/services.yaml +0 -51
  451. egse/settings.py +0 -379
  452. egse/settings.yaml +0 -980
  453. egse/setup.py +0 -1180
  454. egse/shutter/__init__.py +0 -0
  455. egse/shutter/thorlabs/__init__.py +0 -19
  456. egse/shutter/thorlabs/ksc101.py +0 -205
  457. egse/shutter/thorlabs/ksc101.yaml +0 -105
  458. egse/shutter/thorlabs/ksc101_cs.py +0 -136
  459. egse/shutter/thorlabs/ksc101_devif.py +0 -201
  460. egse/shutter/thorlabs/ksc101_protocol.py +0 -69
  461. egse/shutter/thorlabs/ksc101_ui.py +0 -548
  462. egse/shutter/thorlabs/sc10.py +0 -82
  463. egse/shutter/thorlabs/sc10.yaml +0 -52
  464. egse/shutter/thorlabs/sc10_controller.py +0 -81
  465. egse/shutter/thorlabs/sc10_cs.py +0 -108
  466. egse/shutter/thorlabs/sc10_interface.py +0 -25
  467. egse/shutter/thorlabs/sc10_simulator.py +0 -30
  468. egse/simulator.py +0 -41
  469. egse/slack.py +0 -61
  470. egse/socketdevice.py +0 -218
  471. egse/sockets.py +0 -218
  472. egse/spw.py +0 -1479
  473. egse/stages/__init__.py +0 -12
  474. egse/stages/aerotech/ensemble.py +0 -247
  475. egse/stages/aerotech/ensemble.yaml +0 -205
  476. egse/stages/aerotech/ensemble_controller.py +0 -275
  477. egse/stages/aerotech/ensemble_cs.py +0 -110
  478. egse/stages/aerotech/ensemble_interface.py +0 -132
  479. egse/stages/aerotech/ensemble_parameters.py +0 -433
  480. egse/stages/aerotech/ensemble_simulator.py +0 -27
  481. egse/stages/aerotech/mgse_sim.py +0 -193
  482. egse/stages/arun/smd3.py +0 -111
  483. egse/stages/arun/smd3.yaml +0 -68
  484. egse/stages/arun/smd3_controller.py +0 -472
  485. egse/stages/arun/smd3_cs.py +0 -112
  486. egse/stages/arun/smd3_interface.py +0 -53
  487. egse/stages/arun/smd3_simulator.py +0 -27
  488. egse/stages/arun/smd3_stop.py +0 -16
  489. egse/stages/huber/__init__.py +0 -49
  490. egse/stages/huber/smc9300.py +0 -904
  491. egse/stages/huber/smc9300.yaml +0 -63
  492. egse/stages/huber/smc9300_cs.py +0 -178
  493. egse/stages/huber/smc9300_devif.py +0 -345
  494. egse/stages/huber/smc9300_protocol.py +0 -111
  495. egse/stages/huber/smc9300_sim.py +0 -547
  496. egse/stages/huber/smc9300_ui.py +0 -973
  497. egse/state.py +0 -173
  498. egse/statemachine.py +0 -274
  499. egse/storage/__init__.py +0 -1004
  500. egse/storage/persistence.py +0 -2295
  501. egse/storage/storage.yaml +0 -72
  502. egse/storage/storage_cs.py +0 -214
  503. egse/styles/dark.qss +0 -343
  504. egse/styles/default.qss +0 -48
  505. egse/synoptics/__init__.py +0 -412
  506. egse/synoptics/syn.yaml +0 -9
  507. egse/synoptics/syn_cs.py +0 -195
  508. egse/system.py +0 -1408
  509. egse/tcs/__init__.py +0 -14
  510. egse/tcs/tcs.py +0 -874
  511. egse/tcs/tcs.yaml +0 -14
  512. egse/tcs/tcs_cs.py +0 -202
  513. egse/tcs/tcs_devif.py +0 -292
  514. egse/tcs/tcs_protocol.py +0 -177
  515. egse/tcs/tcs_sim.py +0 -177
  516. egse/tcs/tcs_ui.py +0 -543
  517. egse/tdms.py +0 -171
  518. egse/tempcontrol/__init__.py +0 -23
  519. egse/tempcontrol/agilent/agilent34970.py +0 -109
  520. egse/tempcontrol/agilent/agilent34970.yaml +0 -44
  521. egse/tempcontrol/agilent/agilent34970_cs.py +0 -116
  522. egse/tempcontrol/agilent/agilent34970_devif.py +0 -182
  523. egse/tempcontrol/agilent/agilent34970_protocol.py +0 -99
  524. egse/tempcontrol/agilent/agilent34972.py +0 -111
  525. egse/tempcontrol/agilent/agilent34972.yaml +0 -44
  526. egse/tempcontrol/agilent/agilent34972_cs.py +0 -117
  527. egse/tempcontrol/agilent/agilent34972_devif.py +0 -189
  528. egse/tempcontrol/agilent/agilent34972_protocol.py +0 -101
  529. egse/tempcontrol/beaglebone/beaglebone.py +0 -342
  530. egse/tempcontrol/beaglebone/beaglebone.yaml +0 -110
  531. egse/tempcontrol/beaglebone/beaglebone_cs.py +0 -117
  532. egse/tempcontrol/beaglebone/beaglebone_protocol.py +0 -135
  533. egse/tempcontrol/beaglebone/beaglebone_ui.py +0 -681
  534. egse/tempcontrol/digalox/digalox.py +0 -107
  535. egse/tempcontrol/digalox/digalox.yaml +0 -36
  536. egse/tempcontrol/digalox/digalox_cs.py +0 -112
  537. egse/tempcontrol/digalox/digalox_protocol.py +0 -55
  538. egse/tempcontrol/keithley/__init__.py +0 -33
  539. egse/tempcontrol/keithley/daq6510.py +0 -662
  540. egse/tempcontrol/keithley/daq6510.yaml +0 -105
  541. egse/tempcontrol/keithley/daq6510_cs.py +0 -163
  542. egse/tempcontrol/keithley/daq6510_devif.py +0 -343
  543. egse/tempcontrol/keithley/daq6510_protocol.py +0 -78
  544. egse/tempcontrol/keithley/daq6510_sim.py +0 -186
  545. egse/tempcontrol/lakeshore/__init__.py +0 -33
  546. egse/tempcontrol/lakeshore/lsci.py +0 -361
  547. egse/tempcontrol/lakeshore/lsci.yaml +0 -162
  548. egse/tempcontrol/lakeshore/lsci_cs.py +0 -174
  549. egse/tempcontrol/lakeshore/lsci_devif.py +0 -292
  550. egse/tempcontrol/lakeshore/lsci_protocol.py +0 -73
  551. egse/tempcontrol/lakeshore/lsci_ui.py +0 -389
  552. egse/tempcontrol/ni/__init__.py +0 -0
  553. egse/tempcontrol/spid/spid.py +0 -109
  554. egse/tempcontrol/spid/spid.yaml +0 -81
  555. egse/tempcontrol/spid/spid_controller.py +0 -279
  556. egse/tempcontrol/spid/spid_cs.py +0 -136
  557. egse/tempcontrol/spid/spid_protocol.py +0 -107
  558. egse/tempcontrol/spid/spid_ui.py +0 -727
  559. egse/tempcontrol/srs/__init__.py +0 -22
  560. egse/tempcontrol/srs/ptc10.py +0 -875
  561. egse/tempcontrol/srs/ptc10.yaml +0 -227
  562. egse/tempcontrol/srs/ptc10_cs.py +0 -128
  563. egse/tempcontrol/srs/ptc10_devif.py +0 -118
  564. egse/tempcontrol/srs/ptc10_protocol.py +0 -42
  565. egse/tempcontrol/srs/ptc10_ui.py +0 -906
  566. egse/ups/apc/apc.py +0 -236
  567. egse/ups/apc/apc.yaml +0 -45
  568. egse/ups/apc/apc_cs.py +0 -101
  569. egse/ups/apc/apc_protocol.py +0 -125
  570. egse/user.yaml +0 -7
  571. egse/vacuum/beaglebone/beaglebone.py +0 -149
  572. egse/vacuum/beaglebone/beaglebone.yaml +0 -44
  573. egse/vacuum/beaglebone/beaglebone_cs.py +0 -108
  574. egse/vacuum/beaglebone/beaglebone_devif.py +0 -164
  575. egse/vacuum/beaglebone/beaglebone_protocol.py +0 -193
  576. egse/vacuum/beaglebone/beaglebone_ui.py +0 -638
  577. egse/vacuum/instrutech/igm402.py +0 -92
  578. egse/vacuum/instrutech/igm402.yaml +0 -90
  579. egse/vacuum/instrutech/igm402_controller.py +0 -128
  580. egse/vacuum/instrutech/igm402_cs.py +0 -108
  581. egse/vacuum/instrutech/igm402_interface.py +0 -49
  582. egse/vacuum/instrutech/igm402_simulator.py +0 -36
  583. egse/vacuum/keller/kellerBus.py +0 -256
  584. egse/vacuum/keller/leo3.py +0 -102
  585. egse/vacuum/keller/leo3.yaml +0 -38
  586. egse/vacuum/keller/leo3_controller.py +0 -83
  587. egse/vacuum/keller/leo3_cs.py +0 -101
  588. egse/vacuum/keller/leo3_interface.py +0 -33
  589. egse/vacuum/mks/evision.py +0 -86
  590. egse/vacuum/mks/evision.yaml +0 -75
  591. egse/vacuum/mks/evision_cs.py +0 -101
  592. egse/vacuum/mks/evision_devif.py +0 -316
  593. egse/vacuum/mks/evision_interface.py +0 -60
  594. egse/vacuum/mks/evision_simulator.py +0 -24
  595. egse/vacuum/mks/evision_ui.py +0 -704
  596. egse/vacuum/pfeiffer/acp40.py +0 -87
  597. egse/vacuum/pfeiffer/acp40.yaml +0 -60
  598. egse/vacuum/pfeiffer/acp40_controller.py +0 -117
  599. egse/vacuum/pfeiffer/acp40_cs.py +0 -109
  600. egse/vacuum/pfeiffer/acp40_interface.py +0 -40
  601. egse/vacuum/pfeiffer/acp40_simulator.py +0 -39
  602. egse/vacuum/pfeiffer/tc400.py +0 -113
  603. egse/vacuum/pfeiffer/tc400.yaml +0 -83
  604. egse/vacuum/pfeiffer/tc400_controller.py +0 -140
  605. egse/vacuum/pfeiffer/tc400_cs.py +0 -109
  606. egse/vacuum/pfeiffer/tc400_interface.py +0 -70
  607. egse/vacuum/pfeiffer/tc400_simulator.py +0 -24
  608. egse/vacuum/pfeiffer/tpg261.py +0 -81
  609. egse/vacuum/pfeiffer/tpg261.yaml +0 -66
  610. egse/vacuum/pfeiffer/tpg261_controller.py +0 -150
  611. egse/vacuum/pfeiffer/tpg261_cs.py +0 -109
  612. egse/vacuum/pfeiffer/tpg261_interface.py +0 -60
  613. egse/vacuum/pfeiffer/tpg261_simulator.py +0 -24
  614. egse/version.py +0 -174
  615. egse/visitedpositions.py +0 -398
  616. egse/windowing.py +0 -213
  617. egse/zmq/__init__.py +0 -28
  618. egse/zmq/spw.py +0 -160
  619. egse/zmq_ser.py +0 -41
  620. scripts/alerts/cold.yaml +0 -278
  621. scripts/alerts/example_alerts.yaml +0 -54
  622. scripts/alerts/transition.yaml +0 -14
  623. scripts/alerts/warm.yaml +0 -49
  624. scripts/analyse_n_fee_hk_data.py +0 -44
  625. scripts/check_hdf5_files.py +0 -192
  626. scripts/check_register_sync.py +0 -47
  627. scripts/create_hdf5_report.py +0 -295
  628. scripts/csl_model.py +0 -436
  629. scripts/csl_restore_setup.py +0 -230
  630. scripts/export-grafana-dashboards.py +0 -50
  631. scripts/fdir/cs_recovery/fdir_cs_recovery.py +0 -59
  632. scripts/fdir/fdir_table.yaml +0 -70
  633. scripts/fdir/fdir_test_recovery.py +0 -11
  634. scripts/fdir/hw_recovery/fdir_agilent_hw_recovery.py +0 -73
  635. scripts/fdir/limit_recovery/fdir_agilent_limit.py +0 -64
  636. scripts/fdir/limit_recovery/fdir_bb_heater_limit.py +0 -61
  637. scripts/fdir/limit_recovery/fdir_ensemble_limit.py +0 -33
  638. scripts/fdir/limit_recovery/fdir_pressure_limit_recovery.py +0 -71
  639. scripts/fix_csv.py +0 -80
  640. scripts/n_fee_supply_voltage_calculation.py +0 -92
  641. scripts/playground.py +0 -30
  642. scripts/print_hdf5_hk_data.py +0 -68
  643. scripts/print_register_map.py +0 -43
  644. scripts/sron/commanding/control_heaters.py +0 -44
  645. scripts/sron/commanding/pumpdown.py +0 -46
  646. scripts/sron/commanding/set_pid_setpoint.py +0 -19
  647. scripts/sron/commanding/shutdown_bbb_heaters.py +0 -10
  648. scripts/sron/commanding/shutdown_pumps.py +0 -33
  649. scripts/sron/tm_gen/tm_gen_agilent.py +0 -38
  650. scripts/sron/tm_gen/tm_gen_heaters.py +0 -4
  651. scripts/sron/tm_gen/tm_gen_spid.py +0 -13
  652. scripts/update_operational_cgse.py +0 -268
  653. scripts/update_operational_cgse_old.py +0 -273
egse/listener.py DELETED
@@ -1,73 +0,0 @@
1
- import logging
2
- from enum import IntEnum
3
- from typing import Any
4
-
5
- from egse.decorators import dynamic_interface
6
-
7
- LOGGER = logging.getLogger(__name__)
8
-
9
- class EVENT_ID(IntEnum):
10
- ALL = 0
11
- SETUP = 1
12
-
13
- class Event:
14
- def __init__(self, event_id: int, context: Any):
15
- self.id = event_id
16
- self.context = context
17
- def __repr__(self):
18
- return f"Event({self.id}, {self.context})"
19
-
20
-
21
- class EventInterface:
22
- @dynamic_interface
23
- def handle_event(self, event: Event):
24
- ...
25
-
26
- class Listeners:
27
- def __init__(self):
28
- self._listeners: dict[str, dict] = {}
29
-
30
- def __len__(self):
31
- return len(self._listeners)
32
-
33
- def add_listener(self, listener: dict):
34
- """
35
- The argument is a dictionary with the following expected content:
36
-
37
- * name (str): the name of the process
38
- * proxy (str): the proxy class
39
-
40
- Args:
41
- listener: a dictionary with properties of the listener
42
-
43
- Raises:
44
- ValueError if the listener already exists.
45
- """
46
- try:
47
- listener_name = listener["name"]
48
- except KeyError as exc:
49
- raise ValueError(f"Expected 'name' key in listener argument {listener}.") from exc
50
-
51
- if listener_name in self._listeners:
52
- raise ValueError(f"Process {listener_name} is already registered as a listener.")
53
-
54
- self._listeners[listener_name] = listener
55
-
56
- def remove_listener(self, listener: dict):
57
- try:
58
- listener_name = listener["name"]
59
- except KeyError as exc:
60
- raise ValueError(f"Expected 'name' key in listener argument {listener}.") from exc
61
-
62
- try:
63
- del self._listeners[listener_name]
64
- except KeyError as exc:
65
- raise ValueError(f"Process {listener_name} cannot be removed, not registered.") from exc
66
-
67
- def notify_listeners(self, event: Event):
68
- for name, listener in self._listeners.items():
69
- proxy = listener['proxy']
70
- LOGGER.info(f"Notifying process {name} of {event.context or {}} on {event.id=}")
71
- with proxy() as pobj:
72
- rc = pobj.handle_event(event)
73
- LOGGER.info(f"{rc=}")
egse/logger/__init__.py DELETED
@@ -1,243 +0,0 @@
1
- """
2
- This module defines the level, format and handlers for the root logger and for the special
3
- 'egse' logger. The egse_logger will be configured with a special handler which sends all
4
- logging messages to a log control server.
5
-
6
- This module is loaded whenever an egse module is loaded, to ensure all log messages are properly
7
- forwarded to the log control server.
8
- """
9
-
10
- import logging
11
- import pickle
12
- import sys
13
- import traceback
14
-
15
- import zmq
16
-
17
- LOG_FORMAT_FULL = (
18
- "%(asctime)23s:%(processName)20s:%(levelname)8s:%(lineno)5d:%(name)-20s:%(message)s"
19
- )
20
-
21
- # Configure the root logger
22
-
23
- logging.basicConfig(level=logging.DEBUG, format=LOG_FORMAT_FULL)
24
-
25
- __all__ = [
26
- "egse_logger",
27
- "set_all_logger_levels",
28
- "ZeroMQHandler",
29
- "close_all_zmq_handlers",
30
- ]
31
-
32
-
33
- class ZeroMQHandler(logging.Handler):
34
- def __init__(self, uri=None, socket_type=zmq.PUSH, ctx=None):
35
-
36
- from egse.settings import Settings
37
- from egse.zmq_ser import connect_address
38
-
39
- ctrl_settings = Settings.load("Logging Control Server")
40
- uri = uri or connect_address(ctrl_settings.PROTOCOL, ctrl_settings.HOSTNAME,
41
- ctrl_settings.LOGGING_PORT)
42
-
43
- logging.Handler.__init__(self)
44
-
45
- # print(f"ZeroMQHandler.__init__({uri=}, {socket_type=}, {ctx=})")
46
-
47
- self.setLevel(logging.NOTSET)
48
-
49
- self.ctx = ctx or zmq.Context().instance()
50
- self.socket = zmq.Socket(self.ctx, socket_type)
51
- self.socket.setsockopt(zmq.SNDHWM, 0) # never block on sending msg
52
- self.socket.connect(uri)
53
-
54
- def __del__(self):
55
- self.close()
56
-
57
- def close(self):
58
- self.socket.close(linger=0)
59
-
60
- def emit(self, record):
61
- """
62
- Emit a record.
63
-
64
- Writes the LogRecord to the queue, preparing it for pickling first.
65
- """
66
-
67
- # print(f"ZeroMQHandler.emit({record})")
68
-
69
- from egse.system import is_in_ipython
70
-
71
- try:
72
- if record.exc_info:
73
- record.exc_text = traceback.format_exc()
74
- record.exc_info = None # traceback objects can not be pickled
75
- if record.processName == "MainProcess" and is_in_ipython():
76
- record.processName = "IPython"
77
- data = pickle.dumps(record.__dict__)
78
- self.socket.send(data, flags=zmq.NOBLOCK)
79
- except (KeyboardInterrupt, SystemExit):
80
- raise
81
- except Exception as exc:
82
- print(f"ZeroMQHandler: Exception - {exc}", file=sys.stderr)
83
- self.handleError(record)
84
-
85
-
86
- def close_all_zmq_handlers():
87
- """
88
- Close all the ZeroMQHandlers that are connected to a logger.
89
-
90
- This function is automatically called upon termination of the control servers. For your own
91
- applications, call this function before exiting the App.
92
- """
93
-
94
- loggers = logging.Logger.manager.loggerDict
95
-
96
- for name, logger in loggers.items():
97
- if isinstance(logger, logging.PlaceHolder):
98
- continue
99
- for handler in logger.handlers:
100
- if isinstance(handler, ZeroMQHandler):
101
- logger.debug(f"Closing handler for logger {name}")
102
- handler.close()
103
-
104
-
105
- # Initialize logging as we want it for the Common-EGSE
106
- #
107
- # * The ZeroMQHandler to send all logging messages, i.e. level=DEBUG to the Logging Server
108
- # * The (local) StreamingHandlers to print only INFO messages and higher
109
-
110
- logging.disable(logging.NOTSET)
111
- root_logger = logging.getLogger()
112
-
113
- for handler in root_logger.handlers:
114
- handler.setLevel(logging.INFO)
115
-
116
-
117
- # Define the `egse` logger and add the ZeroMQHandler to this logger
118
-
119
- egse_logger = logging.getLogger("egse")
120
- egse_logger.setLevel(logging.DEBUG)
121
-
122
- zmq_handler = ZeroMQHandler()
123
- zmq_handler.setLevel(logging.NOTSET)
124
-
125
- egse_logger.addHandler(zmq_handler)
126
- egse_logger.setLevel(logging.DEBUG)
127
-
128
-
129
- def replace_zmq_handler():
130
- """
131
- This function will replace the current ZeroMQ Handler with a new instance. Use this function
132
- in the run() method of a multiprocessing.Process:
133
-
134
- import egse.logger
135
- egse.logger.replace_zmq_handler()
136
-
137
- Don't use this function in the __init__() method as only the run() method will execute in
138
- the new Process and replace the handler in the proper environment. The reason for this is
139
- that the ZeroMQ socket is not thread/Process safe, so a new ZeroMQ socket needs to be created
140
- in the correct process environment.
141
- """
142
- global egse_logger
143
-
144
- this_handler = None
145
- for handler in egse_logger.handlers:
146
- if isinstance(handler, ZeroMQHandler):
147
- this_handler = handler
148
- if this_handler is not None:
149
- egse_logger.removeHandler(this_handler)
150
- egse_logger.addHandler(ZeroMQHandler())
151
-
152
-
153
- def create_new_zmq_logger(name: str):
154
- """
155
- Create a new logger with the given name and add a ZeroMQ Handler to this logger.
156
-
157
- If the logger already has a ZeroMQ handler attached, don't add a second ZeroMQ handler,
158
- just return the Logger object.
159
-
160
- Args:
161
- name: the requested name for the logger
162
-
163
- Returns:
164
- A Logger for the given name with a ZeroMQ handler attached.
165
- """
166
- logger = logging.getLogger(name)
167
- logger.setLevel(logging.DEBUG)
168
-
169
- # If the ZeroMQ handler already exists for this logger, don't add a second handler
170
-
171
- for handler in logger.handlers:
172
- if isinstance(handler, ZeroMQHandler):
173
- return logger
174
-
175
- zmq_handler = ZeroMQHandler()
176
- zmq_handler.setLevel(logging.NOTSET)
177
-
178
- logger.addHandler(zmq_handler)
179
- logger.setLevel(logging.DEBUG)
180
-
181
- return logger
182
-
183
-
184
- # We define a new level that is lower the DEBUG for extreme verbose messages
185
-
186
- logging.FLASH_FLOOD = 5
187
- logging.addLevelName(logging.FLASH_FLOOD, "FLASH_FLOOD")
188
-
189
-
190
- def flash_flood(self, msg, *args, **kwargs):
191
- if self.isEnabledFor(logging.FLASH_FLOOD):
192
- self._log(logging.FLASH_FLOOD, msg, args, **kwargs)
193
-
194
-
195
- logging.flash_flood = flash_flood
196
- logging.Logger.flash_flood = flash_flood
197
-
198
-
199
- def set_all_logger_levels(level: int):
200
- global root_logger, egse_logger
201
-
202
- root_logger.level = level
203
- egse_logger.level = level
204
-
205
- for handler in root_logger.handlers:
206
- handler.setLevel(level)
207
-
208
- # We don't want to restrict egse_logger levels
209
-
210
- # for handler in egse_logger.handlers:
211
- # handler.setLevel(level)
212
-
213
-
214
- if __name__ == "__main__":
215
-
216
- import egse.logger
217
-
218
- LOGGER = logging.getLogger("egse.0mq-log-test")
219
- LOGGER.setLevel(logging.FLASH_FLOOD)
220
-
221
- LOGGER.flash_flood("Hello, ZeroMQ logging: This is a FLASH_FLOOD message.")
222
- LOGGER.debug("Hello, ZeroMQ logging: This is a DEBUG message.")
223
- LOGGER.info("Hello, ZeroMQ logging: This is an INFO message.")
224
- LOGGER.warning("Hello, ZeroMQ logging: This is a WARNING message.")
225
- LOGGER.error("Hello, ZeroMQ logging: This is an ERROR message.")
226
- LOGGER.critical("Hello, ZeroMQ logging: This is a CRITICAL message.")
227
- try:
228
- raise ValueError("A fake ValueError, raised for testing.")
229
- except ValueError:
230
- LOGGER.exception("Hello, ZeroMQ logging: This is an EXCEPTION message.")
231
-
232
- LOGGER = logging.getLogger("plain-log-test")
233
-
234
- LOGGER.flash_flood("Vanilla logging: This is a FLASH_FLOOD message.")
235
- LOGGER.debug("Vanilla logging: This is a DEBUG message.")
236
- LOGGER.info("Vanilla logging: This is an INFO message.")
237
- LOGGER.warning("Vanilla logging: This is a WARNING message.")
238
- LOGGER.error("Vanilla logging: This is an ERROR message.")
239
- LOGGER.critical("Vanilla logging: This is a CRITICAL message.")
240
- try:
241
- raise ValueError("A fake ValueError, raised for testing.")
242
- except ValueError:
243
- LOGGER.exception("Vanilla logging: This is an EXCEPTION message.")
egse/logger/log_cs.py DELETED
@@ -1,321 +0,0 @@
1
- """
2
- The Log Server receives all log messages and events from control servers and client applications
3
- and saves those messages in a log file at a given location.
4
- """
5
- import datetime
6
- import logging
7
- import multiprocessing
8
- import pickle
9
- from logging import StreamHandler
10
- from logging.handlers import SocketHandler
11
- from logging.handlers import TimedRotatingFileHandler
12
- from pathlib import Path
13
- from typing import Optional
14
- from typing import Union
15
-
16
- import click
17
- import rich
18
- import zmq
19
- from prometheus_client import Counter
20
- from prometheus_client import start_http_server
21
-
22
- from egse.env import get_log_file_location
23
- from egse.settings import Settings
24
- from egse.system import format_datetime
25
- from egse.system import replace_environment_variable
26
- from egse.zmq_ser import bind_address
27
- from egse.zmq_ser import connect_address
28
-
29
- CTRL_SETTINGS = Settings.load("Logging Control Server")
30
-
31
-
32
- # The format for the log file.
33
- # The line that is saved in the log file shall contain as much information as possible.
34
-
35
- LOG_FORMAT_FILE = (
36
- "%(asctime)s:%(processName)s:%(process)s:%(levelname)s:%(lineno)d:%(name)s:%(message)s"
37
- )
38
-
39
- LOG_FORMAT_KEY_VALUE = (
40
- "level=%(levelname)s ts=%(asctime)s process=%(processName)s process_id=%(process)s caller=%(name)s:%(lineno)s msg=\"%(message)s\""
41
- )
42
-
43
- LOG_FORMAT_DATE = "%Y-%m-%dT%H:%M:%S,%f"
44
-
45
- # The format for the console output.
46
- # The line that is printed on the console shall be concise.
47
-
48
- LOG_FORMAT_STREAM = "%(asctime)s:%(levelname)s:%(name)s:%(message)s"
49
-
50
- LOG_RECORDS = Counter(
51
- "log_records_count", "Count the number of log records processed", ["source", "name"]
52
- )
53
-
54
- LOG_LEVEL_FILE = logging.DEBUG
55
- LOG_LEVEL_STREAM = logging.ERROR
56
- LOG_LEVEL_SOCKET = 1 # ALL records shall go to the socket handler
57
-
58
- LOGGER_NAME = "egse.logger.log_cs"
59
-
60
- file_handler: Optional[TimedRotatingFileHandler] = None
61
- stream_handler: Optional[StreamHandler] = None
62
- socket_handler: Optional[SocketHandler] = None
63
-
64
-
65
- class DateTimeFormatter(logging.Formatter):
66
-
67
- def formatTime(self, record, datefmt=None):
68
- converted_time = datetime.datetime.fromtimestamp(record.created)
69
- if datefmt:
70
- return converted_time.strftime(datefmt)
71
- formatted_time = converted_time.strftime("%Y-%m-%dT%H:%M:%S")
72
- return f"{formatted_time}.{record.msecs:03.0f}"
73
-
74
-
75
- file_formatter = DateTimeFormatter(fmt=LOG_FORMAT_KEY_VALUE, datefmt=LOG_FORMAT_DATE)
76
-
77
-
78
- @click.group()
79
- def cli():
80
- pass
81
-
82
-
83
- @cli.command()
84
- def start():
85
- """Start the Logger Control Server."""
86
-
87
- global file_handler, stream_handler, socket_handler
88
-
89
- multiprocessing.current_process().name = "log_cs"
90
-
91
- start_http_server(CTRL_SETTINGS.METRICS_PORT)
92
-
93
- # TODO (rik):
94
- # The `max_*` values should be read from the Settings (DONE) and it shall be possible to
95
- # overwrite these values from the commandline maybe.
96
-
97
- max_bytes = CTRL_SETTINGS.MAX_SIZE_LOG_FILES * 1024 * 1024
98
- max_nr_log_files = CTRL_SETTINGS.MAX_NR_LOG_FILES
99
-
100
- log_file_location = Path(get_log_file_location())
101
- if not log_file_location.exists():
102
- raise FileNotFoundError(f"The location for the log files doesn't exist: {log_file_location!s}.")
103
-
104
- file_handler = TimedRotatingFileHandler(
105
- filename=log_file_location / "general.log", when='midnight'
106
- )
107
- file_handler.setFormatter(file_formatter)
108
-
109
- # There is no need to set the level for the handlers, because the level is checked by the
110
- # Logger and we use the handlers directly here. Use a filter to restrict messages.
111
-
112
- stream_handler = StreamHandler()
113
- stream_handler.setFormatter(logging.Formatter(fmt=LOG_FORMAT_STREAM))
114
-
115
- # Log records are also sent to the cutelog listening server
116
-
117
- socket_handler = SocketHandler(CTRL_SETTINGS.CUTELOG_IP_ADDRESS, CTRL_SETTINGS.CUTELOG_LISTENING_PORT)
118
- socket_handler.setFormatter(file_formatter)
119
-
120
- context = zmq.Context()
121
-
122
- endpoint = bind_address(CTRL_SETTINGS.PROTOCOL, CTRL_SETTINGS.LOGGING_PORT)
123
- receiver = context.socket(zmq.PULL)
124
- receiver.bind(endpoint)
125
-
126
- endpoint = bind_address(CTRL_SETTINGS.PROTOCOL, CTRL_SETTINGS.COMMANDING_PORT)
127
- commander = context.socket(zmq.REP)
128
- commander.bind(endpoint)
129
-
130
- poller = zmq.Poller()
131
- poller.register(receiver, zmq.POLLIN)
132
- poller.register(commander, zmq.POLLIN)
133
-
134
- while True:
135
- try:
136
- socks = dict(poller.poll())
137
-
138
- if commander in socks:
139
- pickle_string = commander.recv()
140
- command = pickle.loads(pickle_string)
141
-
142
- if command.lower() == "quit":
143
- commander.send(pickle.dumps("ACK"))
144
- break
145
-
146
- response = handle_command(command)
147
- commander.send(pickle.dumps(response))
148
-
149
- if receiver in socks:
150
- pickle_string = receiver.recv()
151
- record = pickle.loads(pickle_string)
152
- record = logging.makeLogRecord(record)
153
-
154
- handle_log_record(record)
155
-
156
- except KeyboardInterrupt:
157
- click.echo("KeyboardInterrupt caught!")
158
- break
159
-
160
- record = logging.LogRecord(
161
- name=LOGGER_NAME,
162
- level=logging.WARNING,
163
- pathname=__file__,
164
- lineno=137,
165
- msg="Logger terminated.",
166
- args=(),
167
- exc_info=None,
168
- func="start",
169
- sinfo=None
170
- )
171
- handle_log_record(record)
172
-
173
- file_handler.close()
174
- stream_handler.close()
175
- commander.close(linger=0)
176
- receiver.close(linger=0)
177
-
178
-
179
- def handle_log_record(record):
180
- """Send the log record to the file handler and the stream handler."""
181
- global file_handler, stream_handler, socket_handler
182
-
183
- if record.levelno >= LOG_LEVEL_FILE:
184
- file_handler.emit(record)
185
-
186
- if record.levelno >= LOG_LEVEL_STREAM:
187
- stream_handler.handle(record)
188
-
189
- if record.levelno >= LOG_LEVEL_SOCKET:
190
- socket_handler.handle(record)
191
-
192
- LOG_RECORDS.labels(source="all", name="all").inc()
193
- LOG_RECORDS.labels(source="logger", name=record.name).inc()
194
- LOG_RECORDS.labels(source="process", name=record.processName).inc()
195
-
196
-
197
- def handle_command(command) -> dict:
198
- """Handle commands that are sent to the commanding socket."""
199
- global file_handler
200
- global LOG_LEVEL_FILE
201
-
202
- response = dict(
203
- timestamp=format_datetime(),
204
- )
205
- if command.lower() == 'roll':
206
- file_handler.doRollover()
207
- response.update(dict(status="ACK"))
208
- record = logging.LogRecord(
209
- name=LOGGER_NAME,
210
- level=logging.WARNING,
211
- pathname=__file__,
212
- lineno=197,
213
- msg="Logger rolled over.",
214
- args=(),
215
- exc_info=None,
216
- func="roll",
217
- sinfo=None
218
- )
219
- handle_log_record(record)
220
-
221
- elif command.lower() == 'status':
222
- response.update(dict(
223
- status="ACK",
224
- file_logger_level=logging.getLevelName(LOG_LEVEL_FILE),
225
- stream_logger_level=logging.getLevelName(LOG_LEVEL_STREAM),
226
- file_logger_location=file_handler.baseFilename,
227
- ))
228
- elif command.lower().startswith("set_level"):
229
- new_level = command.split()[-1]
230
- LOG_LEVEL_FILE = logging._nameToLevel[new_level]
231
- response.update(dict(
232
- status="ACK",
233
- file_logger_level=logging.getLevelName(LOG_LEVEL_FILE),
234
- ))
235
-
236
- return response
237
-
238
-
239
- @cli.command()
240
- def stop():
241
- """Stop the Logger Control Server."""
242
-
243
- response = send_request("quit")
244
- if response == "ACK":
245
- rich.print("Logger successfully terminated.")
246
- else:
247
- rich.print(f"[red] ERROR: {response}")
248
-
249
-
250
- @cli.command()
251
- def roll():
252
- """Roll over the log file of the Logger Control Server."""
253
-
254
- response = send_request("roll")
255
- if response.get("status") == "ACK":
256
- rich.print("[green]Logger files successfully rotated.")
257
- else:
258
- rich.print(f"[red]ERROR: {response}")
259
-
260
-
261
- @cli.command()
262
- def status():
263
- """Roll over the log file of the Logger Control Server."""
264
-
265
- rich.print("Log Manager:")
266
-
267
- response = send_request("status")
268
- if response.get("status") == "ACK":
269
- rich.print(" Status: [green]active")
270
- rich.print(f" Level [grey50](file)[black]: {response.get('file_logger_level')}")
271
- rich.print(f" Level [grey50](stdout)[black]: {response.get('stream_logger_level')}")
272
- rich.print(f" Log file location: {response.get('file_logger_location')}")
273
- else:
274
- rich.print(" Status: [red]not active")
275
-
276
-
277
- @cli.command()
278
- @click.argument('level')
279
- def level(level: Union[int, str]):
280
- """Set the logging level for """
281
- try:
282
- level = logging.getLevelName(int(level))
283
- except ValueError:
284
- if level not in logging._nameToLevel:
285
- rich.print(f"[red]Invalid logging level given '{level}'.")
286
- rich.print(f"Should be one of {logging._levelToName}.")
287
- return
288
-
289
- response = send_request(f"set_level {level}")
290
- if response.get("status") == "ACK":
291
- rich.print(f"Log level on the server is now set to {response.get('file_logger_level')}.")
292
- else:
293
- rich.print(f"[red]ERROR: {response}")
294
-
295
-
296
- TIMEOUT_RECV = 1.0 # seconds
297
-
298
-
299
- def send_request(command_request: str):
300
- """Sends a request to the Logger Control Server and waits for a response."""
301
- ctx = zmq.Context().instance()
302
- endpoint = connect_address(
303
- CTRL_SETTINGS.PROTOCOL, CTRL_SETTINGS.HOSTNAME, CTRL_SETTINGS.COMMANDING_PORT
304
- )
305
- socket = ctx.socket(zmq.REQ)
306
- socket.connect(endpoint)
307
-
308
- socket.send(pickle.dumps(command_request))
309
- rlist, _, _ = zmq.select([socket], [], [], timeout=TIMEOUT_RECV)
310
- if socket in rlist:
311
- response = socket.recv()
312
- response = pickle.loads(response)
313
- else:
314
- response = {"error": "Receive from ZeroMQ socket timed out for Logger Control Server."}
315
- socket.close(linger=0)
316
-
317
- return response
318
-
319
-
320
- if __name__ == "__main__":
321
- cli()