Swiss Army knife package for EOQ3, e.g. domain creation and destruction, CLI tools, and services
Project description
eoq3utils - Swiss Army knife package for EOQ3
Contains API, CLI and service utils that ease the working with EOQ3.
Furthermore, installing this will all EOQ3 packages at once, i.e. , eoq3 , eoq3conceptsgen , eoq3pyaccesscontroller , eoq3pyactions , eoq3pyecoreutils , eoq3pyecoremdb , eoq3pyecorempl , eoq3autobahnws , eoq3tcp.
Usage
API
Domain Factory
To create and close different kind of domains easily, CreateDomain and CleanUpDOmain can be used. The example shows how to create and clean up different types of domains with the same commands. Parameters are individual.
from eoq3utils import DOMAIN_TYPES, CreateDomain, CleanUpDomain
PARAMS = []
PARAMS.append( ParameterSet(n,{"kindOfDomain" : DOMAIN_TYPES.LOCAL ,"domainSettings": {}})); #PyecoreMdb
PARAMS.append( ParameterSet(n,{"kindOfDomain" : DOMAIN_TYPES.LOCALPROCESS ,"domainSettings": {}})); #DomainToProcessWrapper
PARAMS.append( ParameterSet(n,{"kindOfDomain" : DOMAIN_TYPES.MULTITHREAD_DOMAINPOOL ,"domainSettings": {"numberOfDomainWorkers" : 2}})); #DomainPool
PARAMS.append( ParameterSet(n,{"kindOfDomain" : DOMAIN_TYPES.MULTIPROCESS_DOMAINPOOL,"domainSettings": {"numberOfDomainWorkers" : 2}})); #DomainPool in process
PARAMS.append( ParameterSet(n,{"kindOfDomain" : DOMAIN_TYPES.TCPCLIENT ,"domainSettings": {"host": "127.0.0.1", "port": 6141, "startServer": False }})); # TCP client only
PARAMS.append( ParameterSet(n,{"kindOfDomain" : DOMAIN_TYPES.WSCLIENT ,"domainSettings": {"host": "127.0.0.1", "port": 5141, "startServer": True }})); # WS client and host (server is also cleaned up automatically with CleanUpDomain)
for p in PARAMS:
domain = CreateDomain(p.kindOfDomain, p.domainSettings)
#TODO: do something with the domain
CleanUpDomain(resource.domain)
CLI
Modules to interact with files and remote domains such as TCP and WS from the command line.
Commands
eoq3utils.cli.domaindotcpcli
Send a command to a TCP domain:
python -m eoq3utils.cli.domaindotcpcli --cmd "GET (/*M2MODELS:l0)" --tcpHost "127.0.0.1" --tcpPort 6141
eoq3utils.cli.domaindowscli
Send a command to a WebSocket domain:
python -m eoq3utils.cli.domaindowscli --cmd "GET (/*M2MODELS:l0)" --wsHost "127.0.0.1" --wsPort 5141
EOQ files
Uploading and downloading model information to EOQ files.
eoq3utils.cli.loadeoqfiletcpcli
Upload an eoq file to a TCP host:
python -m python -m eoq3utils.cli.loadeoqfiletcpcli --infile "m2model.eoq" --tcpHost "127.0.0.1" --tcpPort 6141
python -m python -m eoq3utils.cli.loadeoqfiletcpcli --infile "m1model.eoq" --tcpHost "127.0.0.1" --tcpPort 6141
eoq3utils.cli.loadeoqfilewscli
Upload eoq files to a WebSocket host:
python -m python -m eoq3utils.cli.loadeoqfilewscli --infile "m2model.eoq" --wsHost "127.0.0.1" --wsPort 6141
python -m python -m eoq3utils.cli.loadeoqfilewscli --infile "m1model.eoq" --wsHost "127.0.0.1" --wsPort 6141
eoq3utils.cli.saveeoqfiletcpcli
Download M2 model as eoq file from TCP host:
python -m eoq3utils.cli.saveeoqfiletcpcli --outfile "m2model.ecore" --rootobj "(/*MDB/*M2MODELS:0)" --tcpHost "127.0.0.1" --tcpPort 6141
The same for M1 model:
python -m eoq3utils.cli.saveeoqfiletcpcli --outfile "m1model.ecore" --rootobj "(/*MDB/*M1MODELS:0)" --tcpHost "127.0.0.1" --tcpPort 6141
eoq3utils.cli.saveeoqfilewscli
Download M2 model as eoq file from WebSocket host:
python -m eoq3utils.cli.saveeoqfilewscli --outfile "m2model.eoq" --rootobj "(/*MDB/*M2MODELS:0)" -savemetamodel 1 --host "127.0.0.1" --port 5141
The same for M1 model:
python -m eoq3utils.cli.saveeoqfilewscli --outfile "m1model.ecore" --rootobj "(/*MDB/*M1MODELS:0)" --tcpHost "127.0.0.1" --tcpPort 6141
ECORE Files
Uploading, downloading and converting ecore files.
eoq3utils.cli.ecorefiletoeoqfilecli
Eoq to ecore file conversion:
python -m eoq3utils.cli.ecorefiletoeoqfilecli --infile "m2model.ecore" --outfile "m2model.eoq"
python -m eoq3utils.cli.ecorefiletoeoqfilecli --infile "m1model.ecore" --outfile "m1model.eoq" --metafile "m2model.ecore"
eoq3utils.cli.ecorefiletoeoqfilecli
Eoq to ecore file conversion:
python -m eoq3utils.cli.eoqfiletoecorefilecli --infile "m2model.eoq" --outfile "m2model.ecore"
python -m eoq3utils.cli.eoqfiletoecorefilecli --infile "m1model.eoq" --outfile "m1model.eoq" --metafile "m2model.ecore"
eoq3utils.cli.saveecorefiletcpcli
Ecore file from TCP host downloading:
python -m eoq3utils.cli.saveecorefiletcpcli --outfile "m2model.ecore" --rootobj "(/*MDB/*M2MODELS:0)" --tcpHost "127.0.0.1" --tcpPort 6141
eoq3utils.cli.saveecorefilewscli
Ecore file from WebSocket host downloading:
python -m eoq3utils.cli.saveecorefilewscli --outfile "m1model.xmi" --rootobj "(/*MDB/*M1MODELS:0)" --metafile "m2model.ecore" -savemetamodel 1 --host "127.0.0.1" --port 5141
eoq3utils.cli.loadecorefiletcpcli
Ecore file to TCP host uploading:
python -m eoq3utils.cli.loadecorefiletcpcli --infile "m2model.ecore" --tcpHost "127.0.0.1" --tcpPort 6141
python -m eoq3utils.cli.loadecorefiletcpcli --infile "m1model.xmi" --metafile "m2model.ecore" --tcpHost "127.0.0.1" --tcpPort 6141
eoq3utils.cli.loadecorefilewscli
Ecore file to WebSocket host uploading:
python -m eoq3utils.cli.loadecorefilewscli --infile "m2model.ecore" --wsHost "127.0.0.1" --wsPort 6141
python -m eoq3utils.cli.loadecorefilewscli --infile "m1model.xmi" --metafile "m2model.ecore" --wsHost "127.0.0.1" --wsPort 6141
Services
Services to start a domain, MPL or action manager via WebSocket.
Services can be configured using ini files.
Ini files are loaded using the --config option.
Ini files can be generated using the --configout option.
eoq3utils.services.wsdomaincli
Start a server offering a domain via WebSocket:
python -m eoq3utils.services.wsdomaincli --wsHost "127.0.0.1" --wsPort 6141
Optionally, a TCP server enabled in addition::
python -m eoq3utils.services.wsdomaincli --wsHost "127.0.0.1" --wsPort 6141 --enableTcp 1 --tcpHost "127.0.0.1" --tcpPort 6141
eoq3utils.services.wsmplcli:
Start an MPL service connecting via WebSocket to a domain:
python -m eoq3utils.services.wsmplcli --workspace "./Workspace" --wsHost "127.0.0.1" --wsPort 6141
eoq3utils.services.wsactionmanagercli:
Start an action manager service connecting via WebSocket to a domain:
python -m eoq3utils.services.wsactionmanagercli --wsHost "127.0.0.1" --wsPort 6141
eoq3utils.services.wsactionhandlercli:
Start an action handler service connecting via WebSocket to a domain:
python -m eoq3utils.services.wsactionhandlercli --actionsdir "./Actions" --wsHost "127.0.0.1" --wsPort 6141
eoq3utils.services.wsservercli:
Start a WebSocket server including a selection of domain, MPL, action manager and action handler services:
python -m eoq3utils.services.wsservercli --enableDomain 1 --enableMpl 1 --enableActionManager 0 --enableActionHandler 0
The services are configured by individual ini files, which can be specified using options:
python -m eoq3utils.services.wsservercli --enableDomain 1 --domainConfig "./wsdomain.ini" --enableMpl 1 --mplConfig "./wsmpl.ini" --enableActionManager 1 --actionManagerConfig "./wsactionmanager.ini" --enableActionHandler 1 --actionHandlerConfig "./wsactionhandler.ini"
Documentation
For more information see EOQ3 documentation: https://eoq.gitlab.io/doc/eoq3/
Author
2024 Bjoern Annighoefer
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file eoq3utils-2.10.10.tar.gz.
File metadata
- Download URL: eoq3utils-2.10.10.tar.gz
- Upload date:
- Size: 27.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
92a77f1ca008668d00975f7ef109abf776aa8989454dc7396fa7d05811f4b7f5
|
|
| MD5 |
fc4382e11d1d7ff1ea699b61648a5ea1
|
|
| BLAKE2b-256 |
4341f3b29fb445fe50cfa3db47d238d5d02a6b999b7ba44160e70fac9a35cb91
|
File details
Details for the file eoq3utils-2.10.10-py3-none-any.whl.
File metadata
- Download URL: eoq3utils-2.10.10-py3-none-any.whl
- Upload date:
- Size: 48.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
365b33dce0c0a5e0fe4eecfc1e5cf2c6c26abf85f4c355d35f43b9443cdbe031
|
|
| MD5 |
13cdb13eeaf6faffc9826b6eadcdf7b7
|
|
| BLAKE2b-256 |
a1917ab12d10fef9d5130e47dfc71db9887a02455ac6f43d022b1a3fc3c08c6d
|