pyegeria 0.7.16__tar.gz → 0.7.18__tar.gz

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 (89) hide show
  1. {pyegeria-0.7.16 → pyegeria-0.7.18}/PKG-INFO +1 -1
  2. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cli/egeria.py +17 -9
  3. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cli/egeria_tech.py +20 -10
  4. pyegeria-0.7.18/examples/widgets/tech/get_element_info.py +119 -0
  5. pyegeria-0.7.18/examples/widgets/tech/list_related_specification.py +144 -0
  6. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyproject.toml +2 -2
  7. {pyegeria-0.7.16 → pyegeria-0.7.18}/LICENSE +0 -0
  8. {pyegeria-0.7.16 → pyegeria-0.7.18}/README.md +0 -0
  9. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/doc_samples/Create_Collection_Sample.py +0 -0
  10. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/doc_samples/Create_Sustainability_Collection_Sample.py +0 -0
  11. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/README.md +0 -0
  12. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/__init__.py +0 -0
  13. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/get_asset_graph.py +0 -0
  14. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/get_collection.py +0 -0
  15. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/get_project_structure.py +0 -0
  16. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/get_tech_type_elements.py +0 -0
  17. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/get_tech_type_template.py +0 -0
  18. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/list_assets.py +0 -0
  19. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/list_cert_types.py +0 -0
  20. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/list_glossary.py +0 -0
  21. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/list_projects.py +0 -0
  22. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/list_relationships.py +0 -0
  23. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/list_tech_types.py +0 -0
  24. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cat/list_todos.py +0 -0
  25. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cli/__init__.py +0 -0
  26. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cli/egeria_cat.py +0 -0
  27. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cli/egeria_my.py +0 -0
  28. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cli/egeria_ops.py +0 -0
  29. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/cli/ops_config.py +0 -0
  30. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/my/README.md +0 -0
  31. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/my/__init__.py +0 -0
  32. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/my/list_my_profile.py +0 -0
  33. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/my/list_my_roles.py +0 -0
  34. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/my/monitor_my_todos.py +0 -0
  35. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/my/monitor_open_todos.py +0 -0
  36. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/my/my_profile_actions.py +0 -0
  37. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/README.md +0 -0
  38. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/__init__.py +0 -0
  39. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/engine_actions.py +0 -0
  40. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/integration_daemon_actions.py +0 -0
  41. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/list_catalog_targets.py +0 -0
  42. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/load_archive.py +0 -0
  43. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_asset_events.py +0 -0
  44. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_coco_status.py +0 -0
  45. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_engine_activity.py +0 -0
  46. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_gov_eng_status.py +0 -0
  47. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_integ_daemon_status.py +0 -0
  48. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_platform_status.py +0 -0
  49. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_server_list.py +0 -0
  50. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/monitor_server_status.py +0 -0
  51. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/refresh_integration_daemon.py +0 -0
  52. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/ops/restart_integration_daemon.py +0 -0
  53. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/README.md +0 -0
  54. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/__init__.py +0 -0
  55. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/get_guid_info.py +0 -0
  56. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/get_tech_details.py +0 -0
  57. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/list_asset_types.py +0 -0
  58. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/list_elements.py +0 -0
  59. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/list_registered_services.py +0 -0
  60. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/list_relationship_types.py +0 -0
  61. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/list_tech_templates.py +0 -0
  62. {pyegeria-0.7.16 → pyegeria-0.7.18}/examples/widgets/tech/list_valid_metadata_values.py +0 -0
  63. /pyegeria-0.7.16/examples/widgets/tech/list_related_elements.py → /pyegeria-0.7.18/examples/widgets/tech/x_list_related_elements.py +0 -0
  64. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/Xloaded_resources_omvs.py +0 -0
  65. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/__init__.py +0 -0
  66. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/_client.py +0 -0
  67. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/_deprecated_gov_engine.py +0 -0
  68. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/_exceptions.py +0 -0
  69. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/_globals.py +0 -0
  70. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/_validators.py +0 -0
  71. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/action_author_omvs.py +0 -0
  72. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/asset_catalog_omvs.py +0 -0
  73. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/automated_curation_omvs.py +0 -0
  74. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/classification_manager_omvs.py +0 -0
  75. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/collection_manager_omvs.py +0 -0
  76. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/core_omag_server_config.py +0 -0
  77. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/create_tech_guid_lists.py +0 -0
  78. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/feedback_manager_omvs.py +0 -0
  79. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/full_omag_server_config.py +0 -0
  80. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/glossary_browser_omvs.py +0 -0
  81. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/glossary_manager_omvs.py +0 -0
  82. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/my_profile_omvs.py +0 -0
  83. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/platform_services.py +0 -0
  84. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/project_manager_omvs.py +0 -0
  85. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/registered_info.py +0 -0
  86. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/runtime_manager_omvs.py +0 -0
  87. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/server_operations.py +0 -0
  88. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/utils.py +0 -0
  89. {pyegeria-0.7.16 → pyegeria-0.7.18}/pyegeria/valid_metadata_omvs.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pyegeria
3
- Version: 0.7.16
3
+ Version: 0.7.18
4
4
  Summary: A python client for Egeria
5
5
  Home-page: https://github.com/odpi/egeria-python
6
6
  License: Apache 2.0
@@ -52,7 +52,8 @@ from examples.widgets.tech.list_relationship_types import display_relationship_t
52
52
  from examples.widgets.tech.list_tech_templates import display_templates_spec
53
53
  from examples.widgets.tech.list_valid_metadata_values import display_metadata_values
54
54
  from examples.widgets.tech.list_elements import list_elements
55
- from examples.widgets.tech.list_related_elements import display_related_elements
55
+ from examples.widgets.tech.get_element_info import display_elements
56
+ from examples.widgets.tech.list_related_specification import display_related_specification
56
57
 
57
58
 
58
59
  @tui()
@@ -199,11 +200,20 @@ def show(ctx):
199
200
  pass
200
201
 
201
202
 
202
- @show.command("list-elements")
203
+ @show.command("get-elements")
203
204
  @click.pass_context
204
205
  @click.option('--om_type', default='Project', help='Metadata type to query')
205
206
  def get_element_info(ctx, om_type):
206
- """Display the valid metadata values for a property and type"""
207
+ """Display the elements for an Open Metadata Type"""
208
+ c = ctx.obj
209
+ display_elements(om_type, c.view_server, c.view_server_url,
210
+ c.userid, c.password, c.jupyter, c.width)
211
+
212
+ @show.command("list-elements")
213
+ @click.pass_context
214
+ @click.option('--om_type', default='Project', help='Metadata type to query')
215
+ def list_element_info(ctx, om_type):
216
+ """Display the elements for an Open Metadata Type"""
207
217
  c = ctx.obj
208
218
  list_elements(om_type, c.view_server, c.view_server_url,
209
219
  c.userid, c.password, c.jupyter, c.width)
@@ -277,15 +287,13 @@ def show_registered_services(ctx, services):
277
287
  display_registered_svcs(services, c.view_server, c.view_server_url,
278
288
  c.userid, c.password, c.jupyter, c.width)
279
289
 
280
- @show.command('related-elements')
290
+ @show.command('related-specifications')
281
291
  @click.pass_context
282
292
  @click.argument('element-guid')
283
- @click.option('--rel-type',default = 'SpecificationPropertyAssignment',
284
- help="Relationship type to find related elements of")
285
- @click.option('--om_type', default = None, help="Optional Open Metadata Type to filter by.")
286
- def show_related_elements(ctx, element_guid, rel_type, om_type):
293
+ def show_related_specifications(ctx, element_guid):
294
+ """List specifications related to the given Element"""
287
295
  c = ctx.obj
288
- display_related_elements(element_guid,rel_type,om_type, c.view_server, c.view_server_url,
296
+ display_related_specification(element_guid, c.view_server, c.view_server_url,
289
297
  c.userid, c.password, c.jupyter, c.width)
290
298
 
291
299
 
@@ -23,7 +23,8 @@ from examples.widgets.tech.list_tech_templates import display_templates_spec
23
23
  from examples.widgets.tech.list_valid_metadata_values import display_metadata_values
24
24
  from examples.widgets.cat.get_tech_type_template import template_viewer
25
25
  from examples.widgets.tech.list_elements import list_elements
26
- from examples.widgets.tech.list_related_elements import display_related_elements
26
+ from examples.widgets.tech.get_element_info import display_elements
27
+ from examples.widgets.tech.list_related_specification import display_related_specification
27
28
 
28
29
 
29
30
 
@@ -111,6 +112,16 @@ def show_guid_infos(ctx, guid):
111
112
  display_guid(guid, c.server, c.url,
112
113
  c.userid, c.password, c.jupyter, c.width)
113
114
 
115
+ @show.command('related-specifications')
116
+ @click.pass_context
117
+ @click.argument('element-guid')
118
+ def show_related_specifications(ctx, element_guid):
119
+ """List specifications related to the given Element"""
120
+ c = ctx.obj
121
+ display_related_specification(element_guid,c.view_server, c.view_server_url,
122
+ c.userid, c.password, c.jupyter, c.width)
123
+
124
+
114
125
 
115
126
  @show.command('tech-types')
116
127
  @click.option('--search-string', default='*', help='Tech type to search for')
@@ -211,22 +222,21 @@ def valid_metadata_values(ctx, property, type_name):
211
222
  @show.command('list-elements')
212
223
  @click.pass_context
213
224
  @click.option('--om_type', default='Organization', help='Metadata type to query')
214
- def get_element_info(ctx, om_type):
225
+ def list_element_info(ctx, om_type):
215
226
  """Display the valid metadata values for a property and type"""
216
227
  c = ctx.obj
217
228
  list_elements(om_type, c.view_server, c.view_server_url,
218
229
  c.userid, c.password, c.jupyter, c.width)
219
230
 
220
- @show.command('related-elements')
231
+ @show.command("get-elements")
221
232
  @click.pass_context
222
- @click.argument('element-guid')
223
- @click.option('--rel-type',default = 'SpecificationPropertyAssignment',
224
- help="Relationship type to find related elements of")
225
- @click.option('--om_type', default = None, help="Optional Open Metadata Type to filter by.")
226
- def show_related_elements(ctx, element_guid, rel_type, om_type):
233
+ @click.option('--om_type', default='Project', help='Metadata type to query')
234
+ def get_element_info(ctx, om_type):
235
+ """Display the elements for an Open Metadata Type"""
227
236
  c = ctx.obj
228
- display_related_elements(element_guid,rel_type,om_type, c.view_server, c.view_server_url,
229
- c.userid, c.password, c.jupyter, c.width)
237
+ display_elements(om_type, c.view_server, c.view_server_url,
238
+ c.userid, c.password, c.jupyter, c.width)
239
+
230
240
 
231
241
  #
232
242
  # Tell
@@ -0,0 +1,119 @@
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
+
8
+ A simple display of elements for an Open Metadata Type in tree form.
9
+ """
10
+ import argparse
11
+ import json
12
+ import os
13
+ import sys
14
+
15
+ from rich import print, box
16
+ from rich.console import Console
17
+ from rich.markdown import Markdown
18
+ from rich.panel import Panel
19
+
20
+ from rich.prompt import Prompt
21
+ from rich.text import Text
22
+ from rich.tree import Tree
23
+
24
+ from pyegeria import (
25
+ InvalidParameterException,
26
+ PropertyServerException,
27
+ UserNotAuthorizedException,
28
+ Client, ClassificationManager
29
+ )
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('VIEW_SERVER', 'view-server')
36
+ EGERIA_VIEW_SERVER_URL = os.environ.get('EGERIA_VIEW_SERVER_URL', 'https://localhost:9443')
37
+ EGERIA_INTEGRATION_DAEMON = os.environ.get('INTEGRATION_DAEMON', 'integration-daemon')
38
+ EGERIA_ADMIN_USER = os.environ.get('ADMIN_USER', 'garygeeke')
39
+ EGERIA_ADMIN_PASSWORD = os.environ.get('ADMIN_PASSWORD', 'secret')
40
+ EGERIA_USER = os.environ.get('EGERIA_USER', 'erinoverview')
41
+ EGERIA_USER_PASSWORD = os.environ.get('EGERIA_USER_PASSWORD', 'secret')
42
+ EGERIA_JUPYTER = bool(os.environ.get('EGERIA_JUPYTER', 'False'))
43
+ EGERIA_WIDTH = int(os.environ.get('EGERIA_WIDTH', '200'))
44
+
45
+
46
+ def display_elements(om_type: str, server: str, url: str, username: str, user_password: str,
47
+ jupyter: bool = EGERIA_JUPYTER, width: int = EGERIA_WIDTH
48
+ ):
49
+ c = ClassificationManager(server, url, user_id=username, user_pwd=user_password)
50
+
51
+ bearer_token = c.create_egeria_bearer_token(username, user_password)
52
+
53
+ try:
54
+ console = Console(width=width, force_terminal=not jupyter, style="bold white on black")
55
+ r = c.get_elements(om_type)
56
+ if type(r) is not list:
57
+ print(f"\n\n\tno elements found: {r}")
58
+ sys.exit(1)
59
+
60
+ tree = Tree(f"Elements for Open Metadata Type:{om_type}\n* There are {len(r)} elements", style="bold bright_white on black",
61
+ guide_style="bold bright_blue")
62
+ t = tree.add(f"Elements for {om_type}", style="bold bright_white on black")
63
+ for element in r:
64
+ header = element['elementHeader']
65
+ el_type = header["type"]['typeName']
66
+ el_home = header['origin']['homeMetadataCollectionName']
67
+ el_create_time = header['versions']['createTime']
68
+ el_guid = header['guid']
69
+
70
+ el_md = (f"#### Element Basics\n"
71
+ f"* **Type**: {el_type}\n"
72
+ f"* **Home**: {el_home}\n"
73
+ f"* **Created**: {el_create_time}\n"
74
+ f"* **GUID**: {el_guid}\n ---\n")
75
+ for prop in element['properties'].keys():
76
+ el_md += f"* **{prop}**: {element['properties'][prop]}\n"
77
+
78
+ el_out = Markdown(el_md)
79
+ p = Panel.fit(el_out, title=element['properties']['qualifiedName'],
80
+ style = "bold white on black")
81
+ t = tree.add(p)
82
+
83
+ print(tree)
84
+
85
+ c.close_session()
86
+
87
+ except (InvalidParameterException, PropertyServerException, UserNotAuthorizedException, ValueError) as e:
88
+ if type(e) is str:
89
+ console.print_exception()
90
+ else:
91
+ # console.print_exception(show_locals=True)
92
+ console.print(f"\n ===> Looks like the type {om_type} isn't known...\n")
93
+
94
+
95
+
96
+ def main():
97
+ parser = argparse.ArgumentParser()
98
+ parser.add_argument("--server", help="Name of the server to display status for")
99
+ parser.add_argument("--url", help="URL Platform to connect to")
100
+ parser.add_argument("--userid", help="User Id")
101
+ parser.add_argument("--password", help="User Password")
102
+
103
+ # parser.add_argument("--sponsor", help="Name of sponsor to search")
104
+ args = parser.parse_args()
105
+
106
+ server = args.server if args.server is not None else EGERIA_VIEW_SERVER
107
+ url = args.url if args.url is not None else EGERIA_VIEW_SERVER_URL
108
+ userid = args.userid if args.userid is not None else EGERIA_USER
109
+ user_pass = args.password if args.password is not None else EGERIA_USER_PASSWORD
110
+
111
+ try:
112
+ om_type = Prompt.ask("Enter the Open Metadata Type to find Elements for", default=None)
113
+ display_elements(om_type, server, url, userid, user_pass)
114
+ except (KeyboardInterrupt):
115
+ pass
116
+
117
+
118
+ if __name__ == "__main__":
119
+ main()
@@ -0,0 +1,144 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ SPDX-License-Identifier: Apache-2.0
4
+ Copyright Contributors to the ODPi Egeria project.
5
+
6
+ List elements related to given element guid by the specified relationship type. Optionally filter by a specified
7
+ open metadata type.
8
+
9
+ """
10
+ import argparse
11
+ import os
12
+ import sys
13
+ import time
14
+
15
+ from rich import box
16
+ from rich.console import Console
17
+ from rich.markdown import Markdown
18
+ from rich.prompt import Prompt
19
+ from rich.table import Table
20
+
21
+ from pyegeria import (InvalidParameterException, PropertyServerException, UserNotAuthorizedException,
22
+ print_exception_response, ClassificationManager)
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('EGERIA_VIEW_SERVER_URL', 'https://localhost:9443')
30
+ EGERIA_INTEGRATION_DAEMON = os.environ.get('INTEGRATION_DAEMON', 'integration-daemon')
31
+ EGERIA_ADMIN_USER = os.environ.get('ADMIN_USER', 'garygeeke')
32
+ EGERIA_ADMIN_PASSWORD = os.environ.get('ADMIN_PASSWORD', 'secret')
33
+ EGERIA_USER = os.environ.get('EGERIA_USER', 'erinoverview')
34
+ EGERIA_USER_PASSWORD = os.environ.get('EGERIA_USER_PASSWORD', 'secret')
35
+ EGERIA_JUPYTER = bool(os.environ.get('EGERIA_JUPYTER', 'False'))
36
+ EGERIA_WIDTH = int(os.environ.get('EGERIA_WIDTH', '200'))
37
+
38
+
39
+ def display_related_specification(element_guid: str, server: str, url: str, username: str, password: str,
40
+ jupyter: bool = EGERIA_JUPYTER, width: int = EGERIA_WIDTH):
41
+ c_client = ClassificationManager(server, url, user_id=username, user_pwd=password)
42
+ token = c_client.create_egeria_bearer_token()
43
+ rel_el = c_client.get_related_elements(element_guid, 'SpecificationPropertyAssignment', None)
44
+
45
+ if type(rel_el) is str:
46
+ print(f"\n\nDid not find related specifications for {element_guid}\n\n")
47
+ sys.exit(0)
48
+
49
+ related_elements: dict = {}
50
+
51
+ def generate_table() -> Table:
52
+ """Make a new table."""
53
+ table = Table(title=f"Specifications related to: {element_guid} @ {time.asctime()}",
54
+ style="bold bright_white on black", row_styles=["bold bright_white on black"],
55
+ header_style="white on dark_blue", title_style="bold bright_white on black", caption_style="white on black",
56
+ show_lines=True, box=box.ROUNDED, caption=f"Elements from Server '{server}' @ Platform - {url}",
57
+ expand=True, # width=500
58
+ )
59
+
60
+ table.add_column("Name", justify='center', style="bold bright_white")
61
+ table.add_column("Specification", justify='center', style="bold bright_white")
62
+
63
+ for element in rel_el:
64
+ relationship_props = element["relationshipProperties"]['propertyType']
65
+ related_elements[relationship_props] = []
66
+
67
+ for element in rel_el:
68
+ relationship_props = element["relationshipProperties"]['propertyType']
69
+
70
+ rel_element = element['relatedElement']
71
+ el = rel_element["properties"]
72
+ re: dict = {}
73
+
74
+ re['case'] = el.get("isCaseSensitive", '---')
75
+ re['name'] = el.get("preferredValue", '---')
76
+ re['description'] = el.get("description", '---')
77
+ add = el.get("additionalProperties", '---')
78
+ if type(add) is str:
79
+ re['additional'] = add
80
+ else:
81
+ add_md = ""
82
+ for k in add.keys():
83
+ add_md += f"* {k}: {add[k]}\n"
84
+ re['additional'] = Markdown(add_md)
85
+
86
+ related_elements[relationship_props].append(re)
87
+
88
+ for kind in related_elements.keys():
89
+
90
+ spec_table = Table(expand=False, show_lines=True)
91
+ spec_table.add_column('Name')
92
+ spec_table.add_column('Case Sensitive?')
93
+ spec_table.add_column('Description')
94
+ spec_table.add_column('Additional Properties')
95
+
96
+ for spec_row in related_elements[kind]:
97
+ name = spec_row['name']
98
+ case = spec_row['case']
99
+ desc = spec_row['description']
100
+ additional_props = spec_row['additional']
101
+ spec_table.add_row(name, case, desc, additional_props)
102
+
103
+ table.add_row(kind, spec_table)
104
+
105
+ return table
106
+
107
+ try:
108
+ console = Console(width=width, force_terminal=not jupyter)
109
+
110
+ with console.pager(styles=True):
111
+ console.print(generate_table())
112
+
113
+ except (InvalidParameterException, PropertyServerException, UserNotAuthorizedException) as e:
114
+ print_exception_response(e)
115
+ assert e.related_http_code != "200", "Invalid parameters"
116
+ finally:
117
+ c_client.close_session()
118
+
119
+
120
+ def main():
121
+ parser = argparse.ArgumentParser()
122
+ parser.add_argument("--server", help="Name of the server to display status for")
123
+ parser.add_argument("--url", help="URL Platform to connect to")
124
+ parser.add_argument("--userid", help="User Id")
125
+ parser.add_argument("--password", help="Password")
126
+
127
+ args = parser.parse_args()
128
+
129
+ server = args.server if args.server is not None else EGERIA_VIEW_SERVER
130
+ url = args.url if args.url is not None else EGERIA_PLATFORM_URL
131
+ userid = args.userid if args.userid is not None else EGERIA_USER
132
+ password = args.password if args.password is not None else EGERIA_USER_PASSWORD
133
+ guid = None
134
+
135
+ try:
136
+ element_guid = Prompt.ask("Enter an Element GUID find relationships for")
137
+
138
+ display_related_specification(element_guid, server, url, userid, password)
139
+ except(KeyboardInterrupt):
140
+ pass
141
+
142
+
143
+ if __name__ == "__main__":
144
+ main()
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "pyegeria"
3
- version = "0.7.16"
3
+ version = "0.7.18"
4
4
  license = 'Apache 2.0'
5
5
  authors = ["Dan Wolfson <dan.wolfson@pdr-associates.com>"]
6
6
  readme = "README.md"
@@ -100,6 +100,6 @@ pytest = "^8.2.2"
100
100
  list_tech_templates = "examples.widgets.tech.list_tech_templates:main"
101
101
  get_element_info = "examples.widgets.tech.get_element_info:main"
102
102
  list_elements = "examples.widgets.tech.list_elements:main"
103
- list_related_elements = "examples.widgets.tech.list_related_elements:main"
103
+ list_related_specification = "examples.widgets.tech.list_related_specification:main"
104
104
 
105
105
  list_valid_metadata_values = "examples.widgets.tech.list_valid_metadata_values:main"
File without changes
File without changes
File without changes
File without changes