Data level integration for services built atop of Modular Framework
Project description
Modular SDK
You use Modular SDK to create, configure, and manage common entities, such as:
- Customers;
- Tenants;
- TenantSettings;
- Regions;
- Applications;
- Parents;
Prerequisites
- Python 3.8+ required
Building distribution archives
- Make sure you have the latest version of PyPA’s build installed:
python3 -m pip install --upgrade build
- Run the command form the same directory where
pyptoject.toml
is located:python3 -m build
- This command should output a lot of text and once completed should generate two files in the dist directory:
dist/
modular_sdk-{version}.tar.gz
modular_sdk-{version}-py3-none-any.whl
Installation
pip install modular-sdk
Usage
To use Modular SDK, you must import, configure and indicate which service or services you're going to use:
from modular_sdk.modular import Modular
modular_sdk = Modular()
parent_service = modular_sdk.parent_service()
tenant_service = modular_sdk.tenant_service()
For now, Modular provides 3 ways of DB access. Depends on the way of database connection, different sets of env variables must be set:
- Onprem, Mongodb:
modular_service_mode
:docker
,
modular_mongo_user
:$MONGO_USER
,
modular_mongo_password
:$MONGO_PASSWORD
,
modular_mongo_url
:$MONGO_URL
,
modular_mongo_db_name
:$MONGO_DB_NAME
, - SaaS, DynamoDB (cross-account access):
modular_service_mode
:saas
# Optional
modular_assume_role_arn
:$ASSUME_ROLE_ARN
- SAAS, DynamoDB (same AWS account):
modular_service_mode
:saas
# Optional
Alternatively, you can pass these parameters (fully or partially) on initialization:
from modular_sdk.modular import Modular
modular_sdk = Modular(modular_service_mode='docker',
modular_mongo_user='MONGO_USER',
modular_mongo_password='MONGO_PASSWORD',
modular_mongo_url='MONGO_URL',
modular_mongo_db_name='DB_NAME')
# initialize some services
application_service = modular_sdk.application_service()
parent_service = modular_sdk.parent_service()
More examples
Example 1: List Maestro Customers
from modular_sdk.modular import Modular
# initializing application service
customer_service = Modular().customer_service()
# listing available customers
customers = customer_service.list()
# printing customer names
for customer in customers:
print(customer.name)
Example 2: Update Maestro Application
from modular_sdk.modular import Modular
# initializing application service
application_service = Modular().application_service()
# extracting application by id
application = application_service.get_application_by_id(
application_id="$APP_ID")
# updating application description
description_to_set = 'Updated application description'
application_service.update(application=application,
description=description_to_set)
# saving updated application
application_service.save(application=application)
Example 3: Delete Maestro Parent
from modular_sdk.modular import Modular
# initializing parent service
parent_service = Modular().parent_service()
# extracting parent by id
parent = parent_service.get_parent_by_id(parent_id="$PARENT_ID")
# deleting parent
parent_service.mark_deleted(parent=parent)
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
File details
Details for the file modular_sdk-2.2.1.tar.gz
.
File metadata
- Download URL: modular_sdk-2.2.1.tar.gz
- Upload date:
- Size: 61.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dd970aa08af29825464b990cbfff2a1a74e41d64d61d0ff82938bdc031e66de5 |
|
MD5 | b9daf77d7df0d99e5332ba3eacf91aae |
|
BLAKE2b-256 | 56632f07a97991425f6b279f2711abe9248d251caab91650f36d06e9103f495d |
File details
Details for the file modular_sdk-2.2.1-py3-none-any.whl
.
File metadata
- Download URL: modular_sdk-2.2.1-py3-none-any.whl
- Upload date:
- Size: 82.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 50894c6076635ffea7a037dc90af97f25012d97c9d12ece71b86dbd51642d56b |
|
MD5 | 568a18860cea065443a5f060e8092074 |
|
BLAKE2b-256 | acfd8180e6adf75958ce0d05a3fd413efe7b499800d1beeb8b045d81782e93d9 |