Export legacy 3Di model settings to the 3Di API V3
Project description
threedi-settings
Convert legacy model settings (V2) files to API V3 resources.
Installation
To get all functionalities this package as to offer, install with all extras
$ pip install threedi-settings[cmd, api]
Usage
Before you hit it off make sure you have the following environment variables set correctly
API_HOST=https://api.3di.live/v3.0 # no trailing slash
API_USERNAME=<your name goes here>
API_PASSWORD=<your password goes here>
Ths will give you access to the command line interface that let's you convert 3Di model settings to
3Di API resources. There are two flavors. Either use a model *.ini
file as input or the *.sqlite
file.
Both commands requires a SIMULATION_ID
argument as settings can only be defined
on a per simulation basis in the API. That gives you much more flexibility to experiment
with different configurations.
Export from SQLITE database file
To use the settings that are stored in a 3Di model sqlite database file use the following command. Please note, that
all aggregation settings stored in the database also will be exported to the API V3. You can suppress this behaviour
through the --no-aggregations
flag.
export-settings export-from-sqlite --help
Usage: export-settings export-from-sqlite [OPTIONS] SIMULATION_ID SQLITE_FILE
[SETTINGS_ROW]
"Create API V3 settings resources from legacy model sqlite file"
Arguments:
SIMULATION_ID [required]
SQLITE_FILE SQLITE model file. [required]
[SETTINGS_ROW] Specify the row id of the v2_global_settings entry you want
to export. [default: 1]
Options:
--aggregations / --no-aggregations
If the '--no-aggregations' option is not
explicitly set, the aggregation settings
found in the sqlite file will be exported,
too. [default: True]
--help Show this message and exit.
If you are unsure about the SETTINGS_ROW
argument you can quickly list the existing rows in the database by running
global-settings ls --help
Usage: global-settings ls [OPTIONS] SQLITE_FILE
Shows id and name of existing global settings entries
Arguments:
SQLITE_FILE SQLITE model file. [required]
Options:
--help Show this message and exit.
Export from ini (and aggregation) file
If you have access to the model ini file, and optionally to the corresponding aggregation file, you can use
export-settings export-from-ini --help
Usage: export-settings export-from-ini [OPTIONS] SIMULATION_ID INI_FILE
[AGGREGATION_FILE]
"Create API V3 settings resources from legacy model ini file"
Arguments:
SIMULATION_ID [required]
INI_FILE Legacy model settings ini file. [required]
[AGGREGATION_FILE] Legacy model aggregation settings file.
Options:
--help Show this message and exit.
Overview of the API V3 simulation settings fields
Most of the setting fields have been renamed in the API V3. To get an overview
of all available fields, their descriptions, suitable defaults etc use the
describe-simulation-settings
command.
describe-simulation-settings --help
Usage: describe-simulation-settings [OPTIONS]
Shows all API V3 simulation settings fields, help texts on how to use
them, suitable defaults, types etc.
Options:
--help Show this message and exit.
Internal Usage
This package is also used to retrieve simulation settings resources from the API to further convert them to an internal format that the 3Di calculation core is able to read and process.
The package therefore can be installed without the extras mentioned above or a
single extra like api
which will give you the threedi-api-client
requirement
and therefore access to the http module.
- Free software: MIT license
- Documentation: https://threedi-settings.readthedocs.io.
Credits
This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.
History
0.0.5 (2021-04-22)
-
Update readme with required env variables.
-
Fix for export edge cases.
0.0.4 (2021-04-16)
-
Added export from sqlite file command.
-
Added command that lists the global settings entries of a given sqlite file.
-
Added command that shows a description of the simulation settings API V3 fields.
0.0.3 (2021-04-07)
- Unit tests.
0.0.2 (2021-03-26)
-
Setup proper package incl readme.
-
Docstrings and code organisation.
0.0.1 (2021-03-18)
- First release on PyPI.
Project details
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
File details
Details for the file threedi_settings-0.0.5.tar.gz
.
File metadata
- Download URL: threedi_settings-0.0.5.tar.gz
- Upload date:
- Size: 882.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8b08263c6fbe78f142636bb8648729b254faa5eb0fd0eb3cf8e0d97f4edb5386 |
|
MD5 | 41df31b810aa5fb0ca4afa0894e5268a |
|
BLAKE2b-256 | f6834fb2bc1e3b0063a97f082fb372ce6cfe58576acecb86132962876ab62e40 |
File details
Details for the file threedi_settings-0.0.5-py2.py3-none-any.whl
.
File metadata
- Download URL: threedi_settings-0.0.5-py2.py3-none-any.whl
- Upload date:
- Size: 21.4 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ff9393110983ad2fafc28a5af6ff6e2bf697667f222a01dff125e830886a1776 |
|
MD5 | 792aaca6435ff046499217eb6540f2e2 |
|
BLAKE2b-256 | 336e5665c3d9030f7e7bcf20bc193a076ce419c511457806fa84d8b789c3e4db |