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,360 @@
1
+ """This creates a templates guid file from the core metadata archive"""
2
+
3
+ import argparse
4
+ import os
5
+ import sys
6
+ import time
7
+ from typing import Union
8
+
9
+ import nest_asyncio
10
+ from rich import box
11
+ from rich.console import Console
12
+ from rich.prompt import Prompt
13
+ from rich.table import Table
14
+ from textual.widgets import DataTable
15
+
16
+ from pyegeria import AutomatedCuration
17
+ from pyegeria import (
18
+ InvalidParameterException,
19
+ PropertyServerException,
20
+ UserNotAuthorizedException,
21
+ print_exception_response,
22
+ )
23
+
24
+ console = Console()
25
+ EGERIA_METADATA_STORE = os.environ.get("EGERIA_METADATA_STORE", "active-metadata-store")
26
+ EGERIA_KAFKA_ENDPOINT = os.environ.get("KAFKA_ENDPOINT", "localhost:9092")
27
+ EGERIA_PLATFORM_URL = os.environ.get("EGERIA_PLATFORM_URL", "https://localhost:9443")
28
+ EGERIA_VIEW_SERVER = os.environ.get("VIEW_SERVER", "view-server")
29
+ EGERIA_VIEW_SERVER_URL = os.environ.get(
30
+ "EGERIA_VIEW_SERVER_URL", "https://localhost:9443"
31
+ )
32
+ EGERIA_INTEGRATION_DAEMON = os.environ.get("INTEGRATION_DAEMON", "integration-daemon")
33
+ EGERIA_ADMIN_USER = os.environ.get("ADMIN_USER", "garygeeke")
34
+ EGERIA_ADMIN_PASSWORD = os.environ.get("ADMIN_PASSWORD", "secret")
35
+ EGERIA_USER = os.environ.get("EGERIA_USER", "erinoverview")
36
+ EGERIA_USER_PASSWORD = os.environ.get("EGERIA_USER_PASSWORD", "secret")
37
+ EGERIA_JUPYTER = bool(os.environ.get("EGERIA_JUPYTER", "False"))
38
+ EGERIA_WIDTH = int(os.environ.get("EGERIA_WIDTH", "200"))
39
+
40
+
41
+ def list_templates(
42
+ search_string: str, server: str, url: str, username: str, password: str
43
+ ) -> []:
44
+ """Return a list of templates for one or more technology type"""
45
+ a_client = AutomatedCuration(server, url, username)
46
+ token = a_client.create_egeria_bearer_token(username, password)
47
+ tech_list = a_client.find_technology_types(search_string, page_size=0)
48
+ tech_info_list: dict = []
49
+
50
+ if type(tech_list) is list:
51
+ for item in tech_list:
52
+ if "deployedImplementationType" not in item["qualifiedName"]:
53
+ continue
54
+
55
+ details = a_client.get_technology_type_detail(item["name"])
56
+ entry = {details["name"]: {}}
57
+ if type(details) is str:
58
+ tech_info_list.append(entry)
59
+ continue
60
+ templates = details.get("catalogTemplates", "Not Found")
61
+ if type(templates) is list:
62
+ t_list = []
63
+ entry = {details["name"]: {}}
64
+ for template in templates:
65
+ t_list.append({"template": template["name"]})
66
+ entry[details["name"]] = t_list
67
+ tech_info_list.append(entry)
68
+ return tech_info_list
69
+
70
+
71
+ def add_row(
72
+ table: Union[Table, DataTable],
73
+ name: str,
74
+ template_name: str,
75
+ template_guid: str,
76
+ placeholder_table: Table,
77
+ ) -> Table | DataTable:
78
+ if isinstance(table, Table):
79
+ table.add_row(name, template_name, template_guid, placeholder_table)
80
+ elif isinstance(table, DataTable):
81
+ table.add_row(name, template_name, template_guid, placeholder_table)
82
+
83
+ return table
84
+
85
+
86
+ def display_templates_spec(
87
+ search_string: str,
88
+ server: str,
89
+ url: str,
90
+ username: str,
91
+ password: str,
92
+ jupyter: bool = EGERIA_JUPYTER,
93
+ width: int = EGERIA_WIDTH,
94
+ data_table: bool = False,
95
+ ) -> Table | DataTable:
96
+ a_client = AutomatedCuration(server, url, username)
97
+ nest_asyncio.apply()
98
+ token = a_client.create_egeria_bearer_token(username, password)
99
+ tech_list = a_client.find_technology_types(search_string, page_size=0)
100
+
101
+ def generate_table(data_table: bool) -> Table | DataTable:
102
+ """Make a new table."""
103
+ if data_table:
104
+ table = DataTable()
105
+ table.add_columns("Name", "Template Name", "Template GUID", "Placeholders")
106
+ else:
107
+ table = Table(
108
+ title=f"Technology Templates for: {url} @ {time.asctime()}",
109
+ style="bold bright_white on black",
110
+ row_styles=["bold bright_white on black"],
111
+ header_style="white on dark_blue",
112
+ title_style="bold bright_white on black",
113
+ caption_style="white on black",
114
+ show_lines=True,
115
+ box=box.ROUNDED,
116
+ caption=f"Templates from Server '{server}' @ Platform - {url}",
117
+ expand=True,
118
+ # width=500
119
+ )
120
+
121
+ table.add_column("Name", width=20)
122
+ table.add_column("Template Name", width=20)
123
+ table.add_column("Template GUID", width=38, no_wrap=True)
124
+ table.add_column("Placeholders")
125
+
126
+ if type(tech_list) is list:
127
+ for item in tech_list:
128
+ if "deployedImplementationType" not in item["qualifiedName"]:
129
+ continue
130
+ placeholder_table = Table(expand=False, show_lines=True)
131
+ placeholder_table.add_column("Name", width=20, no_wrap=True)
132
+ placeholder_table.add_column("Type", width=10)
133
+ placeholder_table.add_column("Required", width=10)
134
+ placeholder_table.add_column("Example", width=20)
135
+ placeholder_table.add_column("Description", width=40)
136
+
137
+ name = item.get("name", "none")
138
+
139
+ details = a_client.get_technology_type_detail(name)
140
+ if type(details) is str:
141
+ console.log(f"Missing details for - {name}: {details}")
142
+ continue
143
+
144
+ templates = details.get("catalogTemplates", "Not Found")
145
+ if type(templates) is not str:
146
+ for template in templates:
147
+ template_name = template.get("name", None)
148
+
149
+ template_name = (
150
+ f"{name}_Template"
151
+ if template_name is None
152
+ else template_name
153
+ )
154
+
155
+ specification = template["specification"]["placeholderProperty"]
156
+ template_guid = template["relatedElement"]["guid"]
157
+
158
+ for placeholder in specification:
159
+ placeholder_data_type = placeholder["dataType"]
160
+ placeholder_description = placeholder["description"]
161
+ placeholder_name = placeholder["placeholderPropertyName"]
162
+ placeholder_required = placeholder["required"]
163
+ placeholder_example = placeholder.get("example", None)
164
+ placeholder_table.add_row(
165
+ placeholder_name,
166
+ placeholder_data_type,
167
+ placeholder_required,
168
+ placeholder_example,
169
+ placeholder_description,
170
+ )
171
+
172
+ # table.add_row(name, template_name, template_guid, placeholder_table)
173
+ table = add_row(
174
+ table, name, template_name, template_guid, placeholder_table
175
+ )
176
+
177
+ return table
178
+ else:
179
+ print("Unknown technology type")
180
+ sys.exit(1)
181
+
182
+ try:
183
+ if data_table:
184
+ return generate_table(data_table)
185
+ else:
186
+ console = Console(width=width, force_terminal=not jupyter)
187
+
188
+ with console.pager(styles=True):
189
+ console.print(generate_table(data_table))
190
+
191
+ except (
192
+ InvalidParameterException,
193
+ PropertyServerException,
194
+ UserNotAuthorizedException,
195
+ ) as e:
196
+ print_exception_response(e)
197
+ assert e.related_http_code != "200", "Invalid parameters"
198
+ finally:
199
+ a_client.close_session()
200
+
201
+
202
+ def main():
203
+ parser = argparse.ArgumentParser()
204
+ parser.add_argument("--server", help="Name of the server to display status for")
205
+ parser.add_argument("--url", help="URL Platform to connect to")
206
+ parser.add_argument("--userid", help="User Id")
207
+ parser.add_argument("--password", help="Password")
208
+
209
+ args = parser.parse_args()
210
+
211
+ server = args.server if args.server is not None else EGERIA_VIEW_SERVER
212
+ url = args.url if args.url is not None else EGERIA_PLATFORM_URL
213
+ userid = args.userid if args.userid is not None else EGERIA_USER
214
+ password = args.password if args.password is not None else EGERIA_USER_PASSWORD
215
+ guid = None
216
+
217
+ try:
218
+ search_string = Prompt.ask(
219
+ "Enter the technology you are searching for:", default="*"
220
+ )
221
+ display_templates_spec(
222
+ search_string, server, url, userid, password, data_table=False
223
+ )
224
+ except KeyboardInterrupt:
225
+ pass
226
+
227
+
228
+ # def display_templates_spec(
229
+ # search_string: str,
230
+ # server: str,
231
+ # url: str,
232
+ # username: str,
233
+ # password: str,
234
+ # jupyter: bool = EGERIA_JUPYTER,
235
+ # width: int = EGERIA_WIDTH,
236
+ # ):
237
+ # a_client = AutomatedCuration(server, url, username)
238
+ # token = a_client.create_egeria_bearer_token(username, password)
239
+ # tech_list = a_client.find_technology_types(search_string, page_size=0)
240
+ #
241
+ # def generate_table() -> Table:
242
+ # """Make a new table."""
243
+ # table = Table(
244
+ # title=f"Technology Templates for: {url} @ {time.asctime()}",
245
+ # style="bold bright_white on black",
246
+ # row_styles=["bold bright_white on black"],
247
+ # header_style="white on dark_blue",
248
+ # title_style="bold bright_white on black",
249
+ # caption_style="white on black",
250
+ # show_lines=True,
251
+ # box=box.ROUNDED,
252
+ # caption=f"Templates from Server '{server}' @ Platform - {url}",
253
+ # expand=True,
254
+ # # width=500
255
+ # )
256
+ #
257
+ # table.add_column("Name", width=20)
258
+ # table.add_column("Template Name", width=20)
259
+ # table.add_column("Template GUID", width=38, no_wrap=True)
260
+ # table.add_column("Placeholders")
261
+ #
262
+ # if type(tech_list) is list:
263
+ # for item in tech_list:
264
+ # if "deployedImplementationType" not in item["qualifiedName"]:
265
+ # continue
266
+ # placeholder_table = Table(expand=False, show_lines=True)
267
+ # placeholder_table.add_column("Name", width=20, no_wrap=True)
268
+ # placeholder_table.add_column("Type", width=10)
269
+ # placeholder_table.add_column("Required", width=10)
270
+ # placeholder_table.add_column("Example", width=20)
271
+ # placeholder_table.add_column("Description", width=40)
272
+ #
273
+ # name = item.get("name", "none")
274
+ #
275
+ # details = a_client.get_technology_type_detail(name)
276
+ # if type(details) is str:
277
+ # console.log(f"Missing details for - {name}: {details}")
278
+ # continue
279
+ #
280
+ # templates = details.get("catalogTemplates", "Not Found")
281
+ # if type(templates) is not str:
282
+ # for template in templates:
283
+ # template_name = template.get("name", None)
284
+ #
285
+ # template_name = (
286
+ # f"{name}_Template"
287
+ # if template_name is None
288
+ # else template_name
289
+ # )
290
+ #
291
+ # specification = template["specification"]["placeholderProperty"]
292
+ # template_guid = template["relatedElement"]["guid"]
293
+ #
294
+ # for placeholder in specification:
295
+ # placeholder_data_type = placeholder["dataType"]
296
+ # placeholder_description = placeholder["description"]
297
+ # placeholder_name = placeholder["placeholderPropertyName"]
298
+ # placeholder_required = placeholder["required"]
299
+ # placeholder_example = placeholder.get("example", None)
300
+ # placeholder_table.add_row(
301
+ # placeholder_name,
302
+ # placeholder_data_type,
303
+ # placeholder_required,
304
+ # placeholder_example,
305
+ # placeholder_description,
306
+ # )
307
+ #
308
+ # table.add_row(
309
+ # name, template_name, template_guid, placeholder_table
310
+ # )
311
+ #
312
+ # return table
313
+ # else:
314
+ # print("Unknown technology type")
315
+ # sys.exit(1)
316
+ #
317
+ # try:
318
+ # console = Console(width=width, force_terminal=not jupyter)
319
+ #
320
+ # with console.pager(styles=True):
321
+ # console.print(generate_table())
322
+ #
323
+ # except (
324
+ # InvalidParameterException,
325
+ # PropertyServerException,
326
+ # UserNotAuthorizedException,
327
+ # ) as e:
328
+ # print_exception_response(e)
329
+ # assert e.related_http_code != "200", "Invalid parameters"
330
+ # finally:
331
+ # a_client.close_session()
332
+ #
333
+ #
334
+ # def main():
335
+ # parser = argparse.ArgumentParser()
336
+ # parser.add_argument("--server", help="Name of the server to display status for")
337
+ # parser.add_argument("--url", help="URL Platform to connect to")
338
+ # parser.add_argument("--userid", help="User Id")
339
+ # parser.add_argument("--password", help="Password")
340
+ #
341
+ # args = parser.parse_args()
342
+ #
343
+ # server = args.server if args.server is not None else EGERIA_VIEW_SERVER
344
+ # url = args.url if args.url is not None else EGERIA_PLATFORM_URL
345
+ # userid = args.userid if args.userid is not None else EGERIA_USER
346
+ # password = args.password if args.password is not None else EGERIA_USER_PASSWORD
347
+ # guid = None
348
+ #
349
+ # try:
350
+ # search_string = Prompt.ask(
351
+ # "Enter the technology you are searching for:", default="*"
352
+ # )
353
+ # # display_templates_spec(search_string, server, url, userid, password)
354
+ # list_templates(search_string, server, url, userid, password)
355
+ # except KeyboardInterrupt:
356
+ # pass
357
+ #
358
+ #
359
+ # if __name__ == "__main__":
360
+ # main()
@@ -0,0 +1,178 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ SPDX-Lic
4
+ ense-Identifier: Apache-2.0
5
+ Copyright Contributors to the ODPi Egeria project.
6
+
7
+ Unit tests for the Utils helper functions using the Pytest framework.
8
+
9
+
10
+ A simple display for glossary terms
11
+ """
12
+ import os
13
+ import argparse
14
+ import json
15
+ import time
16
+
17
+ from rich import box
18
+ from rich import print
19
+ from rich.console import Console
20
+ from rich.prompt import Prompt
21
+ from rich.table import Table
22
+
23
+ from pyegeria import (
24
+ InvalidParameterException,
25
+ PropertyServerException,
26
+ UserNotAuthorizedException,
27
+ print_exception_response,
28
+ )
29
+ from pyegeria import ValidMetadataManager
30
+
31
+ EGERIA_METADATA_STORE = os.environ.get("EGERIA_METADATA_STORE", "active-metadata-store")
32
+ EGERIA_KAFKA_ENDPOINT = os.environ.get("KAFKA_ENDPOINT", "localhost:9092")
33
+ EGERIA_PLATFORM_URL = os.environ.get("EGERIA_PLATFORM_URL", "https://localhost:9443")
34
+ EGERIA_VIEW_SERVER = os.environ.get("VIEW_SERVER", "view-server")
35
+ EGERIA_VIEW_SERVER_URL = os.environ.get(
36
+ "EGERIA_VIEW_SERVER_URL", "https://localhost:9443"
37
+ )
38
+ EGERIA_INTEGRATION_DAEMON = os.environ.get("INTEGRATION_DAEMON", "integration-daemon")
39
+ EGERIA_ADMIN_USER = os.environ.get("ADMIN_USER", "garygeeke")
40
+ EGERIA_ADMIN_PASSWORD = os.environ.get("ADMIN_PASSWORD", "secret")
41
+ EGERIA_USER = os.environ.get("EGERIA_USER", "erinoverview")
42
+ EGERIA_USER_PASSWORD = os.environ.get("EGERIA_USER_PASSWORD", "secret")
43
+ EGERIA_JUPYTER = bool(os.environ.get("EGERIA_JUPYTER", "False"))
44
+ EGERIA_WIDTH = int(os.environ.get("EGERIA_WIDTH", "200"))
45
+
46
+
47
+ def display_metadata_values(
48
+ property_name: str,
49
+ type_name: str,
50
+ server: str,
51
+ url: str,
52
+ username: str,
53
+ user_pass: str,
54
+ save_output: bool,
55
+ jupyter: bool = EGERIA_JUPYTER,
56
+ width: int = EGERIA_WIDTH,
57
+ ):
58
+ m_client = ValidMetadataManager(server, url, user_id=username)
59
+ token = m_client.create_egeria_bearer_token(username, user_pass)
60
+
61
+ def generate_table(property_name: str, type_name: str) -> Table:
62
+ """Make a new table."""
63
+ table = Table(
64
+ title=f"Valid Metadata Values for Property: {property_name} of type {type_name} @ {time.asctime()}",
65
+ style="bold bright_white on black",
66
+ row_styles=["bold bright_white on black"],
67
+ header_style="white on dark_blue",
68
+ title_style="bold white on black",
69
+ caption_style="white on black",
70
+ show_lines=True,
71
+ box=box.ROUNDED,
72
+ caption=f"Valid Metadata Values for Server '{server}' @ Platform - {url}",
73
+ expand=True,
74
+ )
75
+
76
+ table.add_column("Category")
77
+ table.add_column("Display Name")
78
+
79
+ table.add_column("Preferred Value")
80
+ table.add_column("Deprecated")
81
+ table.add_column("Case Sensitive")
82
+ table.add_column("Additional Properties")
83
+ table.add_column("Description")
84
+
85
+ valid_values = m_client.get_valid_metadata_values(property_name, type_name)
86
+
87
+ if valid_values is None:
88
+ name = " "
89
+ type_name = " "
90
+ created = " "
91
+ priority = " "
92
+ due = " "
93
+ completed = " "
94
+ status = " "
95
+ sponsor = " "
96
+ elif type(valid_values[0]) == str:
97
+ raise ValueError(
98
+ "-->This is not a known metadata property with a valid value"
99
+ )
100
+ else:
101
+ for value in valid_values:
102
+ category = value.get("category", "None")
103
+ display_name = value.get("displayName", "None")
104
+ preferred_value = value.get("preferredValue", "None ")
105
+ deprecated = str(value.get("isDeprecated", "None "))
106
+ case_sensitive = str(value.get("isCaseSensitive", "None"))
107
+ description = value.get("description", "None")
108
+ additional_properties = value.get("additionalProperties", "None")
109
+ if additional_properties is not None:
110
+ props = json.dumps(additional_properties)
111
+ table.add_row(
112
+ category,
113
+ display_name,
114
+ preferred_value,
115
+ deprecated,
116
+ case_sensitive,
117
+ props,
118
+ description,
119
+ )
120
+
121
+ m_client.close_session()
122
+ return table
123
+
124
+ try:
125
+ # with Live(generate_table(), refresh_per_second=4, screen=True) as live:
126
+ # while True:
127
+ # time.sleep(2)
128
+ # live.update(generate_table())
129
+ console = Console(width=width, force_terminal=not jupyter, record=True)
130
+ with console.pager(styles=True):
131
+ console.print(generate_table(property_name, type_name))
132
+ if save_output:
133
+ console.save_html("valid-metadata-values.html")
134
+
135
+ except (
136
+ InvalidParameterException,
137
+ PropertyServerException,
138
+ UserNotAuthorizedException,
139
+ ValueError,
140
+ ) as e:
141
+ if type(e) is str:
142
+ print(e)
143
+ else:
144
+ print_exception_response(e)
145
+
146
+
147
+ def main():
148
+ parser = argparse.ArgumentParser()
149
+ parser.add_argument("--server", help="Name of the server to display status for")
150
+ parser.add_argument("--url", help="URL Platform to connect to")
151
+ parser.add_argument("--userid", help="User Id")
152
+ parser.add_argument("--save-output", help="Save output to file?")
153
+ parser.add_argument("--password", help="User Password")
154
+ # parser.add_argument("--sponsor", help="Name of sponsor to search")
155
+ args = parser.parse_args()
156
+
157
+ server = args.server if args.server is not None else EGERIA_VIEW_SERVER
158
+ url = args.url if args.url is not None else EGERIA_PLATFORM_URL
159
+ userid = args.userid if args.userid is not None else EGERIA_USER
160
+ user_pass = args.password if args.password is not None else EGERIA_USER_PASSWORD
161
+ save_output = args.save_output if args.save_output is not None else False
162
+
163
+ try:
164
+ property_name = Prompt.ask(
165
+ "Enter the Property to retrieve:", default="projectHealth"
166
+ )
167
+ type_name = Prompt.ask(
168
+ "Enter the Metadata Type to filter on:", default="Project"
169
+ )
170
+ display_metadata_values(
171
+ property_name, type_name, server, url, userid, user_pass, save_output
172
+ )
173
+ except KeyboardInterrupt:
174
+ pass
175
+
176
+
177
+ if __name__ == "__main__":
178
+ main()