Skip to main content

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

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.

Credits

This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.

History

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

threedi_settings-0.0.4.tar.gz (881.5 kB view details)

Uploaded Source

Built Distribution

threedi_settings-0.0.4-py2.py3-none-any.whl (21.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file threedi_settings-0.0.4.tar.gz.

File metadata

  • Download URL: threedi_settings-0.0.4.tar.gz
  • Upload date:
  • Size: 881.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for threedi_settings-0.0.4.tar.gz
Algorithm Hash digest
SHA256 ed6e84cf77bbb0eaba85ba6837c13cf37e65bada2ad65b3b762238150cd824c3
MD5 242bccedb40af4eb7576e835b3b6f3aa
BLAKE2b-256 b7de6f0a61c4d7d1ad59483d084ab62112d5737db5cebaf8b75fff1add43ea9a

See more details on using hashes here.

File details

Details for the file threedi_settings-0.0.4-py2.py3-none-any.whl.

File metadata

  • Download URL: threedi_settings-0.0.4-py2.py3-none-any.whl
  • Upload date:
  • Size: 21.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for threedi_settings-0.0.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 2cd29589fef855cdccb875eb5241e6559c9fd250cc0818f31609093874ce0300
MD5 e366eb1becd1c74e46f382f8a31938fd
BLAKE2b-256 62f2184e56415997ac3c2ab71dd36295214dd7c34a85f51ba5d58584e8aa3712

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page