pyegeria 0.2.4__py3-none-any.whl → 5.3.0.dev3__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 (239) hide show
  1. pyegeria/README.md +35 -0
  2. pyegeria/__init__.py +345 -14
  3. pyegeria/_client.py +376 -126
  4. pyegeria/_deprecated_gov_engine.py +451 -0
  5. pyegeria/_exceptions.py +6 -6
  6. pyegeria/_globals.py +7 -1
  7. pyegeria/_validators.py +9 -6
  8. pyegeria/asset_catalog_omvs.py +807 -0
  9. pyegeria/automated_curation_omvs.py +3760 -0
  10. pyegeria/classification_manager_omvs.py +5238 -0
  11. pyegeria/collection_manager_omvs.py +2727 -0
  12. pyegeria/commands/README.md +47 -0
  13. pyegeria/commands/__init__.py +22 -0
  14. pyegeria/commands/cat/README.md +16 -0
  15. pyegeria/commands/cat/__init__.py +1 -0
  16. pyegeria/commands/cat/exp_list_glossaries.py +156 -0
  17. pyegeria/commands/cat/get_asset_graph.py +319 -0
  18. pyegeria/commands/cat/get_collection.py +148 -0
  19. pyegeria/commands/cat/get_project_dependencies.py +168 -0
  20. pyegeria/commands/cat/get_project_structure.py +168 -0
  21. pyegeria/commands/cat/get_tech_type_elements.py +174 -0
  22. pyegeria/commands/cat/glossary_actions.py +362 -0
  23. pyegeria/commands/cat/list_assets.py +176 -0
  24. pyegeria/commands/cat/list_cert_types.py +194 -0
  25. pyegeria/commands/cat/list_collections.py +162 -0
  26. pyegeria/commands/cat/list_deployed_catalogs.py +217 -0
  27. pyegeria/commands/cat/list_deployed_database_schemas.py +251 -0
  28. pyegeria/commands/cat/list_deployed_databases.py +202 -0
  29. pyegeria/commands/cat/list_glossaries.py +150 -0
  30. pyegeria/commands/cat/list_projects.py +221 -0
  31. pyegeria/commands/cat/list_servers_deployed_imp.py +158 -0
  32. pyegeria/commands/cat/list_tech_type_elements.py +190 -0
  33. pyegeria/commands/cat/list_tech_types.py +140 -0
  34. pyegeria/commands/cat/list_terms.py +242 -0
  35. pyegeria/commands/cat/list_todos.py +189 -0
  36. pyegeria/commands/cat/list_user_ids.py +145 -0
  37. pyegeria/commands/cli/__init__.py +13 -0
  38. pyegeria/commands/cli/egeria.py +1844 -0
  39. pyegeria/commands/cli/egeria_cat.py +638 -0
  40. pyegeria/commands/cli/egeria_login_tui.py +313 -0
  41. pyegeria/commands/cli/egeria_my.py +248 -0
  42. pyegeria/commands/cli/egeria_ops.py +502 -0
  43. pyegeria/commands/cli/egeria_tech.py +618 -0
  44. pyegeria/commands/cli/ops_config.py +45 -0
  45. pyegeria/commands/cli/txt_custom_v2.tcss +19 -0
  46. pyegeria/commands/doc/README.md +145 -0
  47. pyegeria/commands/doc/Visual Command Reference/README.md +511 -0
  48. pyegeria/commands/doc/Visual Command Reference/cat/show/assets/asset-graph 2024-11-20 at 15.56.42.png +0 -0
  49. pyegeria/commands/doc/Visual Command Reference/cat/show/assets/assets-in-domain 2024-11-20 at 15.49.55@2x.png +0 -0
  50. pyegeria/commands/doc/Visual Command Reference/cat/show/assets/elements-of-type 2024-11-20 at 16.01.35.png +0 -0
  51. pyegeria/commands/doc/Visual Command Reference/cat/show/assets/tech-type-elements 2024-11-20 at 16.05.05.png +0 -0
  52. pyegeria/commands/doc/Visual Command Reference/cat/show/deployed-data/deployed-data-catalogs 2024-12-17 at 15.43.27@2x.png +0 -0
  53. pyegeria/commands/doc/Visual Command Reference/cat/show/deployed-data/deployed-data-catalogs-2024-11-20 at 16.17.43@2x.png +0 -0
  54. pyegeria/commands/doc/Visual Command Reference/cat/show/deployed-data/deployed-schemas 2024-11-25 at 20.14.50@2x.png +0 -0
  55. pyegeria/commands/doc/Visual Command Reference/cat/show/deployed-data/deployed-schemas 2024-12-17 at 15.48.38@2x.png +0 -0
  56. pyegeria/commands/doc/Visual Command Reference/cat/show/deployed-data/deployed-servers 2024-11-25 at 20.21.25@2x.png +0 -0
  57. pyegeria/commands/doc/Visual Command Reference/cat/show/deployed-data/deployed-servers 2024-12-17 at 15.52.16@2x.png +0 -0
  58. pyegeria/commands/doc/Visual Command Reference/cat/show/deployed-data/deployed_databases 2024-12-16 at 16.40.31@2x.png +0 -0
  59. pyegeria/commands/doc/Visual Command Reference/cat/show/glossary/list-glossaries 2024-11-25 at 20.30.02.png +0 -0
  60. pyegeria/commands/doc/Visual Command Reference/cat/show/glossary/list-terms 2024-11-25 at 20.32.11.png +0 -0
  61. pyegeria/commands/doc/Visual Command Reference/cat/show/info/asset-types 2024-11-25 at 20.34.19@2x.png +0 -0
  62. pyegeria/commands/doc/Visual Command Reference/cat/show/info/certification-types 2024-11-25 at 20.37.07.png +0 -0
  63. pyegeria/commands/doc/Visual Command Reference/cat/show/info/collection-graph 2024-12-12 at 11.33.18@2x.png +0 -0
  64. pyegeria/commands/doc/Visual Command Reference/cat/show/info/list-collections 2024-12-10 at 14.25.51@2x.png +0 -0
  65. pyegeria/commands/doc/Visual Command Reference/cat/show/info/list-todos 2024-12-12 at 11.46.30@2x.png +0 -0
  66. pyegeria/commands/doc/Visual Command Reference/cat/show/info/list-user-ids 2024-12-12 at 11.51.09@2x.png +0 -0
  67. pyegeria/commands/doc/Visual Command Reference/cat/show/info/tech-types 2024-12-12 at 11.37.20@2x.png +0 -0
  68. pyegeria/commands/doc/Visual Command Reference/cat/show/projects/project_dependencies 2024-12-14 at 16.24.39@2x.png +0 -0
  69. pyegeria/commands/doc/Visual Command Reference/cat/show/projects/project_structure 2024-12-14 at 16.21.35@2x.png +0 -0
  70. pyegeria/commands/doc/Visual Command Reference/cat/show/projects/projects 2024-12-14 at 16.18.10@2x.png +0 -0
  71. pyegeria/commands/doc/Visual Command Reference/hey_egeria tui 2024-12-16 at 16.58.22@2x.png +0 -0
  72. pyegeria/commands/doc/Visual Command Reference/my/show/my_profile 2024-12-14 at 16.29.27@2x.png +0 -0
  73. pyegeria/commands/doc/Visual Command Reference/my/show/my_roles 2024-12-14 at 16.32.10@2x.png +0 -0
  74. pyegeria/commands/doc/Visual Command Reference/my/show/my_todos 2024-12-15 at 16.24.13@2x.png +0 -0
  75. pyegeria/commands/doc/Visual Command Reference/my/show/open_todos 2024-12-14 at 16.36.12@2x.png +0 -0
  76. pyegeria/commands/doc/Visual Command Reference/ops/show/engines/list_engine_activity compressed 2024-12-15 at 16.48.48@2x.png +0 -0
  77. pyegeria/commands/doc/Visual Command Reference/ops/show/engines/monitor_engine_activity 2024-12-15 at 16.32.55@2x.png +0 -0
  78. pyegeria/commands/doc/Visual Command Reference/ops/show/engines/monitor_engine_activity compressed 2024-12-15 at 16.38.29@2x.png +0 -0
  79. pyegeria/commands/doc/Visual Command Reference/ops/show/engines/monitor_engine_status 2024-12-15 at 16.51.26.jpeg +0 -0
  80. pyegeria/commands/doc/Visual Command Reference/ops/show/integrations/monitor_integration_daemon_status 2024-12-15 at 16.57.12@2x.png +0 -0
  81. pyegeria/commands/doc/Visual Command Reference/ops/show/integrations/monitor_integration_targets 2024-12-15 at 17.02.19@2x.png +0 -0
  82. pyegeria/commands/doc/Visual Command Reference/ops/show/platforms/monitor_platform_status 2024-12-15 at 19.53.18@2x.png +0 -0
  83. pyegeria/commands/doc/Visual Command Reference/ops/show/servers/monitor_server_status 2024-12-15 at 19.59.39@2x.png +0 -0
  84. pyegeria/commands/doc/Visual Command Reference/ops/show/servers/monitor_server_status full 2024-12-15 at 20.01.57@2x.png +0 -0
  85. pyegeria/commands/doc/Visual Command Reference/ops/show/servers/monitor_startup_servers 2024-12-15 at 19.56.07@2x.png +0 -0
  86. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/get_anchored_elements 2024-12-15 at 21.25.41@2x.png +0 -0
  87. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/get_elements_of_om_type 2024-12-16 at 14.39.59@2x.png +0 -0
  88. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/info_for_guid 2024-12-16 at 11.35.29@2x.png +0 -0
  89. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/list_elements_by_om-type 2024-12-16 at 14.24.18@2x.png +0 -0
  90. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/list_elements_by_om-type extended 2024-12-16 at 14.28.46@2x.png +0 -0
  91. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/list_elements_of_om_type_by_classification 2024-12-16 at 14.35.26@2x.png +0 -0
  92. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/related_elements 2024-12-16 at 14.55.01@2x.png +0 -0
  93. pyegeria/commands/doc/Visual Command Reference/tech/show/elements/show_related_specifications 2024-12-16 at 15.04.55@2x.png +0 -0
  94. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-info/asset_types 2024-12-16 at 15.10.16@2x.png +0 -0
  95. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-info/detailed_governance_action_processes 2024-12-16 at 15.16.26@2x.png +0 -0
  96. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-info/governance_action_processes 2024-12-16 at 15.13.01@2x.png +0 -0
  97. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-info/registered_services 2024-12-16 at 16.44.54@2x.png +0 -0
  98. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-info/relationship_types 2024-12-16 at 16.20.34@2x.png +0 -0
  99. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-info/relationship_types 2024-12-19 at 10.51.54@2x.png +0 -0
  100. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-info/valid_metadata_values 2024-12-16 at 15.31.56@2x.png +0 -0
  101. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-types/list_tech_type_template_specs 2024-12-16 at 16.03.22@2x.png +0 -0
  102. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-types/list_technology_types 2024-12-16 at 15.39.20@2x.png +0 -0
  103. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-types/tech_type_details 2024-12-16 at 15.37.21@2x.png +0 -0
  104. pyegeria/commands/doc/Visual Command Reference/tech/show/tech-types/tech_type_templates 2024-12-16 at 16.11.48@2x.png +0 -0
  105. pyegeria/commands/doc/glossary/basic-glossary-tui.md +109 -0
  106. pyegeria/commands/doc/glossary/images/delete-glossary-step1 2024-11-06 at 15.47.23@2x.png +0 -0
  107. pyegeria/commands/doc/glossary/images/delete-glossary-step2 2024-11-06 at 15.51.29@2x.png +0 -0
  108. pyegeria/commands/doc/glossary/images/delete-glossary-step3 2024-11-06 at 15.53.19@2x.png +0 -0
  109. pyegeria/commands/doc/glossary/images/delete-glossary-step4 2024-11-06 at 15.55.11@2x.png +0 -0
  110. pyegeria/commands/doc/glossary/images/out-create-glossary example 2024-11-05 at 20.38.04@2x.png +0 -0
  111. pyegeria/commands/doc/glossary/images/out-create-term 2024-11-06 at 20.48.29.png +0 -0
  112. pyegeria/commands/doc/glossary/images/out-delete-term 2024-11-07 at 03.57.25.png +0 -0
  113. pyegeria/commands/doc/glossary/images/out-display-terms-for-glossary-test 2024-11-06 at 20.51.28.png +0 -0
  114. pyegeria/commands/doc/glossary/images/out-export-example 2024-11-07 at 09.54.57.png +0 -0
  115. pyegeria/commands/doc/glossary/images/out-exported-terms 2024-11-06 at 21.06.32.png +0 -0
  116. pyegeria/commands/doc/glossary/images/out-glossary-list example 2024-11-05 at 20.41.02@2x.png +0 -0
  117. pyegeria/commands/doc/glossary/images/out-import-terms 2024-11-07 at 08.15.18.png +0 -0
  118. pyegeria/commands/doc/glossary/images/out-list-all-terms 2024-11-06 at 16.22.20@2x.png +0 -0
  119. pyegeria/commands/doc/glossary/images/out-list-terms-for-example 2024-11-06 at 16.40.12.png +0 -0
  120. pyegeria/commands/doc/glossary/images/out-list-terms-second 2024-11-06 at 16.45.13.png +0 -0
  121. pyegeria/commands/doc/glossary/images/out-pipx install pyegeria 2024-11-10 at 18.12.21.png +0 -0
  122. pyegeria/commands/doc/glossary/images/out-server-status-full 2024-11-10 at 18.25.14.png +0 -0
  123. pyegeria/commands/doc/glossary/images/out-servers-status 2024-11-10 at 18.15.42.png +0 -0
  124. pyegeria/commands/doc/glossary/images/out-upsert-import 2024-11-07 at 19.37.00.png +0 -0
  125. pyegeria/commands/doc/glossary/images/tui-2024-11-10 at 18.26.29.png +0 -0
  126. pyegeria/commands/doc/glossary/images/tui-create-glossary example 2024-11-05 at 20.34.24@2x.png +0 -0
  127. pyegeria/commands/doc/glossary/images/tui-create-term 2024-11-06 at 20.46.35.png +0 -0
  128. pyegeria/commands/doc/glossary/images/tui-delete-term 2024-11-07 at 03.51.57.png +0 -0
  129. pyegeria/commands/doc/glossary/images/tui-display-terms-for-example 2024-11-06 at 20.56.49.png +0 -0
  130. pyegeria/commands/doc/glossary/images/tui-export-example 2024-11-07 at 09.52.59.png +0 -0
  131. pyegeria/commands/doc/glossary/images/tui-hey-egeria 2024-11-10 at 18.31.01.png +0 -0
  132. pyegeria/commands/doc/glossary/images/tui-import-upsert-example 2024-11-07 at 10.08.37.png +0 -0
  133. pyegeria/commands/doc/glossary/images/tui-list-terms-second 2024-11-06 at 16.46.34.png +0 -0
  134. pyegeria/commands/doc/glossary/images/tui-load-archive.png +0 -0
  135. pyegeria/commands/doc/glossary/images/tui-server-status-full 2024-11-10 at 19.14.36.png +0 -0
  136. pyegeria/commands/doc/glossary/images/tui-show-glossaries 2024-11-07 at 20.00.05.png +0 -0
  137. pyegeria/commands/doc/glossary/images/tui-show-glossary-terms 2024-11-05 at 19.37.53@2x.png +0 -0
  138. pyegeria/commands/doc/glossary/images/tui-upsert 2024-11-07 at 11.49.04.png +0 -0
  139. pyegeria/commands/doc/glossary/images/upsert-example.om-terms 2024-11-07 at 11.44.05.png +0 -0
  140. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/README.md +346 -0
  141. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/CleanShot 2024-11-18 at 21.32.03@2x.png +0 -0
  142. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/Xmind 1731421782704.png +0 -0
  143. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/Xmind 1731422134920.png +0 -0
  144. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/hey_egeria 2024-11-12 at 20.38.43.png +0 -0
  145. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/hey_egeria cat 2024-11-12 at 21.41.43.png +0 -0
  146. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/out-integ-status-list 2024-11-12 at 16.45.26.png +0 -0
  147. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/out-integ-status-live 2024-11-12 at 16.44.12@2x.png +0 -0
  148. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/out-server-status 2024-11-10 at 18.15.42@2x.png +0 -0
  149. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/out-server-status-full 2024-11-10 at 18.25.14@2x.png +0 -0
  150. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/short-cut commands 2024-11-12 at 22.22.13.png +0 -0
  151. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/tui-hey-egeria.png +0 -0
  152. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/tui-integration-status-paging.png +0 -0
  153. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/tui-load-archive 2024-11-10 at 19.19.09@2x.png +0 -0
  154. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/tui-show-server-status 2024-11-10 at 18.52.01@2x.png +0 -0
  155. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/tui-show-server-status-full 2024-11-10.png +0 -0
  156. pyegeria/commands/doc/hey_egeria: a pyegeria command line interface/images/tui-status-paging 2024-11-12 at 16.26.14@2x.png +0 -0
  157. pyegeria/commands/my/README.md +17 -0
  158. pyegeria/commands/my/__init__.py +0 -0
  159. pyegeria/commands/my/list_my_profile.py +163 -0
  160. pyegeria/commands/my/list_my_roles.py +151 -0
  161. pyegeria/commands/my/monitor_my_todos.py +205 -0
  162. pyegeria/commands/my/monitor_open_todos.py +175 -0
  163. pyegeria/commands/my/todo_actions.py +242 -0
  164. pyegeria/commands/ops/README.md +24 -0
  165. pyegeria/commands/ops/__init__.py +22 -0
  166. pyegeria/commands/ops/gov_server_actions.py +177 -0
  167. pyegeria/commands/ops/list_archives.py +161 -0
  168. pyegeria/commands/ops/list_catalog_targets.py +203 -0
  169. pyegeria/commands/ops/load_archive.py +75 -0
  170. pyegeria/commands/ops/monitor_asset_events.py +107 -0
  171. pyegeria/commands/ops/monitor_engine_activity.py +270 -0
  172. pyegeria/commands/ops/monitor_engine_activity_c.py +286 -0
  173. pyegeria/commands/ops/monitor_gov_eng_status.py +288 -0
  174. pyegeria/commands/ops/monitor_integ_daemon_status.py +321 -0
  175. pyegeria/commands/ops/monitor_platform_status.py +188 -0
  176. pyegeria/commands/ops/monitor_server_startup.py +117 -0
  177. pyegeria/commands/ops/monitor_server_status.py +182 -0
  178. pyegeria/commands/ops/orig_monitor_server_list.py +140 -0
  179. pyegeria/commands/ops/orig_monitor_server_status.py +124 -0
  180. pyegeria/commands/ops/refresh_integration_daemon.py +83 -0
  181. pyegeria/commands/ops/restart_integration_daemon.py +82 -0
  182. pyegeria/commands/ops/table_integ_daemon_status.py +237 -0
  183. pyegeria/commands/ops/x_engine_actions.py +76 -0
  184. pyegeria/commands/tech/README.md +24 -0
  185. pyegeria/commands/tech/__init__.py +0 -0
  186. pyegeria/commands/tech/get_element_info.py +144 -0
  187. pyegeria/commands/tech/get_guid_info.py +134 -0
  188. pyegeria/commands/tech/get_tech_details.py +173 -0
  189. pyegeria/commands/tech/get_tech_type_template.py +166 -0
  190. pyegeria/commands/tech/list_anchored_elements.py +205 -0
  191. pyegeria/commands/tech/list_asset_types.py +123 -0
  192. pyegeria/commands/tech/list_elements.py +168 -0
  193. pyegeria/commands/tech/list_elements_for_classification.py +171 -0
  194. pyegeria/commands/tech/list_elements_x.py +191 -0
  195. pyegeria/commands/tech/list_gov_action_processes.py +139 -0
  196. pyegeria/commands/tech/list_registered_services.py +180 -0
  197. pyegeria/commands/tech/list_related_elements.py +207 -0
  198. pyegeria/commands/tech/list_related_specification.py +169 -0
  199. pyegeria/commands/tech/list_relationship_types.py +164 -0
  200. pyegeria/commands/tech/list_relationships.py +179 -0
  201. pyegeria/commands/tech/list_tech_templates.py +360 -0
  202. pyegeria/commands/tech/list_valid_metadata_values.py +178 -0
  203. pyegeria/commands/tech/table_tech_templates.py +238 -0
  204. pyegeria/commands/tech/x_list_related_elements.py +165 -0
  205. pyegeria/core_omag_server_config.py +550 -313
  206. pyegeria/create_tech_guid_lists.py +105 -0
  207. pyegeria/egeria_cat_client.py +78 -0
  208. pyegeria/egeria_client.py +117 -0
  209. pyegeria/egeria_config_client.py +45 -0
  210. pyegeria/egeria_my_client.py +56 -0
  211. pyegeria/egeria_tech_client.py +93 -0
  212. pyegeria/feedback_manager_omvs.py +4573 -0
  213. pyegeria/full_omag_server_config.py +1337 -0
  214. pyegeria/glossary_browser_omvs.py +2507 -0
  215. pyegeria/glossary_manager_omvs.py +3597 -0
  216. pyegeria/mermaid_utilities.py +218 -0
  217. pyegeria/metadata_explorer_omvs.py +2371 -0
  218. pyegeria/my_profile_omvs.py +1021 -0
  219. pyegeria/platform_services.py +259 -218
  220. pyegeria/project_manager_omvs.py +1854 -0
  221. pyegeria/registered_info.py +111 -108
  222. pyegeria/runtime_manager_omvs.py +2299 -0
  223. pyegeria/server_operations.py +178 -71
  224. pyegeria/template_manager_omvs.py +1414 -0
  225. pyegeria/utils.py +75 -85
  226. pyegeria/valid_metadata_omvs.py +1911 -0
  227. pyegeria/x_action_author_omvs.py +200 -0
  228. pyegeria-5.3.0.dev3.dist-info/METADATA +70 -0
  229. pyegeria-5.3.0.dev3.dist-info/RECORD +232 -0
  230. {pyegeria-0.2.4.dist-info → pyegeria-5.3.0.dev3.dist-info}/WHEEL +1 -1
  231. pyegeria-5.3.0.dev3.dist-info/entry_points.txt +81 -0
  232. pyegeria/config.toml +0 -11
  233. pyegeria/curation_omvs.py +0 -458
  234. pyegeria/exceptions.py +0 -382
  235. pyegeria/glossary_omvs.py +0 -639
  236. pyegeria/gov_engine.py +0 -573
  237. pyegeria-0.2.4.dist-info/METADATA +0 -57
  238. pyegeria-0.2.4.dist-info/RECORD +0 -19
  239. {pyegeria-0.2.4.dist-info/licenses → pyegeria-5.3.0.dev3.dist-info}/LICENSE +0 -0
@@ -0,0 +1,321 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ SPDX-License-Identifier: Apache-2.0
4
+ Copyright Contributors to the ODPi Egeria project.
5
+
6
+
7
+ A simple status display for the Integration Daemon.
8
+
9
+
10
+ """
11
+ import argparse
12
+ import os
13
+ import time
14
+
15
+ from rich import box
16
+ from rich.console import Console
17
+ from rich.live import Live
18
+ from rich.prompt import Prompt
19
+ from rich.table import Table
20
+ import nest_asyncio
21
+ from typing import Union
22
+ from textual.widgets import DataTable
23
+
24
+ from pyegeria import EgeriaTech, AutomatedCuration
25
+ from pyegeria._exceptions import (
26
+ InvalidParameterException,
27
+ PropertyServerException,
28
+ UserNotAuthorizedException,
29
+ print_exception_response,
30
+ )
31
+
32
+ EGERIA_METADATA_STORE = os.environ.get("EGERIA_METADATA_STORE", "active-metadata-store")
33
+ EGERIA_KAFKA_ENDPOINT = os.environ.get("KAFKA_ENDPOINT", "localhost:9092")
34
+ EGERIA_PLATFORM_URL = os.environ.get("EGERIA_PLATFORM_URL", "https://localhost:9443")
35
+ EGERIA_VIEW_SERVER = os.environ.get("EGERIA_VIEW_SERVER", "view-server")
36
+ EGERIA_VIEW_SERVER_URL = os.environ.get(
37
+ "EGERIA_VIEW_SERVER_URL", "https://localhost:9443"
38
+ )
39
+ EGERIA_INTEGRATION_DAEMON = os.environ.get("INTEGRATION_DAEMON", "integration-daemon")
40
+ EGERIA_INTEGRATION_DAEMON_URL = os.environ.get(
41
+ "EGERIA_INTEGRATION_DAEMON_URL", "https://localhost:9443"
42
+ )
43
+ EGERIA_USER = os.environ.get("EGERIA_USER", "erinoverview")
44
+ EGERIA_USER_PASSWORD = os.environ.get("EGERIA_USER_PASSWORD", "secret")
45
+ EGERIA_JUPYTER = bool(os.environ.get("EGERIA_JUPYTER", "False"))
46
+ EGERIA_WIDTH = int(os.environ.get("EGERIA_WIDTH", "200"))
47
+
48
+ disable_ssl_warnings = True
49
+
50
+
51
+ def display_integration_daemon_status(
52
+ search_list: list[str] = ["*"],
53
+ integ_server: str = os.environ.get("EGERIA_INTEGRATION_DAEMON", "integration-daemon"),
54
+ integ_url: str = os.environ.get("EGERIA_INTEGRATION_DAEMON_URL", "https://localhost:9443"),
55
+ view_server: str = os.environ.get("EGERIA_VIEW_SERVER", "view-server"),
56
+ view_url: str = os.environ.get('EGERIA_VIEW_SERVER_URL', "https://localhost:9443"),
57
+ user: str = os.environ.get("EGERIA_USER"),
58
+ user_pass: str = os.environ.get("EGERIA_USER_PASSWORD"),
59
+ paging: bool = False,
60
+ jupyter: bool = os.environ.get("EGERIA_JUPYTER", "False"),
61
+ width: int = os.environ.get("EGERIA_WIDTH","150"),
62
+ sort: bool = True,
63
+ ) -> None:
64
+ """Display the status of connectors running on the specified Integration Daemon OMAG Server.
65
+
66
+ Parameters
67
+ ----------
68
+ search_list : list[str], optional
69
+ A list of connector names to search for. Default is ["*"], which returns all connectors.
70
+
71
+ integ_server : str, optional
72
+ The name of the integration daemon server. Default is EGERIA_INTEGRATION_DAEMON.
73
+
74
+ integ_url : str, optional
75
+ The URL of the integration daemon server. Default is EGERIA_INTEGRATION_DAEMON_URL.
76
+
77
+ view_server : str, optional
78
+ The name of the view server. Default is EGERIA_VIEW_SERVER.
79
+
80
+ view_url : str, optional
81
+ The URL of the view server. Default is EGERIA_VIEW_SERVER_URL.
82
+
83
+ user : str, optional
84
+ The username for authentication. Default is EGERIA_USER.
85
+
86
+ user_pass : str, optional
87
+ The password for authenticated access. Default is EGERIA_USER_PASSWORD.
88
+
89
+ paging : bool, optional
90
+ Determines whether to use paging or a live monitor for console output. Default is True.
91
+
92
+ jupyter : bool, optional
93
+ Determines whether running in a Jupyter environment. Default is EGERIA_JUPYTER.
94
+
95
+ width : int, optional
96
+ The width of the console display. Default is EGERIA_WIDTH.
97
+
98
+ sort : bool, optional
99
+ Determines whether to sort the connector reports. Default is True.
100
+
101
+ Returns
102
+ -------
103
+
104
+ Nothing
105
+ """
106
+ print(f"i={integ_server}\nv={view_server}\n")
107
+ s_client = EgeriaTech(view_server, view_url, user, user_pass)
108
+ token = s_client.create_egeria_bearer_token()
109
+
110
+ def generate_table(search_list: list[str]) -> Table:
111
+ """Make a new table."""
112
+ table = Table(
113
+ title=f"Integration Daemon Status @ {time.asctime()}",
114
+ style="bold white on black",
115
+ row_styles=["bold white on black"],
116
+ header_style="white on dark_blue",
117
+ title_style="bold white on black",
118
+ caption_style="white on black",
119
+ show_lines=True,
120
+ box=box.ROUNDED,
121
+ caption=f"Integration Daemon Status for Server '{integ_server}' @ Platform - {integ_url}",
122
+ expand=True,
123
+ )
124
+ table.add_column("Connector Name", min_width=15)
125
+ table.add_column("Status", max_width=6)
126
+
127
+ table.add_column("Last Refresh Time", min_width=12)
128
+ table.add_column("Min Refresh (mins)", max_width=6)
129
+ table.add_column("Target Element", min_width=20)
130
+ table.add_column("Exception Message", min_width=10)
131
+
132
+ # server_guid = s_client.get_guid_for_name(integ_server)
133
+ daemon_status = s_client.get_server_report(None, integ_server)
134
+
135
+ reports = daemon_status["integrationConnectorReports"]
136
+ if sort is True:
137
+ connector_reports = sorted(
138
+ reports, key=lambda x: x.get("connectorName", "---")
139
+ )
140
+ else:
141
+ connector_reports = reports
142
+
143
+ for connector in connector_reports:
144
+ connector_name = connector.get("connectorName", "---")
145
+
146
+ if (connector_name not in search_list) and (search_list != ["*"]):
147
+ # if specific connectors are requested and it doesn't match, then skip
148
+ continue
149
+
150
+ connector_status = connector.get("connectorStatus", "---")
151
+ connector_guid = connector.get("connectorGUID", "---")
152
+ last_refresh_time = connector.get("lastRefreshTime", "---")[:-10]
153
+ refresh_interval = str(connector.get("minMinutesBetweenRefresh", "---"))
154
+ exception_msg = " "
155
+ if connector_guid != "---":
156
+ targets = s_client.get_catalog_targets(connector_guid)
157
+ tgt_tab = Table()
158
+ tgt_tab.add_column("Target")
159
+ tgt_tab.add_column("UniqueName")
160
+ tgt_tab.add_column("Relationship GUID", no_wrap=True)
161
+
162
+ if type(targets) == list:
163
+ targets_md = True
164
+ for target in targets:
165
+ t_name = target["catalogTargetName"]
166
+ # t_sync = target["permittedSynchronization"]
167
+ t_unique_name = target["catalogTargetElement"]["uniqueName"]
168
+ t_rel_guid = target["relationshipGUID"]
169
+ # targets_m += f"* Target Name: __{t_name}__\n* Sync: {t_sync}\n* Unique Name: {t_unique_name}\n\n"
170
+ tgt_tab.add_row(t_name, t_unique_name, t_rel_guid)
171
+ # targets_md = Markdown(targets_m)
172
+ else:
173
+ targets_md = False
174
+ else:
175
+ targets_md = False
176
+ if targets_md is False:
177
+ targets_out = ""
178
+ else:
179
+ targets_out = tgt_tab
180
+
181
+ if connector_status in ("RUNNING", "REFRESHING", "WAITING"):
182
+ connector_status = f"[green]{connector_status}"
183
+ elif connector_status in ("INITIALIZE FAILED", "CONFIG_FAILED", "FAILED"):
184
+ connector_status = f"[red]{connector_status}"
185
+ else:
186
+ connector_status = f"[yellow]{connector_status}"
187
+
188
+ table.add_row(
189
+ connector_name,
190
+ connector_status,
191
+ last_refresh_time,
192
+ refresh_interval,
193
+ targets_out,
194
+ exception_msg,
195
+ )
196
+
197
+ return table
198
+
199
+ try:
200
+ if paging is True:
201
+ console = Console(width=width) # main_pagig, force_terminal=not jupyter)
202
+ with console.pager():
203
+ console.print(generate_table(search_list))
204
+ else:
205
+ with Live(
206
+ generate_table(search_list),
207
+ refresh_per_second=1,
208
+ screen=True,
209
+ vertical_overflow="visible",
210
+ ) as live:
211
+ while True:
212
+ time.sleep(2)
213
+ live.update(generate_table(search_list))
214
+
215
+ except (
216
+ InvalidParameterException,
217
+ PropertyServerException,
218
+ UserNotAuthorizedException,
219
+ ) as e:
220
+ print_exception_response(e)
221
+
222
+ except KeyboardInterrupt:
223
+ pass
224
+
225
+ finally:
226
+ s_client.close_session()
227
+
228
+
229
+ def main_live(paging: bool = False) -> None:
230
+ parser = argparse.ArgumentParser()
231
+ parser.add_argument(
232
+ "--integ_server", help="Name of the integration server to display status for"
233
+ )
234
+ parser.add_argument("--integ_url", help="URL Platform to connect to")
235
+ parser.add_argument("--view_server", help="Name of the view server to use")
236
+ parser.add_argument("--view_url", help="view server URL Platform to connect to")
237
+ parser.add_argument("--userid", help="User Id")
238
+ parser.add_argument("--password", help="User Password")
239
+
240
+ args = parser.parse_args()
241
+
242
+ integ_server = (
243
+ args.integ_server
244
+ if args.integ_server is not None
245
+ else EGERIA_INTEGRATION_DAEMON
246
+ )
247
+ integ_url = (
248
+ args.integ_url if args.integ_url is not None else EGERIA_INTEGRATION_DAEMON_URL
249
+ )
250
+ view_server = (
251
+ args.view_server if args.view_server is not None else EGERIA_VIEW_SERVER
252
+ )
253
+ view_url = args.view_url if args.view_url is not None else EGERIA_VIEW_SERVER_URL
254
+ userid = args.userid if args.userid is not None else EGERIA_USER
255
+ user_pass = args.password if args.password is not None else EGERIA_USER_PASSWORD
256
+
257
+ search_list = Prompt.ask(
258
+ "Enter the list of connectors you are interested in or '*' for all",
259
+ default="*",
260
+ )
261
+ print(f"i={integ_server}\nv={view_server}\n")
262
+ display_integration_daemon_status(
263
+ search_list=[search_list],
264
+ integ_server=integ_server,
265
+ integ_url=integ_url,
266
+ view_server=view_server,
267
+ view_url=view_url,
268
+ user=userid,
269
+ user_pass=user_pass,
270
+ paging=paging,
271
+ )
272
+
273
+
274
+ def main_paging(paging: bool = True) -> None:
275
+ parser = argparse.ArgumentParser()
276
+ parser.add_argument(
277
+ "--integ_server", help="Name of the integration server to display status for"
278
+ )
279
+ parser.add_argument("--integ_url", help="URL Platform to connect to")
280
+ parser.add_argument("--view_server", help="Name of the view server to use")
281
+ parser.add_argument("--view_url", help="view server URL Platform to connect to")
282
+ parser.add_argument("--userid", help="User Id")
283
+ parser.add_argument("--password", help="User Password")
284
+
285
+ args = parser.parse_args()
286
+
287
+ integ_server = (
288
+ args.integ_server
289
+ if args.integ_server is not None
290
+ else EGERIA_INTEGRATION_DAEMON
291
+ )
292
+ integ_url = (
293
+ args.integ_url if args.integ_url is not None else EGERIA_INTEGRATION_DAEMON_URL
294
+ )
295
+ view_server = (
296
+ args.view_server if args.view_server is not None else EGERIA_VIEW_SERVER
297
+ )
298
+ view_url = args.view_url if args.view_url is not None else EGERIA_VIEW_SERVER_URL
299
+ userid = args.userid if args.userid is not None else EGERIA_USER
300
+ user_pass = args.password if args.password is not None else EGERIA_USER_PASSWORD
301
+ search_list = Prompt.ask(
302
+ "Enter the list of connectors you are interested in or '*' for all",
303
+ default="*",
304
+ )
305
+ display_integration_daemon_status(
306
+ search_list=[search_list],
307
+ integ_server=integ_server,
308
+ integ_url=integ_url,
309
+ view_server=view_server,
310
+ view_url=view_url,
311
+ user=userid,
312
+ user_pass=user_pass,
313
+ paging=paging,
314
+ )
315
+
316
+
317
+ if __name__ == "__main__":
318
+ main_live(paging=False)
319
+
320
+ if __name__ == "__main_paging__":
321
+ main_paging(paging=True)
@@ -0,0 +1,188 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ SPDX-License-Identifier: Apache-2.0
4
+ Copyright Contributors to the ODPi Egeria project.
5
+
6
+ Display the status of cataloged platforms and servers.
7
+ """
8
+
9
+ import argparse
10
+ import os, sys
11
+ import time
12
+
13
+ from rich.console import Console
14
+ from rich.live import Live
15
+ from rich.markdown import Markdown
16
+ from rich.table import Table
17
+
18
+ from pyegeria import RuntimeManager
19
+ from pyegeria._exceptions import (
20
+ InvalidParameterException,
21
+ PropertyServerException,
22
+ UserNotAuthorizedException,
23
+ print_exception_response,
24
+ )
25
+
26
+ EGERIA_METADATA_STORE = os.environ.get("EGERIA_METADATA_STORE", "active-metadata-store")
27
+ EGERIA_KAFKA_ENDPOINT = os.environ.get("KAFKA_ENDPOINT", "localhost:9092")
28
+ EGERIA_PLATFORM_URL = os.environ.get("EGERIA_PLATFORM_URL", "https://localhost:9443")
29
+ EGERIA_VIEW_SERVER = os.environ.get("VIEW_SERVER", "view-server")
30
+ EGERIA_VIEW_SERVER_URL = os.environ.get(
31
+ "EGERIA_VIEW_SERVER_URL", "https://localhost:9443"
32
+ )
33
+ EGERIA_INTEGRATION_DAEMON = os.environ.get("INTEGRATION_DAEMON", "integration-daemon")
34
+ EGERIA_INTEGRATION_DAEMON_URL = os.environ.get(
35
+ "EGERIA_INTEGRATION_DAEMON_URL", "https://localhost:9443"
36
+ )
37
+ EGERIA_ADMIN_USER = os.environ.get("ADMIN_USER", "garygeeke")
38
+ EGERIA_ADMIN_PASSWORD = os.environ.get("ADMIN_PASSWORD", "secret")
39
+ EGERIA_USER = os.environ.get("EGERIA_USER", "erinoverview")
40
+ EGERIA_USER_PASSWORD = os.environ.get("EGERIA_USER_PASSWORD", "secret")
41
+ EGERIA_JUPYTER = bool(os.environ.get("EGERIA_JUPYTER", "False"))
42
+ EGERIA_WIDTH = int(os.environ.get("EGERIA_WIDTH", "200"))
43
+
44
+ disable_ssl_warnings = True
45
+ console = Console(width=EGERIA_WIDTH)
46
+
47
+
48
+ def display_status(
49
+ view_server: str = EGERIA_VIEW_SERVER,
50
+ view_url: str = EGERIA_VIEW_SERVER_URL,
51
+ user: str = EGERIA_USER,
52
+ user_pass: str = EGERIA_USER_PASSWORD,
53
+ jupyter: bool = EGERIA_JUPYTER,
54
+ width: int = EGERIA_WIDTH,
55
+ ):
56
+ r_client = RuntimeManager(view_server, view_url, user)
57
+ token = r_client.create_egeria_bearer_token(user, user_pass)
58
+
59
+ def generate_table() -> Table:
60
+ """Make a new table."""
61
+ table = Table(
62
+ title=f"Server Status for Platform - {time.asctime()}",
63
+ # style="bold white on black",
64
+ row_styles=["bold white on black"],
65
+ header_style="white on dark_blue",
66
+ title_style="bold white on black",
67
+ caption_style="white on black",
68
+ caption=f"Status of Platforms - '{view_url}'",
69
+ show_lines=True,
70
+ # expand=True
71
+ )
72
+ table.add_column("Platform Name & GUID")
73
+ # table.add_column("Platform GUID")
74
+ table.add_column("Platform URL")
75
+ table.add_column("Platform Origin")
76
+ table.add_column("Description")
77
+ table.add_column("Platform Started")
78
+ table.add_column("Servers")
79
+
80
+ server_types = {
81
+ "Metadata Access Store": "Store",
82
+ "View Server": "View",
83
+ "Engine Host Server": "EngineHost",
84
+ "Integration Daemon": "Integration",
85
+ }
86
+ try:
87
+ platform_list = r_client.get_platforms_by_type()
88
+ if type(platform_list) is str:
89
+ print("No OMAG Server Platforms found?")
90
+ sys.exit(1)
91
+
92
+ for platform in platform_list:
93
+ platform_name = platform["properties"].get("displayName", "---")
94
+ platform_guid = platform["elementHeader"]["guid"]
95
+ platform_desc = platform["properties"].get("resourceDescription", "---")
96
+ server_list = ""
97
+
98
+ platform_report = r_client.get_platform_report(platform_guid)
99
+ platform_url = platform_report.get("platformURLRoot", " ")
100
+ platform_origin = platform_report.get("platformOrigin", " ")
101
+ platform_build = platform_report.get("platformBuildProperties", " ")
102
+ platform_build_md = ""
103
+ if type(platform_build) is dict:
104
+ for prop in platform_build:
105
+ platform_build_md = (
106
+ f"{platform_build_md}\n* {prop}: {platform_build[prop]}"
107
+ )
108
+ platform_build_out = Markdown(platform_build_md)
109
+ else:
110
+ platform_build_out = platform_origin
111
+ platform_desc = f"{platform_desc}\n\n\t\t&\n\n{platform_build}"
112
+ platform_started = platform_report.get("platformStartTime", " ")
113
+ platform_id = f"{platform_name}\n\n\t\t&\n\n{platform_guid}"
114
+
115
+ servers = platform_report.get("omagservers", None)
116
+
117
+ if servers is not None:
118
+ for server in servers:
119
+ server_name = server.get("serverName", " ")
120
+ server_type = server.get("serverType", " ")
121
+ server_status = server.get("serverActiveStatus", "UNKNOWN")
122
+ if server_status in ("RUNNING", "STARTING"):
123
+ status_flag = "[bright green]"
124
+ elif server_status in ("INACTIVE", "STOPPING"):
125
+ status_flag = "[bright red]"
126
+ else:
127
+ server_status = "UNKNOWN"
128
+ status_flag = "[bright yellow]"
129
+
130
+ server_list += (
131
+ f"{status_flag}{server_types[server_type]}: {server_name}\n"
132
+ )
133
+
134
+ table.add_row(
135
+ platform_id,
136
+ platform_url,
137
+ platform_build_out,
138
+ platform_desc,
139
+ platform_started,
140
+ server_list,
141
+ style="bold white on black",
142
+ )
143
+
144
+ except Exception as e:
145
+ # console.print_exception(e)
146
+ platform_url = " "
147
+ platform_origin = " "
148
+ platform_started = " "
149
+
150
+ return table
151
+
152
+ try:
153
+ with Live(generate_table(), refresh_per_second=4, screen=True) as live:
154
+ while True:
155
+ time.sleep(2)
156
+ live.update(generate_table())
157
+
158
+ except (
159
+ InvalidParameterException,
160
+ PropertyServerException,
161
+ UserNotAuthorizedException,
162
+ ) as e:
163
+ print_exception_response(e)
164
+
165
+ except KeyboardInterrupt:
166
+ pass
167
+ finally:
168
+ r_client.close_session()
169
+
170
+
171
+ def main():
172
+ parser = argparse.ArgumentParser()
173
+ parser.add_argument("--server", help="Name of the server to display status for")
174
+ parser.add_argument("--url", help="URL Platform to connect to")
175
+ parser.add_argument("--userid", help="User Id")
176
+ parser.add_argument("--password", help="User Password")
177
+ args = parser.parse_args()
178
+
179
+ server = args.server if args.server is not None else EGERIA_VIEW_SERVER
180
+ url = args.url if args.url is not None else EGERIA_PLATFORM_URL
181
+ userid = args.userid if args.userid is not None else EGERIA_USER
182
+ user_pass = args.password if args.password is not None else EGERIA_USER_PASSWORD
183
+
184
+ display_status(server, url, userid, user_pass)
185
+
186
+
187
+ if __name__ == "__main__":
188
+ main()
@@ -0,0 +1,117 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ SPDX-License-Identifier: Apache-2.0
4
+ Copyright Contributors to the ODPi Egeria project.
5
+
6
+ Unit tests for the Utils helper functions using the Pytest framework.
7
+
8
+
9
+ A simple server status display using the OMAS services.
10
+ """
11
+ import os
12
+ import time
13
+ import argparse
14
+
15
+ from pyegeria import (
16
+ InvalidParameterException,
17
+ PropertyServerException,
18
+ UserNotAuthorizedException,
19
+ print_exception_response,
20
+ ServerOps,
21
+ )
22
+ from rich.table import Table
23
+ from rich.live import Live
24
+
25
+
26
+ EGERIA_METADATA_STORE = os.environ.get("EGERIA_METADATA_STORE", "active-metadata-store")
27
+ EGERIA_KAFKA_ENDPOINT = os.environ.get("KAFKA_ENDPOINT", "localhost:9092")
28
+ EGERIA_PLATFORM_URL = os.environ.get("EGERIA_PLATFORM_URL", "https://localhost:9443")
29
+ EGERIA_VIEW_SERVER = os.environ.get("VIEW_SERVER", "view-server")
30
+ EGERIA_VIEW_SERVER_URL = os.environ.get(
31
+ "EGERIA_VIEW_SERVER_URL", "https://localhost:9443"
32
+ )
33
+ EGERIA_INTEGRATION_DAEMON = os.environ.get("INTEGRATION_DAEMON", "integration-daemon")
34
+ EGERIA_ADMIN_USER = os.environ.get("ADMIN_USER", "garygeeke")
35
+ EGERIA_ADMIN_PASSWORD = os.environ.get("ADMIN_PASSWORD", "secret")
36
+ EGERIA_USER = os.environ.get("EGERIA_USER", "erinoverview")
37
+ EGERIA_USER_PASSWORD = os.environ.get("EGERIA_USER_PASSWORD", "secret")
38
+ EGERIA_JUPYTER = bool(os.environ.get("EGERIA_JUPYTER", "False"))
39
+ EGERIA_WIDTH = int(os.environ.get("EGERIA_WIDTH", "220"))
40
+
41
+
42
+ def display_startup_status(
43
+ server: str,
44
+ url: str,
45
+ username: str,
46
+ password: str = EGERIA_USER_PASSWORD,
47
+ jupyter: bool = EGERIA_JUPYTER,
48
+ width: int = EGERIA_WIDTH,
49
+ ):
50
+ p_client = ServerOps(server, url, username)
51
+
52
+ def generate_table() -> Table:
53
+ """Make a new table."""
54
+ table = Table(
55
+ title=f"Server Status for Platform - {time.asctime()}",
56
+ # style = "black on grey66",
57
+ header_style="white on dark_blue",
58
+ caption=f"Server Status for Platform - '{url}'",
59
+ # show_lines=True,
60
+ )
61
+
62
+ table.add_column("Known Server")
63
+ table.add_column("Status")
64
+
65
+ known_server_list = p_client.get_known_servers()
66
+ active_server_list = p_client.get_active_server_list()
67
+ if len(known_server_list) == 0:
68
+ return table
69
+
70
+ for server in known_server_list:
71
+ if server in active_server_list:
72
+ status = "Active"
73
+ else:
74
+ status = "Inactive"
75
+
76
+ table.add_row(
77
+ server,
78
+ "[red]Inactive" if status == "Inactive" else "[green]Active",
79
+ )
80
+ # p_client.close_session()
81
+ return table
82
+
83
+ try:
84
+ with Live(generate_table(), refresh_per_second=4, screen=True) as live:
85
+ while True:
86
+ time.sleep(2)
87
+ live.update(generate_table())
88
+ # services = p_client.get_server_status(server)['serverStatus']['services']
89
+ # for service in services:
90
+ # service_name = service['serviceName']
91
+ # service_status = service['serviceStatus']
92
+
93
+ except (
94
+ InvalidParameterException,
95
+ PropertyServerException,
96
+ UserNotAuthorizedException,
97
+ ) as e:
98
+ print_exception_response(e)
99
+ assert e.related_http_code != "200", "Invalid parameters"
100
+
101
+
102
+ def main():
103
+ parser = argparse.ArgumentParser()
104
+ parser.add_argument("--server", help="Name of the server to display status for")
105
+ parser.add_argument("--url", help="URL Platform to connect to")
106
+ parser.add_argument("--userid", help="User Id")
107
+ args = parser.parse_args()
108
+
109
+ server = args.server if args.server is not None else "active-metadata-store"
110
+ url = args.url if args.url is not None else "https://localhost:9443"
111
+ userid = args.userid if args.userid is not None else "garygeeke"
112
+
113
+ display_startup_status(server, url, userid)
114
+
115
+
116
+ if __name__ == "__main__":
117
+ main()