pyegeria 5.4.0.28__py3-none-any.whl → 5.5.3.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.

Potentially problematic release.


This version of pyegeria might be problematic. Click here for more details.

Files changed (433) hide show
  1. commands/__init__.py +24 -0
  2. commands/cat/Dr-Egeria_md-orig.py +2 -2
  3. commands/cat/collection_actions.py +197 -0
  4. commands/cat/dr_egeria_command_help.py +137 -38
  5. commands/cat/dr_egeria_jupyter.py +7 -7
  6. commands/cat/dr_egeria_md.py +10 -267
  7. commands/cat/exp_list_glossaries.py +11 -14
  8. commands/cat/get_asset_graph.py +37 -267
  9. commands/cat/{get_collection.py → get_collection_tree.py} +10 -18
  10. commands/cat/get_project_dependencies.py +14 -14
  11. commands/cat/get_project_structure.py +15 -14
  12. commands/cat/get_tech_type_elements.py +16 -116
  13. commands/cat/glossary_actions.py +145 -298
  14. commands/cat/list_assets.py +3 -11
  15. commands/cat/list_cert_types.py +17 -63
  16. commands/cat/list_collections.py +17 -139
  17. commands/cat/list_deployed_catalogs.py +15 -27
  18. commands/cat/list_deployed_database_schemas.py +27 -43
  19. commands/cat/list_deployed_databases.py +16 -31
  20. commands/cat/list_deployed_servers.py +35 -54
  21. commands/cat/list_glossaries.py +18 -17
  22. commands/cat/list_projects.py +10 -12
  23. commands/cat/list_tech_type_elements.py +21 -37
  24. commands/cat/list_tech_types.py +13 -25
  25. commands/cat/list_terms.py +38 -79
  26. commands/cat/list_todos.py +4 -11
  27. commands/cat/list_user_ids.py +3 -10
  28. commands/cat/my_reports.py +559 -0
  29. commands/cat/run_report.py +394 -0
  30. commands/cat/{list_format_set.py → run_report_orig.py} +136 -44
  31. commands/cli/egeria.py +182 -219
  32. commands/cli/egeria_cat.py +32 -59
  33. commands/cli/egeria_my.py +13 -0
  34. commands/cli/egeria_ops.py +69 -74
  35. commands/cli/egeria_tech.py +17 -93
  36. commands/{cat → deprecated}/list_data_designer.py +2 -4
  37. commands/{cat → deprecated}/list_data_structures_full.py +3 -6
  38. commands/deprecated/old_get_asset_graph.py +315 -0
  39. commands/my/__init__.py +0 -2
  40. commands/my/list_my_profile.py +27 -34
  41. commands/my/list_my_roles.py +1 -7
  42. commands/my/monitor_my_todos.py +1 -7
  43. commands/my/monitor_open_todos.py +6 -7
  44. commands/my/todo_actions.py +4 -5
  45. commands/ops/__init__.py +0 -2
  46. commands/ops/gov_server_actions.py +17 -21
  47. commands/ops/list_archives.py +17 -38
  48. commands/ops/list_catalog_targets.py +33 -40
  49. commands/ops/load_archive.py +14 -11
  50. commands/ops/{monitor_engine_activity_c.py → monitor_active_engine_activity.py} +51 -82
  51. commands/ops/{monitor_integ_daemon_status.py → monitor_daemon_status.py} +35 -55
  52. commands/ops/monitor_engine_activity.py +79 -77
  53. commands/ops/{monitor_gov_eng_status.py → monitor_engine_status.py} +10 -7
  54. commands/ops/monitor_platform_status.py +38 -50
  55. commands/ops/monitor_server_startup.py +6 -11
  56. commands/ops/monitor_server_status.py +7 -11
  57. commands/ops/orig_monitor_server_list.py +8 -8
  58. commands/ops/orig_monitor_server_status.py +1 -5
  59. commands/ops/refresh_integration_daemon.py +5 -5
  60. commands/ops/restart_integration_daemon.py +5 -5
  61. commands/ops/table_integ_daemon_status.py +6 -6
  62. commands/ops/x_engine_actions.py +7 -7
  63. commands/tech/__init__.py +0 -2
  64. commands/tech/{generic_actions.py → element_actions.py} +6 -11
  65. commands/tech/get_element_info.py +20 -29
  66. commands/tech/get_guid_info.py +23 -42
  67. commands/tech/get_tech_details.py +20 -35
  68. commands/tech/get_tech_type_template.py +28 -39
  69. commands/tech/list_all_om_type_elements.py +24 -30
  70. commands/tech/list_all_om_type_elements_x.py +22 -28
  71. commands/tech/list_all_related_elements.py +19 -28
  72. commands/tech/list_anchored_elements.py +22 -30
  73. commands/tech/list_asset_types.py +19 -24
  74. commands/tech/list_elements_by_classification_by_property_value.py +26 -32
  75. commands/tech/list_elements_by_property_value.py +19 -25
  76. commands/tech/list_elements_by_property_value_x.py +20 -28
  77. commands/tech/list_elements_for_classification.py +28 -41
  78. commands/tech/list_gov_action_processes.py +16 -27
  79. commands/tech/list_information_supply_chains.py +22 -30
  80. commands/tech/list_registered_services.py +14 -26
  81. commands/tech/list_related_elements_with_prop_value.py +15 -25
  82. commands/tech/list_related_specification.py +1 -4
  83. commands/tech/list_relationship_types.py +15 -25
  84. commands/tech/list_relationships.py +20 -36
  85. commands/tech/list_solution_blueprints.py +28 -33
  86. commands/tech/list_solution_components.py +23 -29
  87. commands/tech/list_solution_roles.py +21 -32
  88. commands/tech/list_tech_templates.py +51 -54
  89. commands/tech/list_valid_metadata_values.py +5 -9
  90. commands/tech/table_tech_templates.py +2 -6
  91. commands/tech/x_list_related_elements.py +1 -4
  92. examples/GeoSpatial Products Example.py +524 -0
  93. examples/Jupyter Notebooks/P-egeria-server-config.ipynb +2137 -0
  94. examples/Jupyter Notebooks/README.md +2 -0
  95. examples/Jupyter Notebooks/common/P-environment-check.ipynb +115 -0
  96. examples/Jupyter Notebooks/common/__init__.py +14 -0
  97. examples/Jupyter Notebooks/common/common-functions.ipynb +4694 -0
  98. examples/Jupyter Notebooks/common/environment-check.ipynb +52 -0
  99. examples/Jupyter Notebooks/common/globals.ipynb +184 -0
  100. examples/Jupyter Notebooks/common/globals.py +154 -0
  101. examples/Jupyter Notebooks/common/orig_globals.py +152 -0
  102. examples/format_sets/all_format_sets.json +910 -0
  103. examples/format_sets/custom_format_sets.json +268 -0
  104. examples/format_sets/subset_format_sets.json +187 -0
  105. examples/format_sets_save_load_example.py +291 -0
  106. examples/jacquard_data_sets.py +129 -0
  107. examples/output_formats_example.py +193 -0
  108. examples/test_jacquard_data_sets.py +54 -0
  109. examples/test_jacquard_data_sets_scenarios.py +94 -0
  110. md_processing/__init__.py +33 -24
  111. md_processing/command_dispatcher.py +33 -0
  112. md_processing/command_mapping.py +221 -0
  113. md_processing/data/commands/commands_data_designer.json +537 -0
  114. md_processing/data/commands/commands_external_reference.json +733 -0
  115. md_processing/data/commands/commands_feedback.json +155 -0
  116. md_processing/data/commands/commands_general.json +204 -0
  117. md_processing/data/commands/commands_glossary.json +218 -0
  118. md_processing/data/commands/commands_governance.json +3678 -0
  119. md_processing/data/commands/commands_product_manager.json +865 -0
  120. md_processing/data/commands/commands_project.json +642 -0
  121. md_processing/data/commands/commands_solution_architect.json +366 -0
  122. md_processing/data/commands.json +6489 -30060
  123. md_processing/data/{commands-working.json → commands_working.json} +9304 -13513
  124. md_processing/data/gened_report_specs.py +6584 -0
  125. md_processing/data/generated_format_sets.json +6533 -0
  126. md_processing/data/generated_format_sets_old.json +4137 -0
  127. md_processing/data/generated_format_sets_old.py +45 -0
  128. md_processing/dr_egeria.py +182 -0
  129. md_processing/md_commands/data_designer_commands.py +195 -583
  130. md_processing/md_commands/ext_ref_commands.py +530 -0
  131. md_processing/md_commands/feedback_commands.py +726 -0
  132. md_processing/md_commands/glossary_commands.py +106 -490
  133. md_processing/md_commands/governance_officer_commands.py +129 -18
  134. md_processing/md_commands/product_manager_commands.py +362 -115
  135. md_processing/md_commands/project_commands.py +351 -134
  136. md_processing/md_commands/solution_architect_commands.py +276 -232
  137. md_processing/md_commands/view_commands.py +295 -0
  138. md_processing/md_processing_utils/common_md_proc_utils.py +258 -166
  139. md_processing/md_processing_utils/common_md_utils.py +138 -43
  140. md_processing/md_processing_utils/determine_width.py +103 -0
  141. md_processing/md_processing_utils/extraction_utils.py +100 -39
  142. md_processing/md_processing_utils/gen_report_specs.py +643 -0
  143. md_processing/md_processing_utils/generate_dr_help.py +61 -33
  144. md_processing/md_processing_utils/generate_md_cmd_templates.py +20 -19
  145. md_processing/md_processing_utils/generate_md_templates.py +3 -12
  146. md_processing/md_processing_utils/md_processing_constants.py +1053 -72
  147. pyegeria/__init__.py +203 -158
  148. pyegeria/core/__init__.py +40 -0
  149. pyegeria/core/_base_platform_client.py +574 -0
  150. pyegeria/core/_base_server_client.py +573 -0
  151. pyegeria/{_exceptions_new.py → core/_exceptions.py} +62 -30
  152. pyegeria/{_globals.py → core/_globals.py} +14 -3
  153. pyegeria/core/_server_client.py +6073 -0
  154. pyegeria/{_validators.py → core/_validators.py} +7 -8
  155. pyegeria/core/config.py +654 -0
  156. pyegeria/{create_tech_guid_lists.py → core/create_tech_guid_lists.py} +0 -1
  157. pyegeria/core/load_config.py +37 -0
  158. pyegeria/{logging_configuration.py → core/logging_configuration.py} +1 -1
  159. pyegeria/core/mcp_adapter.py +144 -0
  160. pyegeria/core/mcp_server.py +212 -0
  161. pyegeria/core/utils.py +405 -0
  162. pyegeria/{_client.py → deprecated/_client.py} +24 -25
  163. pyegeria/{_deprecated_gov_engine.py → deprecated/_deprecated_gov_engine.py} +16 -16
  164. pyegeria/{classification_manager_omvs.py → deprecated/classification_manager_omvs.py} +1987 -1877
  165. pyegeria/{output_formatter.py → deprecated/output_formatter_with_machine_keys.py} +298 -45
  166. pyegeria/{runtime_manager_omvs.py → deprecated/runtime_manager_omvs.py} +155 -171
  167. pyegeria/{valid_metadata_omvs.py → deprecated/valid_metadata_omvs.py} +93 -93
  168. pyegeria/{x_action_author_omvs.py → deprecated/x_action_author_omvs.py} +2 -3
  169. pyegeria/egeria_cat_client.py +26 -70
  170. pyegeria/egeria_client.py +130 -93
  171. pyegeria/egeria_config_client.py +40 -46
  172. pyegeria/egeria_tech_client.py +141 -54
  173. pyegeria/models/__init__.py +150 -0
  174. pyegeria/{models.py → models/models.py} +156 -20
  175. pyegeria/omvs/__init__.py +84 -0
  176. pyegeria/omvs/action_author.py +342 -0
  177. pyegeria/omvs/actor_manager.py +5980 -0
  178. pyegeria/omvs/asset_catalog.py +842 -0
  179. pyegeria/omvs/asset_maker.py +2736 -0
  180. pyegeria/omvs/automated_curation.py +4403 -0
  181. pyegeria/omvs/classification_manager.py +11213 -0
  182. pyegeria/{collection_manager.py → omvs/collection_manager.py} +1334 -1160
  183. pyegeria/omvs/community_matters_omvs.py +468 -0
  184. pyegeria/{core_omag_server_config.py → omvs/core_omag_server_config.py} +157 -157
  185. pyegeria/{data_designer.py → omvs/data_designer.py} +1115 -660
  186. pyegeria/omvs/data_discovery.py +869 -0
  187. pyegeria/omvs/data_engineer.py +372 -0
  188. pyegeria/omvs/digital_business.py +1133 -0
  189. pyegeria/omvs/external_links.py +1752 -0
  190. pyegeria/omvs/feedback_manager.py +834 -0
  191. pyegeria/{full_omag_server_config.py → omvs/full_omag_server_config.py} +73 -69
  192. pyegeria/{glossary_manager.py → omvs/glossary_manager.py} +857 -519
  193. pyegeria/{governance_officer.py → omvs/governance_officer.py} +964 -468
  194. pyegeria/omvs/lineage_linker.py +314 -0
  195. pyegeria/omvs/location_arena.py +1525 -0
  196. pyegeria/omvs/metadata_expert.py +668 -0
  197. pyegeria/omvs/metadata_explorer_omvs.py +2943 -0
  198. pyegeria/omvs/my_profile.py +1042 -0
  199. pyegeria/omvs/notification_manager.py +358 -0
  200. pyegeria/omvs/people_organizer.py +394 -0
  201. pyegeria/{platform_services.py → omvs/platform_services.py} +113 -193
  202. pyegeria/omvs/product_manager.py +1825 -0
  203. pyegeria/omvs/project_manager.py +1907 -0
  204. pyegeria/omvs/reference_data.py +1140 -0
  205. pyegeria/omvs/registered_info.py +334 -0
  206. pyegeria/omvs/runtime_manager.py +2817 -0
  207. pyegeria/omvs/schema_maker.py +446 -0
  208. pyegeria/{server_operations.py → omvs/server_operations.py} +27 -26
  209. pyegeria/{solution_architect_omvs.py → omvs/solution_architect.py} +1886 -1505
  210. pyegeria/omvs/specification_properties.py +37 -0
  211. pyegeria/omvs/subject_area.py +1042 -0
  212. pyegeria/omvs/template_manager_omvs.py +236 -0
  213. pyegeria/omvs/time_keeper.py +1761 -0
  214. pyegeria/omvs/valid_metadata.py +3221 -0
  215. pyegeria/omvs/valid_metadata_lists.py +37 -0
  216. pyegeria/omvs/valid_type_lists.py +37 -0
  217. pyegeria/view/__init__.py +28 -0
  218. pyegeria/{_output_format_models.py → view/_output_format_models.py} +160 -24
  219. pyegeria/view/_output_formats.py +14 -0
  220. pyegeria/view/base_report_formats.py +2719 -0
  221. pyegeria/view/dr_egeria_reports.py +56 -0
  222. pyegeria/view/format_set_executor.py +397 -0
  223. pyegeria/{md_processing_utils.py → view/md_processing_utils.py} +5 -5
  224. pyegeria/{mermaid_utilities.py → view/mermaid_utilities.py} +2 -154
  225. pyegeria/view/output_formatter.py +1297 -0
  226. pyegeria-5.5.3.3.dist-info/METADATA +218 -0
  227. pyegeria-5.5.3.3.dist-info/RECORD +241 -0
  228. {pyegeria-5.4.0.28.dist-info → pyegeria-5.5.3.3.dist-info}/WHEEL +2 -1
  229. pyegeria-5.5.3.3.dist-info/entry_points.txt +103 -0
  230. pyegeria-5.5.3.3.dist-info/top_level.txt +4 -0
  231. commands/cat/.DS_Store +0 -0
  232. commands/cat/.env +0 -8
  233. commands/cat/README.md +0 -16
  234. commands/cat/debug_log +0 -1126
  235. commands/cat/debug_log.2025-08-18_11-34-38_088636.zip +0 -0
  236. commands/cat/list_categories.py +0 -192
  237. commands/cat/logs/pyegeria.log +0 -4
  238. commands/cli/debug_log +0 -0
  239. commands/cli/debug_log.log +0 -0
  240. commands/cli/txt_custom_v2.tcss +0 -19
  241. commands/my/README.md +0 -17
  242. commands/ops/README.md +0 -24
  243. commands/ops/logs/pyegeria.log +0 -0
  244. commands/ops/monitor_asset_events.py +0 -108
  245. commands/tech/README.md +0 -24
  246. md_processing/.DS_Store +0 -0
  247. md_processing/dr-egeria-outbox/Collections-2025-08-12-13-30-37.md +0 -163
  248. md_processing/dr-egeria-outbox/Collections-2025-08-12-13-35-58.md +0 -474
  249. md_processing/dr_egeria_inbox/Derive-Dr-Gov-Defs.md +0 -8
  250. md_processing/dr_egeria_inbox/Dr.Egeria Templates.md +0 -873
  251. md_processing/dr_egeria_inbox/arch_test.md +0 -57
  252. md_processing/dr_egeria_inbox/archive/dr_egeria_intro.md +0 -254
  253. md_processing/dr_egeria_inbox/archive/dr_egeria_intro_more_terms.md +0 -696
  254. md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part1.md +0 -254
  255. md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part2.md +0 -298
  256. md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part3.md +0 -608
  257. md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part4.md +0 -94
  258. md_processing/dr_egeria_inbox/archive/freddie_intro.md +0 -284
  259. md_processing/dr_egeria_inbox/archive/freddie_intro_orig.md +0 -275
  260. md_processing/dr_egeria_inbox/archive/test-term.md +0 -110
  261. md_processing/dr_egeria_inbox/cat_test.md +0 -100
  262. md_processing/dr_egeria_inbox/collections.md +0 -39
  263. md_processing/dr_egeria_inbox/data_designer_debug.log +0 -6
  264. md_processing/dr_egeria_inbox/data_designer_out.md +0 -60
  265. md_processing/dr_egeria_inbox/data_designer_search_test.md +0 -11
  266. md_processing/dr_egeria_inbox/data_field.md +0 -54
  267. md_processing/dr_egeria_inbox/data_spec.md +0 -77
  268. md_processing/dr_egeria_inbox/data_spec_test.md +0 -2406
  269. md_processing/dr_egeria_inbox/data_test.md +0 -179
  270. md_processing/dr_egeria_inbox/data_test2.md +0 -429
  271. md_processing/dr_egeria_inbox/data_test3.md +0 -462
  272. md_processing/dr_egeria_inbox/dr_egeria_data_designer_1.md +0 -124
  273. md_processing/dr_egeria_inbox/dr_egeria_intro_categories.md +0 -168
  274. md_processing/dr_egeria_inbox/dr_egeria_intro_part1.md +0 -280
  275. md_processing/dr_egeria_inbox/dr_egeria_intro_part2.md +0 -318
  276. md_processing/dr_egeria_inbox/dr_egeria_intro_part3.md +0 -1073
  277. md_processing/dr_egeria_inbox/dr_egeria_isc1.md +0 -44
  278. md_processing/dr_egeria_inbox/generated_help_report.md +0 -9
  279. md_processing/dr_egeria_inbox/glossary_creation_experiment.ipynb +0 -341
  280. md_processing/dr_egeria_inbox/glossary_list.md +0 -5
  281. md_processing/dr_egeria_inbox/glossary_search_test.md +0 -40
  282. md_processing/dr_egeria_inbox/glossary_test1.md +0 -324
  283. md_processing/dr_egeria_inbox/gov_def.md +0 -482
  284. md_processing/dr_egeria_inbox/gov_def2.md +0 -447
  285. md_processing/dr_egeria_inbox/img.png +0 -0
  286. md_processing/dr_egeria_inbox/product.md +0 -211
  287. md_processing/dr_egeria_inbox/rel.md +0 -8
  288. md_processing/dr_egeria_inbox/sb.md +0 -119
  289. md_processing/dr_egeria_inbox/solution-components.md +0 -136
  290. md_processing/dr_egeria_inbox/solution_blueprints.md +0 -118
  291. md_processing/dr_egeria_inbox/synonym_test.md +0 -42
  292. md_processing/dr_egeria_inbox/t2.md +0 -268
  293. md_processing/dr_egeria_outbox/.obsidian/app.json +0 -1
  294. md_processing/dr_egeria_outbox/.obsidian/appearance.json +0 -1
  295. md_processing/dr_egeria_outbox/.obsidian/community-plugins.json +0 -6
  296. md_processing/dr_egeria_outbox/.obsidian/core-plugins.json +0 -31
  297. md_processing/dr_egeria_outbox/.obsidian/plugins/calendar/data.json +0 -10
  298. md_processing/dr_egeria_outbox/.obsidian/plugins/calendar/main.js +0 -4459
  299. md_processing/dr_egeria_outbox/.obsidian/plugins/calendar/manifest.json +0 -10
  300. md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/data.json +0 -3
  301. md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/main.js +0 -153
  302. md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/manifest.json +0 -11
  303. md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/styles.css +0 -1
  304. md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-tasks-plugin/main.js +0 -500
  305. md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-tasks-plugin/manifest.json +0 -12
  306. md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-tasks-plugin/styles.css +0 -1
  307. md_processing/dr_egeria_outbox/.obsidian/plugins/templater-obsidian/main.js +0 -37
  308. md_processing/dr_egeria_outbox/.obsidian/plugins/templater-obsidian/manifest.json +0 -11
  309. md_processing/dr_egeria_outbox/.obsidian/plugins/templater-obsidian/styles.css +0 -220
  310. md_processing/dr_egeria_outbox/.obsidian/types.json +0 -28
  311. md_processing/dr_egeria_outbox/.obsidian/workspace.json +0 -220
  312. md_processing/dr_egeria_outbox/Untitled.canvas +0 -1
  313. md_processing/dr_egeria_outbox/friday/processed-2025-08-22 21:22-dr_egeria_intro_part1.md +0 -312
  314. md_processing/dr_egeria_outbox/friday/processed-2025-08-22 21:23-dr_egeria_intro_part1.md +0 -265
  315. md_processing/dr_egeria_outbox/friday/processed-2025-08-23 15:06-dr_egeria_intro_part1.md +0 -230
  316. md_processing/dr_egeria_outbox/friday/processed-2025-08-23 15:30-dr_egeria_intro_part1.md +0 -296
  317. md_processing/dr_egeria_outbox/friday/processed-2025-08-23 15:31-dr_egeria_intro_part1.md +0 -253
  318. md_processing/dr_egeria_outbox/friday/processed-2025-08-23 16:08-dr_egeria_intro_part2.md +0 -343
  319. md_processing/dr_egeria_outbox/friday/processed-2025-08-23 16:12-dr_egeria_intro_part2.md +0 -343
  320. md_processing/dr_egeria_outbox/monday/processed-2025-08-19 07:05-product.md +0 -426
  321. md_processing/dr_egeria_outbox/monday/processed-2025-08-19 07:56-product.md +0 -212
  322. md_processing/dr_egeria_outbox/monday/processed-2025-08-19 09:43-product.md +0 -201
  323. md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 14:55-product.md +0 -77
  324. md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 15:05-product.md +0 -75
  325. md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 15:11-product.md +0 -74
  326. md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 20:40-collections.md +0 -49
  327. md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 15:00-Derive-Dr-Gov-Defs.md +0 -719
  328. md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 20:13-Derive-Dr-Gov-Defs.md +0 -41
  329. md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 20:14-Derive-Dr-Gov-Defs.md +0 -33
  330. md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 20:50-Derive-Dr-Gov-Defs.md +0 -192
  331. md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 22:08-gov_def2.md +0 -486
  332. md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 22:10-gov_def2.md +0 -486
  333. md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 08:53-gov_def2.md +0 -486
  334. md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 08:54-gov_def2.md +0 -486
  335. md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 09:03-gov_def2.md +0 -486
  336. md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 09:06-gov_def2.md +0 -486
  337. md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 09:10-gov_def2.md +0 -486
  338. md_processing/dr_egeria_outbox/tuesday/processed-2025-07-16 19:15-gov_def2.md +0 -527
  339. md_processing/dr_egeria_outbox/tuesday/processed-2025-07-17 12:08-gov_def2.md +0 -527
  340. md_processing/dr_egeria_outbox/tuesday/processed-2025-07-17 14:27-gov_def2.md +0 -485
  341. md_processing/dr_egeria_outbox/tuesday/processed-2025-08-19 10:55-product.md +0 -209
  342. md_processing/family_docs/Data Designer/Create_Data_Class.md +0 -164
  343. md_processing/family_docs/Data Designer/Create_Data_Dictionary.md +0 -30
  344. md_processing/family_docs/Data Designer/Create_Data_Field.md +0 -162
  345. md_processing/family_docs/Data Designer/Create_Data_Specification.md +0 -36
  346. md_processing/family_docs/Data Designer/Create_Data_Structure.md +0 -38
  347. md_processing/family_docs/Data Designer/View_Data_Classes.md +0 -78
  348. md_processing/family_docs/Data Designer/View_Data_Dictionaries.md +0 -78
  349. md_processing/family_docs/Data Designer/View_Data_Fields.md +0 -78
  350. md_processing/family_docs/Data Designer/View_Data_Specifications.md +0 -78
  351. md_processing/family_docs/Data Designer/View_Data_Structures.md +0 -78
  352. md_processing/family_docs/Data Designer.md +0 -842
  353. md_processing/family_docs/Digital Product Manager/Add_Member->Collection.md +0 -42
  354. md_processing/family_docs/Digital Product Manager/Attach_Collection->Resource.md +0 -36
  355. md_processing/family_docs/Digital Product Manager/Create_Agreement.md +0 -96
  356. md_processing/family_docs/Digital Product Manager/Create_Data_Sharing_Agreement.md +0 -72
  357. md_processing/family_docs/Digital Product Manager/Create_DigitalSubscription.md +0 -102
  358. md_processing/family_docs/Digital Product Manager/Create_Digital_Product.md +0 -134
  359. md_processing/family_docs/Digital Product Manager/Link_Agreement_Items.md +0 -60
  360. md_processing/family_docs/Digital Product Manager/Link_Contracts.md +0 -26
  361. md_processing/family_docs/Digital Product Manager/Link_Digital_Product_-_Digital_Product.md +0 -30
  362. md_processing/family_docs/Digital Product Manager/Link_Subscribers.md +0 -48
  363. md_processing/family_docs/Digital Product Manager.md +0 -668
  364. md_processing/family_docs/Glossary/Attach_Category_Parent.md +0 -18
  365. md_processing/family_docs/Glossary/Attach_Term-Term_Relationship.md +0 -26
  366. md_processing/family_docs/Glossary/Create_Category.md +0 -38
  367. md_processing/family_docs/Glossary/Create_Glossary.md +0 -42
  368. md_processing/family_docs/Glossary/Create_Term.md +0 -70
  369. md_processing/family_docs/Glossary.md +0 -206
  370. md_processing/family_docs/Governance Officer/Create_Business_Imperative.md +0 -106
  371. md_processing/family_docs/Governance Officer/Create_Certification_Type.md +0 -112
  372. md_processing/family_docs/Governance Officer/Create_Governance_Approach.md +0 -114
  373. md_processing/family_docs/Governance Officer/Create_Governance_Obligation.md +0 -114
  374. md_processing/family_docs/Governance Officer/Create_Governance_Principle.md +0 -114
  375. md_processing/family_docs/Governance Officer/Create_Governance_Procedure.md +0 -128
  376. md_processing/family_docs/Governance Officer/Create_Governance_Process.md +0 -122
  377. md_processing/family_docs/Governance Officer/Create_Governance_Processing_Purpose.md +0 -106
  378. md_processing/family_docs/Governance Officer/Create_Governance_Responsibility.md +0 -122
  379. md_processing/family_docs/Governance Officer/Create_Governance_Rule.md +0 -122
  380. md_processing/family_docs/Governance Officer/Create_Governance_Strategy.md +0 -106
  381. md_processing/family_docs/Governance Officer/Create_License_Type.md +0 -112
  382. md_processing/family_docs/Governance Officer/Create_Naming_Standard_Rule.md +0 -122
  383. md_processing/family_docs/Governance Officer/Create_Regulation_Article.md +0 -106
  384. md_processing/family_docs/Governance Officer/Create_Regulation_Definition.md +0 -118
  385. md_processing/family_docs/Governance Officer/Create_Security_Access_Control.md +0 -114
  386. md_processing/family_docs/Governance Officer/Create_Security_Group.md +0 -120
  387. md_processing/family_docs/Governance Officer/Create_Service_Level_Objectives.md +0 -122
  388. md_processing/family_docs/Governance Officer/Create_Threat_Definition.md +0 -106
  389. md_processing/family_docs/Governance Officer/Link_Governance_Controls.md +0 -32
  390. md_processing/family_docs/Governance Officer/Link_Governance_Drivers.md +0 -32
  391. md_processing/family_docs/Governance Officer/Link_Governance_Policies.md +0 -32
  392. md_processing/family_docs/Governance Officer/View_Governance_Definitions.md +0 -82
  393. md_processing/family_docs/Governance Officer.md +0 -2412
  394. md_processing/family_docs/Solution Architect/Create_Information_Supply_Chain.md +0 -70
  395. md_processing/family_docs/Solution Architect/Create_Solution_Blueprint.md +0 -44
  396. md_processing/family_docs/Solution Architect/Create_Solution_Component.md +0 -96
  397. md_processing/family_docs/Solution Architect/Create_Solution_Role.md +0 -66
  398. md_processing/family_docs/Solution Architect/Link_Information_Supply_Chain_Peers.md +0 -32
  399. md_processing/family_docs/Solution Architect/Link_Solution_Component_Peers.md +0 -32
  400. md_processing/family_docs/Solution Architect/View_Information_Supply_Chains.md +0 -32
  401. md_processing/family_docs/Solution Architect/View_Solution_Blueprints.md +0 -32
  402. md_processing/family_docs/Solution Architect/View_Solution_Components.md +0 -32
  403. md_processing/family_docs/Solution Architect/View_Solution_Roles.md +0 -32
  404. md_processing/family_docs/Solution Architect.md +0 -490
  405. md_processing/md_processing_utils/debug_log +0 -574
  406. md_processing/md_processing_utils/debug_log.log +0 -0
  407. md_processing/md_processing_utils/dr-egeria-help-2025-07-17T17:22:09.md +0 -2065
  408. md_processing/md_processing_utils/generated_help_terms.md +0 -842
  409. pyegeria/.DS_Store +0 -0
  410. pyegeria/README.md +0 -35
  411. pyegeria/_client_new.py +0 -1102
  412. pyegeria/_output_formats.py +0 -730
  413. pyegeria/asset_catalog_omvs.py +0 -864
  414. pyegeria/automated_curation_omvs.py +0 -3765
  415. pyegeria/config.py +0 -523
  416. pyegeria/egeria_my_client.py +0 -91
  417. pyegeria/feedback_manager_omvs.py +0 -4573
  418. pyegeria/load_config_orig.py +0 -218
  419. pyegeria/md_processing_helpers.py +0 -58
  420. pyegeria/md_processing_utils_orig.py +0 -1103
  421. pyegeria/metadata_explorer_omvs.py +0 -2326
  422. pyegeria/my_profile_omvs.py +0 -1022
  423. pyegeria/project_manager.py +0 -1591
  424. pyegeria/registered_info.py +0 -167
  425. pyegeria/template_manager_omvs.py +0 -1414
  426. pyegeria/utils.py +0 -256
  427. pyegeria-5.4.0.28.dist-info/METADATA +0 -77
  428. pyegeria-5.4.0.28.dist-info/RECORD +0 -343
  429. pyegeria-5.4.0.28.dist-info/entry_points.txt +0 -105
  430. /commands/cat/debug_log.log → /pyegeria/deprecated/__init__.py +0 -0
  431. /pyegeria/{_exceptions.py → deprecated/_exceptions.py} +0 -0
  432. /pyegeria/{collection_models.py → models/collection_models.py} +0 -0
  433. {pyegeria-5.4.0.28.dist-info → pyegeria-5.5.3.3.dist-info/licenses}/LICENSE +0 -0
@@ -0,0 +1,468 @@
1
+ """
2
+ SPDX-License-Identifier: Apache-2.0
3
+ Copyright Contributors to the ODPi Egeria project.
4
+
5
+ Community Matters OMVS client.
6
+
7
+ This module provides a lightweight client for the Community Matters View Service
8
+ endpoints as documented in Egeria-community-matters-omvs.http. It follows the
9
+ established patterns used by other OMVS clients (for example, location_arena.py
10
+ and project_manager.py), reusing the ServerClient helper methods for request
11
+ validation and transport.
12
+ """
13
+
14
+ import asyncio
15
+ from typing import Any, Optional
16
+
17
+ from pyegeria.core._server_client import ServerClient
18
+ from pyegeria.models import (
19
+ NewElementRequestBody,
20
+ TemplateRequestBody,
21
+ UpdateElementRequestBody,
22
+ DeleteElementRequestBody,
23
+ FilterRequestBody,
24
+ SearchStringRequestBody,
25
+ GetRequestBody,
26
+ )
27
+ from pyegeria.core.utils import dynamic_catch
28
+
29
+
30
+ class CommunityMatters(ServerClient):
31
+ """
32
+ Client for the Community Matters View Service.
33
+
34
+ The Community Matters View Service provides methods to create and manage communities.
35
+
36
+ Attributes
37
+ ----------
38
+ view_server : str
39
+ The name of the View Server to use.
40
+ platform_url : str
41
+ URL of the server platform to connect to.
42
+ user_id : str
43
+ The identity of the user calling the method.
44
+ user_pwd : str
45
+ The password associated with the user_id. Defaults to None.
46
+ """
47
+
48
+ def __init__(
49
+ self,
50
+ view_server: str,
51
+ platform_url: str,
52
+ user_id: str,
53
+ user_pwd: str | None = None,
54
+ token: str | None = None,
55
+ ):
56
+ self.view_server = view_server
57
+ self.platform_url = platform_url
58
+ self.user_id = user_id
59
+ self.user_pwd = user_pwd
60
+ self.community_command_base: str = (
61
+ f"{self.platform_url}/servers/{self.view_server}/api/open-metadata/community-matters"
62
+ )
63
+ # url_marker only used by some generic helpers (e.g., update status) not used here
64
+ self.url_marker = "community-matters"
65
+ ServerClient.__init__(self, view_server, platform_url, user_id, user_pwd, token)
66
+
67
+ # -----------------------------
68
+ # Create
69
+ # -----------------------------
70
+ @dynamic_catch
71
+ async def _async_create_community(self, body: Optional[dict | NewElementRequestBody] = None) -> str:
72
+ url = f"{self.community_command_base}/communities"
73
+ return await self._async_create_element_body_request(url, ["CommunityProperties"], body)
74
+
75
+ @dynamic_catch
76
+ def create_community(self, body: Optional[dict | NewElementRequestBody] = None) -> str:
77
+ loop = asyncio.get_event_loop()
78
+ return loop.run_until_complete(self._async_create_community(body))
79
+
80
+ # -----------------------------
81
+ # Create from template
82
+ # -----------------------------
83
+ @dynamic_catch
84
+ async def _async_create_community_from_template(self, body: dict | TemplateRequestBody) -> str:
85
+ url = f"{self.community_command_base}/communities/from-template"
86
+ return await self._async_create_element_from_template(url, body)
87
+
88
+ @dynamic_catch
89
+ def create_community_from_template(self, body: dict | TemplateRequestBody) -> str:
90
+ loop = asyncio.get_event_loop()
91
+ return loop.run_until_complete(self._async_create_community_from_template(body))
92
+
93
+ # -----------------------------
94
+ # Update
95
+ # -----------------------------
96
+ @dynamic_catch
97
+ async def _async_update_community(self, community_guid: str, body: dict | UpdateElementRequestBody) -> None:
98
+ url = f"{self.community_command_base}/communities/{community_guid}/update"
99
+ await self._async_update_element_body_request(url, ["CommunityProperties"], body)
100
+
101
+ @dynamic_catch
102
+ def update_community(self, community_guid: str, body: dict | UpdateElementRequestBody) -> None:
103
+ loop = asyncio.get_event_loop()
104
+ loop.run_until_complete(self._async_update_community(community_guid, body))
105
+
106
+ # -----------------------------
107
+ # Delete
108
+ # -----------------------------
109
+ @dynamic_catch
110
+ async def _async_delete_community(
111
+ self,
112
+ community_guid: str,
113
+ body: Optional[dict | DeleteElementRequestBody] = None,
114
+ cascade: bool = False,
115
+ ) -> None:
116
+ url = f"{self.community_command_base}/communities/{community_guid}/delete"
117
+ await self._async_delete_element_request(url, body, cascade)
118
+
119
+ @dynamic_catch
120
+ def delete_community(
121
+ self,
122
+ community_guid: str,
123
+ body: Optional[dict | DeleteElementRequestBody] = None,
124
+ cascade: bool = False,
125
+ ) -> None:
126
+ loop = asyncio.get_event_loop()
127
+ loop.run_until_complete(self._async_delete_community(community_guid, body, cascade))
128
+
129
+ # -----------------------------
130
+ # Get by name
131
+ # -----------------------------
132
+ def _generate_community_output(
133
+ self,
134
+ elements: dict | list[dict],
135
+ filter_or_search: str | None,
136
+ element_type_name: str | None,
137
+ output_format: str = "JSON",
138
+ report_spec: dict | str | None = None,
139
+ ) -> Any:
140
+ # Minimal implementation: return JSON elements unchanged for now.
141
+ # Extend later to provide markdown/DICT formatting with output_formatter if needed.
142
+ return elements
143
+
144
+ @dynamic_catch
145
+ async def _async_get_communities_by_name(
146
+ self,
147
+ filter_string: str | None = None,
148
+ body: Optional[dict | FilterRequestBody] = None,
149
+ start_from: int = 0,
150
+ page_size: int = 0,
151
+ output_format: str = "JSON",
152
+ report_spec: str | dict | None = None,
153
+ ) -> list | str:
154
+ url = f"{self.community_command_base}/communities/by-name"
155
+ response = await self._async_get_name_request(
156
+ url,
157
+ _type="Community",
158
+ _gen_output=self._generate_community_output,
159
+ filter_string=filter_string,
160
+ start_from=start_from,
161
+ page_size=page_size,
162
+ output_format=output_format,
163
+ report_spec=report_spec,
164
+ body=body,
165
+ )
166
+ return response
167
+
168
+ @dynamic_catch
169
+ def get_communities_by_name(
170
+ self,
171
+ filter_string: str | None = None,
172
+ body: Optional[dict | FilterRequestBody] = None,
173
+ start_from: int = 0,
174
+ page_size: int = 0,
175
+ output_format: str = "JSON",
176
+ report_spec: str | dict | None = None,
177
+ ) -> list | str:
178
+ loop = asyncio.get_event_loop()
179
+ return loop.run_until_complete(
180
+ self._async_get_communities_by_name(
181
+ filter_string,
182
+ body,
183
+ start_from,
184
+ page_size,
185
+ output_format,
186
+ report_spec,
187
+ )
188
+ )
189
+
190
+ # -----------------------------
191
+ # Find by search string
192
+ # -----------------------------
193
+ @dynamic_catch
194
+ async def _async_find_communities(self, search_string: str = "*",
195
+ starts_with: bool = True, ends_with: bool = False,
196
+ ignore_case: bool = False,
197
+ anchor_domain: Optional[str] = None,
198
+ metadata_element_type: Optional[str] = None,
199
+ metadata_element_subtypes: Optional[list[str]] = None,
200
+ skip_relationships: Optional[list[str]] = None,
201
+ include_only_relationships: Optional[list[str]] = None,
202
+ skip_classified_elements: Optional[list[str]] = None,
203
+ include_only_classified_elements: Optional[list[str]] = None,
204
+ graph_query_depth: int = 3,
205
+ governance_zone_filter: Optional[list[str]] = None, as_of_time: Optional[str] = None,
206
+ effective_time: Optional[str] = None, relationship_page_size: int = 0,
207
+ limit_results_by_status: Optional[list[str]] = None, sequencing_order: Optional[str] = None,
208
+ sequencing_property: Optional[str] = None,
209
+ output_format: str = "JSON",
210
+ report_spec: str | dict = None,
211
+ start_from: int = 0, page_size: int = 100,
212
+ property_names: Optional[list[str]] = None,
213
+ body: Optional[dict | SearchStringRequestBody] = None) -> list | str:
214
+ """ Retrieve the list of community metadata elements that contain the search string. Async Version.
215
+
216
+ Parameters
217
+ ----------
218
+ search_string: str
219
+ Search string to match against - None or '*' indicate match against all communities.
220
+ starts_with : bool, [default=True], optional
221
+ Starts with the supplied string.
222
+ ends_with : bool, [default=False], optional
223
+ Ends with the supplied string
224
+ ignore_case : bool, [default=False], optional
225
+ Ignore case when searching
226
+ anchor_domain: str, optional
227
+ The anchor domain to search in.
228
+ metadata_element_type: str, optional
229
+ The type of metadata element to search for.
230
+ metadata_element_subtypes: list[str], optional
231
+ The subtypes of metadata element to search for.
232
+ skip_relationships: list[str], optional
233
+ The types of relationships to skip.
234
+ include_only_relationships: list[str], optional
235
+ The types of relationships to include.
236
+ skip_classified_elements: list[str], optional
237
+ The types of classified elements to skip.
238
+ include_only_classified_elements: list[str], optional
239
+ The types of classified elements to include.
240
+ graph_query_depth: int, [default=3], optional
241
+ The depth of the graph query.
242
+ governance_zone_filter: list[str], optional
243
+ The governance zones to search in.
244
+ as_of_time: str, optional
245
+ The time to search as of.
246
+ effective_time: str, optional
247
+ The effective time to search at.
248
+ relationship_page_size: int, [default=0], optional
249
+ The page size for relationships.
250
+ limit_results_by_status: list[str], optional
251
+ The statuses to limit results by.
252
+ sequencing_order: str, optional
253
+ The order to sequence results by.
254
+ sequencing_property: str, optional
255
+ The property to sequence results by.
256
+ output_format: str, default = "JSON"
257
+ - one of "MD", "LIST", "FORM", "REPORT", "DICT", "MERMAID" or "JSON"
258
+ report_spec: str | dict , optional, default = None
259
+ - The desired output columns/fields to include.
260
+ start_from: int, [default=0], optional
261
+ When multiple pages of results are available, the page number to start from.
262
+ page_size: int, [default=100]
263
+ The number of items to return in a single page.
264
+ property_names: list[str], optional
265
+ The names of properties to search for.
266
+ body: dict | SearchStringRequestBody, optional, default = None
267
+ - if provided, the search parameters in the body will supercede other attributes, such as "search_string"
268
+
269
+ Returns
270
+ -------
271
+ List | str
272
+
273
+ Output depends on the output format specified.
274
+
275
+ Raises
276
+ ------
277
+
278
+ ValidationError
279
+ If the client passes incorrect parameters on the request that don't conform to the data model.
280
+ PyegeriaException
281
+ Issues raised in communicating or server side processing.
282
+ NotAuthorizedException
283
+ The principle specified by the user_id does not have authorization for the requested action
284
+
285
+ """
286
+ url = f"{self.community_command_base}/communities/by-search-string"
287
+ response = await self._async_find_request(url, _type="Community", _gen_output=self._generate_community_output,
288
+ search_string=search_string, starts_with=starts_with,
289
+ ends_with=ends_with, ignore_case=ignore_case,
290
+ anchor_domain=anchor_domain,
291
+ metadata_element_type=metadata_element_type,
292
+ metadata_element_subtypes=metadata_element_subtypes,
293
+ skip_relationships=skip_relationships,
294
+ include_only_relationships=include_only_relationships,
295
+ skip_classified_elements=skip_classified_elements,
296
+ include_only_classified_elements=include_only_classified_elements,
297
+ graph_query_depth=graph_query_depth,
298
+ governance_zone_filter=governance_zone_filter,
299
+ as_of_time=as_of_time, effective_time=effective_time,
300
+ relationship_page_size=relationship_page_size,
301
+ limit_results_by_status=limit_results_by_status,
302
+ sequencing_order=sequencing_order,
303
+ sequencing_property=sequencing_property,
304
+ output_format=output_format, report_spec=report_spec,
305
+ start_from=start_from, page_size=page_size,
306
+ property_names=property_names, body=body)
307
+
308
+ return response
309
+
310
+ @dynamic_catch
311
+ def find_communities(self, search_string: str = "*",
312
+ starts_with: bool = True, ends_with: bool = False,
313
+ ignore_case: bool = False,
314
+ anchor_domain: Optional[str] = None,
315
+ metadata_element_type: Optional[str] = None,
316
+ metadata_element_subtypes: Optional[list[str]] = None,
317
+ skip_relationships: Optional[list[str]] = None,
318
+ include_only_relationships: Optional[list[str]] = None,
319
+ skip_classified_elements: Optional[list[str]] = None,
320
+ include_only_classified_elements: Optional[list[str]] = None,
321
+ graph_query_depth: int = 3,
322
+ governance_zone_filter: Optional[list[str]] = None, as_of_time: Optional[str] = None,
323
+ effective_time: Optional[str] = None, relationship_page_size: int = 0,
324
+ limit_results_by_status: Optional[list[str]] = None, sequencing_order: Optional[str] = None,
325
+ sequencing_property: Optional[str] = None,
326
+ output_format: str = "JSON",
327
+ report_spec: str | dict = None,
328
+ start_from: int = 0, page_size: int = 100,
329
+ property_names: Optional[list[str]] = None,
330
+ body: Optional[dict | SearchStringRequestBody] = None) -> list | str:
331
+ """ Retrieve the list of community metadata elements that contain the search string.
332
+
333
+ Parameters
334
+ ----------
335
+ search_string: str
336
+ Search string to match against - None or '*' indicate match against all communities.
337
+ starts_with : bool, [default=True], optional
338
+ Starts with the supplied string.
339
+ ends_with : bool, [default=False], optional
340
+ Ends with the supplied string
341
+ ignore_case : bool, [default=False], optional
342
+ Ignore case when searching
343
+ anchor_domain: str, optional
344
+ The anchor domain to search in.
345
+ metadata_element_type: str, optional
346
+ The type of metadata element to search for.
347
+ metadata_element_subtypes: list[str], optional
348
+ The subtypes of metadata element to search for.
349
+ skip_relationships: list[str], optional
350
+ The types of relationships to skip.
351
+ include_only_relationships: list[str], optional
352
+ The types of relationships to include.
353
+ skip_classified_elements: list[str], optional
354
+ The types of classified elements to skip.
355
+ include_only_classified_elements: list[str], optional
356
+ The types of classified elements to include.
357
+ graph_query_depth: int, [default=3], optional
358
+ The depth of the graph query.
359
+ governance_zone_filter: list[str], optional
360
+ The governance zones to search in.
361
+ as_of_time: str, optional
362
+ The time to search as of.
363
+ effective_time: str, optional
364
+ The effective time to search at.
365
+ relationship_page_size: int, [default=0], optional
366
+ The page size for relationships.
367
+ limit_results_by_status: list[str], optional
368
+ The statuses to limit results by.
369
+ sequencing_order: str, optional
370
+ The order to sequence results by.
371
+ sequencing_property: str, optional
372
+ The property to sequence results by.
373
+ output_format: str, default = "JSON"
374
+ - one of "MD", "LIST", "FORM", "REPORT", "DICT", "MERMAID" or "JSON"
375
+ report_spec: str | dict , optional, default = None
376
+ - The desired output columns/fields to include.
377
+ start_from: int, [default=0], optional
378
+ When multiple pages of results are available, the page number to start from.
379
+ page_size: int, [default=100]
380
+ The number of items to return in a single page.
381
+ property_names: list[str], optional
382
+ The names of properties to search for.
383
+ body: dict | SearchStringRequestBody, optional, default = None
384
+ - if provided, the search parameters in the body will supercede other attributes, such as "search_string"
385
+
386
+ Returns
387
+ -------
388
+ List | str
389
+
390
+ Output depends on the output format specified.
391
+
392
+ Raises
393
+ ------
394
+
395
+ ValidationError
396
+ If the client passes incorrect parameters on the request that don't conform to the data model.
397
+ PyegeriaException
398
+ Issues raised in communicating or server side processing.
399
+ NotAuthorizedException
400
+ The principle specified by the user_id does not have authorization for the requested action
401
+
402
+ """
403
+ loop = asyncio.get_event_loop()
404
+ return loop.run_until_complete(self._async_find_communities(search_string=search_string,
405
+ starts_with=starts_with,
406
+ ends_with=ends_with,
407
+ ignore_case=ignore_case,
408
+ anchor_domain=anchor_domain,
409
+ metadata_element_type=metadata_element_type,
410
+ metadata_element_subtypes=metadata_element_subtypes,
411
+ skip_relationships=skip_relationships,
412
+ include_only_relationships=include_only_relationships,
413
+ skip_classified_elements=skip_classified_elements,
414
+ include_only_classified_elements=include_only_classified_elements,
415
+ graph_query_depth=graph_query_depth,
416
+ governance_zone_filter=governance_zone_filter,
417
+ as_of_time=as_of_time,
418
+ effective_time=effective_time,
419
+ relationship_page_size=relationship_page_size,
420
+ limit_results_by_status=limit_results_by_status,
421
+ sequencing_order=sequencing_order,
422
+ sequencing_property=sequencing_property,
423
+ output_format=output_format,
424
+ report_spec=report_spec,
425
+ start_from=start_from,
426
+ page_size=page_size,
427
+ property_names=property_names,
428
+ body=body))
429
+
430
+ # -----------------------------
431
+ # Get by GUID
432
+ # -----------------------------
433
+ @dynamic_catch
434
+ async def _async_get_community_by_guid(
435
+ self,
436
+ community_guid: str,
437
+ body: Optional[dict | GetRequestBody] = None,
438
+ output_format: str = "JSON",
439
+ report_spec: str | dict | None = None,
440
+ ) -> dict | str:
441
+ url = f"{self.community_command_base}/communities/{community_guid}/retrieve"
442
+ response = await self._async_get_guid_request(
443
+ url,
444
+ _type="Community",
445
+ _gen_output=self._generate_community_output,
446
+ output_format=output_format,
447
+ report_spec=report_spec,
448
+ body=body,
449
+ )
450
+ return response
451
+
452
+ @dynamic_catch
453
+ def get_community_by_guid(
454
+ self,
455
+ community_guid: str,
456
+ body: Optional[dict | GetRequestBody] = None,
457
+ output_format: str = "JSON",
458
+ report_spec: str | dict | None = None,
459
+ ) -> dict | str:
460
+ loop = asyncio.get_event_loop()
461
+ return loop.run_until_complete(
462
+ self._async_get_community_by_guid(
463
+ community_guid,
464
+ body,
465
+ output_format,
466
+ report_spec,
467
+ )
468
+ )