cmem-cmemc 24.1.2__py3-none-any.whl → 24.1.3__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
cmem_cmemc/__init__.py CHANGED
@@ -27,7 +27,7 @@ from cmem_cmemc.exceptions import InvalidConfigurationError
27
27
  from cmem_cmemc.manual_helper.graph import print_manual_graph
28
28
  from cmem_cmemc.manual_helper.multi_page import create_multi_page_documentation
29
29
  from cmem_cmemc.manual_helper.single_page import print_manual
30
- from cmem_cmemc.utils import extract_error_message, get_version
30
+ from cmem_cmemc.utils import check_python_version, extract_error_message, get_version
31
31
 
32
32
  CMEMC_VERSION = get_version()
33
33
 
@@ -39,16 +39,10 @@ if os.environ.get("_CMEMC_COMPLETE", "") == "zsh_source":
39
39
 
40
40
  version = sys.version_info
41
41
  PYTHON_VERSION = f"{version.major}.{version.minor}.{version.micro}"
42
- PYTHON_EXPECTED = "3.11"
43
- PYTHON_GOT = f"{version.major}.{version.minor}"
44
- if PYTHON_EXPECTED != PYTHON_GOT and not CONTEXT.is_completing():
45
- CONTEXT.echo_warning(
46
- "Warning: You are running cmemc under a non-tested python "
47
- f"environment (expected {PYTHON_EXPECTED}, got {PYTHON_GOT})"
48
- )
42
+ check_python_version(ctx=CONTEXT)
49
43
 
50
44
  # set the user-agent environment for the http request headers
51
- os.environ["CMEM_USER_AGENT"] = f"cmemc/{CMEMC_VERSION} " f"(Python {PYTHON_VERSION})"
45
+ os.environ["CMEM_USER_AGENT"] = f"cmemc/{CMEMC_VERSION} (Python {PYTHON_VERSION})"
52
46
 
53
47
  # https://github.com/pallets/click/blob/master/examples/complex/complex/cli.py
54
48
  CONTEXT_SETTINGS = {"auto_envvar_prefix": "CMEMC", "help_option_names": ["-h", "--help"]}
@@ -1,6 +1,6 @@
1
1
  """admin commands for cmem command line interface."""
2
2
 
3
- from datetime import UTC, datetime
3
+ from datetime import datetime, timezone
4
4
 
5
5
  import click
6
6
  import jwt
@@ -42,9 +42,9 @@ def _check_graphdb_license(app: ApplicationContext, data: dict, months: int, exi
42
42
  # DP < 24.1 has no graph license information here
43
43
  return
44
44
  expiration_date_str = data["dp"]["info"]["store"]["licenseExpiration"]
45
- expiration_date = datetime.strptime(expiration_date_str, "%Y-%m-%d").astimezone(tz=UTC)
45
+ expiration_date = datetime.strptime(expiration_date_str, "%Y-%m-%d").astimezone(tz=timezone.utc)
46
46
  grace_starts = expiration_date - relativedelta(months=months)
47
- if grace_starts < datetime.now(tz=UTC):
47
+ if grace_starts < datetime.now(tz=timezone.utc):
48
48
  graphdb_license_end = data["dp"]["info"]["store"]["licenseExpiration"]
49
49
  output = f"Your GraphDB license expires on {graphdb_license_end}."
50
50
  if exit_1 == "always":
@@ -1,7 +1,7 @@
1
1
  """graph validation command group"""
2
2
 
3
3
  import time
4
- from datetime import UTC, datetime
4
+ from datetime import datetime, timezone
5
5
 
6
6
  import click
7
7
  import requests
@@ -145,8 +145,8 @@ def _get_batch_validation_option(validation_: dict) -> tuple[str, str]:
145
145
  id_ = validation_["id"]
146
146
  state = validation_["state"]
147
147
  graph = validation_["contextGraphIri"]
148
- stamp = datetime.fromtimestamp(validation_["executionStarted"] / 1000, tz=UTC)
149
- time_ago = timeago.format(stamp, datetime.now(tz=UTC))
148
+ stamp = datetime.fromtimestamp(validation_["executionStarted"] / 1000, tz=timezone.utc)
149
+ time_ago = timeago.format(stamp, datetime.now(tz=timezone.utc))
150
150
  resources = _get_resource_count(validation_)
151
151
  violations = _get_violation_count(validation_)
152
152
  return (
@@ -409,8 +409,8 @@ def list_command(ctx: Context, filter_: tuple[tuple[str, str]], id_only: bool, r
409
409
  table = []
410
410
  for _ in validations:
411
411
  if "executionStarted" in _ and _["executionStarted"] is not None:
412
- stamp = datetime.fromtimestamp(_["executionStarted"] / 1000, tz=UTC)
413
- time_ago = timeago.format(stamp, datetime.now(tz=UTC))
412
+ stamp = datetime.fromtimestamp(_["executionStarted"] / 1000, tz=timezone.utc)
413
+ time_ago = timeago.format(stamp, datetime.now(tz=timezone.utc))
414
414
  else:
415
415
  time_ago = f"{_['state']}"
416
416
  row = [
@@ -1,7 +1,7 @@
1
1
  """vocabularies commands for cmem command line interface."""
2
2
 
3
3
  import io
4
- from datetime import UTC, datetime
4
+ from datetime import datetime, timezone
5
5
  from re import match
6
6
  from urllib.parse import urlparse
7
7
 
@@ -141,7 +141,7 @@ def _insert_catalog_entry(iri: str, prefix: str, namespace: str, label: str, lan
141
141
  iri=iri,
142
142
  prefix=prefix,
143
143
  namespace=namespace,
144
- date=datetime.now(tz=UTC).date(),
144
+ date=datetime.now(tz=timezone.utc).date(),
145
145
  label=label,
146
146
  language=language,
147
147
  description="vocabulary imported with cmemc",
@@ -3,7 +3,7 @@
3
3
  import re
4
4
  import sys
5
5
  import time
6
- from datetime import UTC, datetime
6
+ from datetime import datetime, timezone
7
7
  from pathlib import Path
8
8
 
9
9
  import click
@@ -320,8 +320,8 @@ def _workflow_echo_status(app: ApplicationContext, status: dict) -> None:
320
320
  canceled only exists sometimes
321
321
  """
322
322
  # prepare human friendly relative time
323
- now = datetime.now(tz=UTC)
324
- stamp = datetime.fromtimestamp(status["lastUpdateTime"] / 1000, tz=UTC)
323
+ now = datetime.now(tz=timezone.utc)
324
+ stamp = datetime.fromtimestamp(status["lastUpdateTime"] / 1000, tz=timezone.utc)
325
325
  time_ago = timeago.format(stamp, now, "en")
326
326
  status_name = status["statusName"]
327
327
  status_message = status["message"]
cmem_cmemc/context.py CHANGED
@@ -6,7 +6,7 @@ import json
6
6
  import os
7
7
  import re
8
8
  import subprocess # nosec
9
- from datetime import UTC, datetime
9
+ from datetime import datetime, timezone
10
10
  from os import environ as env
11
11
  from os import getenv
12
12
  from pathlib import Path
@@ -94,7 +94,7 @@ class ApplicationContext:
94
94
  def get_template_data(self) -> dict[str, str]:
95
95
  """Get the template data dict with vars from the context."""
96
96
  data: dict[str, str] = {}
97
- today = str(datetime.now(tz=UTC).date())
97
+ today = str(datetime.now(tz=timezone.utc).date())
98
98
  data.update(date=today)
99
99
  if self.connection is not None:
100
100
  data.update(connection=self.connection.name)
@@ -268,7 +268,7 @@ class ApplicationContext:
268
268
  """Output a debug message if --debug is enabled."""
269
269
  # pylint: disable=invalid-name
270
270
  if self.debug:
271
- now = datetime.now(tz=UTC)
271
+ now = datetime.now(tz=timezone.utc)
272
272
  click.secho(f"[{now!s}] {message}", err=True, dim=True)
273
273
 
274
274
  def echo_info(self, message: str | list[str] | set[str], nl: bool = True, fg: str = "") -> None:
cmem_cmemc/utils.py CHANGED
@@ -3,9 +3,10 @@
3
3
  import json
4
4
  import os
5
5
  import re
6
+ import sys
6
7
  import unicodedata
7
8
  from dataclasses import dataclass
8
- from importlib.metadata import version
9
+ from importlib.metadata import version as cmemc_version
9
10
  from pathlib import Path
10
11
 
11
12
  import requests
@@ -22,7 +23,22 @@ from cmem_cmemc.context import ApplicationContext
22
23
 
23
24
  def get_version() -> str:
24
25
  """Get the current version or SNAPSHOT."""
25
- return version("cmem-cmemc")
26
+ return cmemc_version("cmem-cmemc")
27
+
28
+
29
+ def check_python_version(ctx: ApplicationContext) -> None:
30
+ """Check the runtime python version and warn or error."""
31
+ version = sys.version_info
32
+ major_expected = [3]
33
+ minor_expected = [10, 11, 12]
34
+ if version.major not in major_expected:
35
+ ctx.echo_error(f"Error: cmemc can not be executed with Python {version.major}.")
36
+ sys.exit(1)
37
+ if version.minor not in minor_expected and not ctx.is_completing():
38
+ ctx.echo_warning(
39
+ "Warning: You are running cmemc under a non-tested python "
40
+ f"environment ({version.major}.{version.minor})."
41
+ )
26
42
 
27
43
 
28
44
  def extract_error_message(error: Exception) -> str:
@@ -0,0 +1,87 @@
1
+ Metadata-Version: 2.1
2
+ Name: cmem-cmemc
3
+ Version: 24.1.3
4
+ Summary: Command line client for eccenca Corporate Memory
5
+ Home-page: https://eccenca.com/go/cmemc
6
+ License: Apache 2.0
7
+ Author: eccenca
8
+ Author-email: cmempy-developer@eccenca.com
9
+ Requires-Python: >=3.9,<4.0
10
+ Classifier: Development Status :: 5 - Production/Stable
11
+ Classifier: Environment :: Console
12
+ Classifier: Intended Audience :: Customer Service
13
+ Classifier: Intended Audience :: Developers
14
+ Classifier: Intended Audience :: Information Technology
15
+ Classifier: Intended Audience :: Science/Research
16
+ Classifier: Intended Audience :: System Administrators
17
+ Classifier: License :: OSI Approved :: Apache Software License
18
+ Classifier: License :: Other/Proprietary License
19
+ Classifier: Natural Language :: English
20
+ Classifier: Operating System :: OS Independent
21
+ Classifier: Programming Language :: Python :: 3
22
+ Classifier: Programming Language :: Python :: 3.9
23
+ Classifier: Programming Language :: Python :: 3.10
24
+ Classifier: Programming Language :: Python :: 3.11
25
+ Classifier: Programming Language :: Python :: 3.12
26
+ Classifier: Programming Language :: Python :: 3 :: Only
27
+ Classifier: Topic :: Database
28
+ Classifier: Topic :: Software Development :: Testing
29
+ Classifier: Topic :: Utilities
30
+ Requires-Dist: beautifulsoup4 (>=4.12.2,<5.0.0)
31
+ Requires-Dist: certifi (>=2023.5.7)
32
+ Requires-Dist: click (>=8.1.7,<9.0.0)
33
+ Requires-Dist: click-didyoumean (>=0.3.0,<0.4.0)
34
+ Requires-Dist: click-help-colors (>=0.9.1,<0.10.0)
35
+ Requires-Dist: cmem-cmempy (==24.1.1)
36
+ Requires-Dist: configparser (>=5.3.0,<6.0.0)
37
+ Requires-Dist: jinja2 (>=3.1.2,<4.0.0)
38
+ Requires-Dist: natsort (>=8.3.1,<9.0.0)
39
+ Requires-Dist: prometheus-client (>=0.16.0,<0.17.0)
40
+ Requires-Dist: pygments (>=2.15.1,<3.0.0)
41
+ Requires-Dist: pyjwt (>=2.7.0,<3.0.0)
42
+ Requires-Dist: python-dateutil (>=2.8.2,<3.0.0)
43
+ Requires-Dist: requests (>=2.31.0,<3.0.0)
44
+ Requires-Dist: rich (>=13.7.0,<14.0.0)
45
+ Requires-Dist: six (>=1.16.0,<2.0.0)
46
+ Requires-Dist: timeago (>=1.0.16,<2.0.0)
47
+ Requires-Dist: treelib (>=1.6.4,<2.0.0)
48
+ Requires-Dist: urllib3 (>=2,<3)
49
+ Description-Content-Type: text/markdown
50
+
51
+ # cmemc
52
+
53
+ cmemc is the official command line client for [eccenca Corporate Memory](https://documentation.eccenca.com/).
54
+
55
+ [![version][version-shield]][changelog] [![Python Versions][python-shield]][pypi] [![eccenca Corporate Memory][cmem-shield]][cmem]
56
+
57
+ [![teaser][teaser-image]][cmemc-docu]
58
+
59
+ ## Installation
60
+
61
+ In order to install the cmemc, run:
62
+
63
+ pipx install cmem-cmemc
64
+
65
+ Of course you can install cmemc also with pip, but we recommend [pipx](https://pypa.github.io/pipx/) for normal desktop usage.
66
+
67
+ ## Configuration and Usage
68
+
69
+ cmemc is intended for System Administrators and Linked Data Expert, who wants to automate and remote control activities on eccenca Corporate Memory.
70
+
71
+ The cmemc manual including basic usage pattern, configuration as well as a command reference is available at:
72
+
73
+ [https://eccenca.com/go/cmemc](https://eccenca.com/go/cmemc)
74
+
75
+ cmemc only works with Python 3 and refuses to work with Python 2.x.
76
+ In addition to that, cmemc will warn you in case an untested Python environment is used.
77
+
78
+
79
+ [version-shield]: https://badge.fury.io/py/cmem-cmemc.svg
80
+ [changelog]: https://pypi.org/project/cmem-cmemc/#history
81
+ [python-shield]: https://img.shields.io/pypi/pyversions/cmem-cmemc.svg
82
+ [pypi]: https://pypi.org/project/cmem-cmemc/
83
+ [cmem]: https://documentation.eccenca.com
84
+ [cmem-shield]: https://img.shields.io/badge/made%20for-eccenca%20Corporate%20Memory-blue?logo=
85
+ [teaser-image]: https://documentation.eccenca.com/24.1/automate/cmemc-command-line-interface/configuration/completion-setup/22.1-cmemc-create-dataset.gif
86
+ [cmemc-docu]: https://eccenca.com/go/cmemc
87
+
@@ -1,8 +1,8 @@
1
- cmem_cmemc/__init__.py,sha256=WOoZ0R_OAd5p6NAtcQGFdvDv5OLBeQOUYWHY-f3CNzc,5789
1
+ cmem_cmemc/__init__.py,sha256=z7zjBQWM1c2nW9ylGUelIPiKBtXhIO38qILBJXzuEWs,5532
2
2
  cmem_cmemc/_cmemc.zsh,sha256=fmkrBHIQxus8cp2AgO1tzZ5mNZdGL_83cYz3a9uAdsg,1326
3
3
  cmem_cmemc/commands/__init__.py,sha256=_PsHWhMFwyfRAYInt0AOs3dA3Cuqhsnf_enFLjxVCGQ,3626
4
4
  cmem_cmemc/commands/acl.py,sha256=cA76UvQquhZc9MdS3e94kcfSn9V_RzTQ5XM0Ko6w6hM,13769
5
- cmem_cmemc/commands/admin.py,sha256=tlN4bK_xcqeEUnA0DlbNPsSMXm_CeF_K1_mvybBqLe8,8658
5
+ cmem_cmemc/commands/admin.py,sha256=pv9N9laUWV7xevOw0toLBezRz2_B5spcgwU2B-pqaAY,8681
6
6
  cmem_cmemc/commands/client.py,sha256=23Sc3h64eAMaB4bJVfiamR470DMpDj1hsPWKsxUSMLg,5039
7
7
  cmem_cmemc/commands/config.py,sha256=9-xEtHoJyaqU9J7C8a3Q7SpPvJQHLufMXxZYuXYQ5Pk,5699
8
8
  cmem_cmemc/commands/dataset.py,sha256=hn3449Aby_lMgBHumSHqFn6SZS9q3cmh3ZMoUOG85RE,30198
@@ -15,23 +15,23 @@ cmem_cmemc/commands/resource.py,sha256=n6ri6Tu2sNUNZuNfNGpRnMQxOx9VeTFGL1OWXUKKp
15
15
  cmem_cmemc/commands/scheduler.py,sha256=L9Cl7u3Nq3UjfgRzayivxxCHq2U6ZtpqtTCsXsndnFg,8512
16
16
  cmem_cmemc/commands/store.py,sha256=PybRXCO6R84lEWR8fsTB1jZrc8CMGrWejpruPuM9lIM,6741
17
17
  cmem_cmemc/commands/user.py,sha256=0BbPoPhguSeMjLUn29Qh3kRcMbpQ75bAwDHgYWrZMyQ,12288
18
- cmem_cmemc/commands/validation.py,sha256=vCjkFyJOAJWjFedhgdOUabSopQUt7b0bZUPt2DB0Z4g,19943
18
+ cmem_cmemc/commands/validation.py,sha256=Kr5zk_9_LPoRz11LVJ_vkEhP2KrVg8Ns2aiMfiCt-cI,19984
19
19
  cmem_cmemc/commands/variable.py,sha256=IvQ-Yzg2z8Hb-ZstEuOCTMBDg0N931z_73K9xZPbdoM,11356
20
- cmem_cmemc/commands/vocabulary.py,sha256=rwPSMiJ9wrDww7Jmk20wsrbx2JqAHeXZ1_F9rpWoFjM,16679
21
- cmem_cmemc/commands/workflow.py,sha256=Uq4KaSUYuIlLQr-VyLGyhTEJOh873iSvH5rGu6KtIsY,24609
20
+ cmem_cmemc/commands/vocabulary.py,sha256=9bD_Ah6uVd4GwywIRAahSLfcqxE8yrawXIUmSMW-dMA,16693
21
+ cmem_cmemc/commands/workflow.py,sha256=msBdaNClFuSdPD8KIC9sjno8C4gunyAI7n_hev4yq2w,24632
22
22
  cmem_cmemc/commands/workspace.py,sha256=4kMstZejLdP8KIrt9p3BMw8mrrNUrdX7E8_fSI78nc4,4097
23
23
  cmem_cmemc/completion.py,sha256=amF9lWdxrWvS1CAQkEOQH1S7FpbmMniw6xjKlFOw4kY,42011
24
24
  cmem_cmemc/constants.py,sha256=s16jrvmIt42a1SrahwjON5prk8ry6MuAXHeBnuMDZyY,422
25
- cmem_cmemc/context.py,sha256=mcCY8c1JPOTB_1mWEBsxgOfRzgA69Vnfh2HN6h20hmU,17707
25
+ cmem_cmemc/context.py,sha256=tLyVsma3oCLUEwpywUwX-ZLtp1XqEYLnC_bVK4Ro0ps,17730
26
26
  cmem_cmemc/exceptions.py,sha256=SpUHdmVM8cZpSjBv6ICgr9NLr3OJ5XO42DlvjohprVo,232
27
27
  cmem_cmemc/manual_helper/__init__.py,sha256=G3Lqw2aPxo8x63Tg7L0aa5VD9BMaRzZDmhrog7IuEPg,43
28
28
  cmem_cmemc/manual_helper/graph.py,sha256=qDchHdjRRDW2oZ66by81NxhoDgNxXaAUxq2keewEiVU,3598
29
29
  cmem_cmemc/manual_helper/multi_page.py,sha256=K-S2_NubrHGynO5I_IMAanO2pZN2KETUV00wpjMqvjI,12171
30
30
  cmem_cmemc/manual_helper/single_page.py,sha256=sVSeaZmPa-Cs6dtp27MqyiO6rIrskY9BtDyeAZhBWXM,1477
31
31
  cmem_cmemc/object_list.py,sha256=QU-8JE5jvFcrUelEC4l5z7A9SInNnCRzRTS1bMw5FZc,13256
32
- cmem_cmemc/utils.py,sha256=AiZMholCLF744TaNH-k86WNQavtCQstNfiwKQ2lJ5B4,10720
33
- cmem_cmemc-24.1.2.dist-info/LICENSE,sha256=WNHhf_5RCaeuKWyq_K39vmp9F28LxKsB4SpomwSZ2L0,11357
34
- cmem_cmemc-24.1.2.dist-info/METADATA,sha256=FFvhFZZOK8AaUlRNYUouNuYF1Zd9yN8PxuQYE1dcZ2I,2619
35
- cmem_cmemc-24.1.2.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
36
- cmem_cmemc-24.1.2.dist-info/entry_points.txt,sha256=znWUTG-zgDITu6Frsd-OtNxBxj6Uo8Fa7bz6gaZYMrA,41
37
- cmem_cmemc-24.1.2.dist-info/RECORD,,
32
+ cmem_cmemc/utils.py,sha256=LPotUSjAMSP2GFg5a5zqCQcpgFeR3Txht8nTTKneO2U,11362
33
+ cmem_cmemc-24.1.3.dist-info/LICENSE,sha256=WNHhf_5RCaeuKWyq_K39vmp9F28LxKsB4SpomwSZ2L0,11357
34
+ cmem_cmemc-24.1.3.dist-info/METADATA,sha256=XapeDIfA6hhIZn5nJLJ72FKZC0OYtiyVM-GoBrWeICw,5541
35
+ cmem_cmemc-24.1.3.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
36
+ cmem_cmemc-24.1.3.dist-info/entry_points.txt,sha256=znWUTG-zgDITu6Frsd-OtNxBxj6Uo8Fa7bz6gaZYMrA,41
37
+ cmem_cmemc-24.1.3.dist-info/RECORD,,
@@ -1,68 +0,0 @@
1
- Metadata-Version: 2.1
2
- Name: cmem-cmemc
3
- Version: 24.1.2
4
- Summary: Command line client for eccenca Corporate Memory
5
- Home-page: https://eccenca.com/go/cmemc
6
- License: Apache 2.0
7
- Author: eccenca
8
- Author-email: cmempy-developer@eccenca.com
9
- Requires-Python: >=3.9,<4.0
10
- Classifier: Development Status :: 5 - Production/Stable
11
- Classifier: Intended Audience :: Developers
12
- Classifier: Intended Audience :: Science/Research
13
- Classifier: Intended Audience :: System Administrators
14
- Classifier: License :: OSI Approved :: Apache Software License
15
- Classifier: License :: Other/Proprietary License
16
- Classifier: Programming Language :: Python :: 3
17
- Classifier: Programming Language :: Python :: 3.9
18
- Classifier: Programming Language :: Python :: 3.10
19
- Classifier: Programming Language :: Python :: 3.11
20
- Classifier: Programming Language :: Python :: 3.12
21
- Classifier: Topic :: Database
22
- Classifier: Topic :: Software Development :: Testing
23
- Classifier: Topic :: Utilities
24
- Requires-Dist: beautifulsoup4 (>=4.12.2,<5.0.0)
25
- Requires-Dist: certifi (>=2023.5.7)
26
- Requires-Dist: click (>=8.1.7,<9.0.0)
27
- Requires-Dist: click-didyoumean (>=0.3.0,<0.4.0)
28
- Requires-Dist: click-help-colors (>=0.9.1,<0.10.0)
29
- Requires-Dist: cmem-cmempy (==24.1.1)
30
- Requires-Dist: configparser (>=5.3.0,<6.0.0)
31
- Requires-Dist: jinja2 (>=3.1.2,<4.0.0)
32
- Requires-Dist: natsort (>=8.3.1,<9.0.0)
33
- Requires-Dist: prometheus-client (>=0.16.0,<0.17.0)
34
- Requires-Dist: pygments (>=2.15.1,<3.0.0)
35
- Requires-Dist: pyjwt (>=2.7.0,<3.0.0)
36
- Requires-Dist: python-dateutil (>=2.8.2,<3.0.0)
37
- Requires-Dist: requests (>=2.31.0,<3.0.0)
38
- Requires-Dist: rich (>=13.7.0,<14.0.0)
39
- Requires-Dist: six (>=1.16.0,<2.0.0)
40
- Requires-Dist: timeago (>=1.0.16,<2.0.0)
41
- Requires-Dist: treelib (>=1.6.4,<2.0.0)
42
- Requires-Dist: urllib3 (>=2,<3)
43
- Description-Content-Type: text/markdown
44
-
45
- # cmemc
46
-
47
- cmemc is the official command line client for [eccenca Corporate Memory](https://documentation.eccenca.com/).
48
-
49
- ## Installation
50
-
51
- In order to install the cmemc, run:
52
-
53
- pipx install cmem-cmemc
54
-
55
- Of course you can install cmemc also with pip, but we recommend [pipx](https://pypa.github.io/pipx/) for normal desktop usage.
56
-
57
- ## Configuration and Usage
58
-
59
- cmemc is intended for System Administrators and Linked Data Expert, who wants to automate and remote control activities on eccenca Corporate Memory.
60
-
61
- The cmemc manual including basic usage pattern, configuration as well as a command reference is available at:
62
-
63
- [https://eccenca.com/go/cmemc](https://eccenca.com/go/cmemc)
64
-
65
- cmemc only works with Python 3 and refuses to work with Python 2.x.
66
- In addition to that, cmemc will warn you in case an untested Python environment is used.
67
-
68
-