Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
$ pip install osiris-sdk
The SDK requires Python 3.
To get started with the SDK you will need the URL to the Osiris-ingress API and the tenant ID for the organisation who runs the API. Furthermore, you will need to register your application withing the tenant using Azure App Registration. You will also need to create a dataset in the DataPlatform.
An App Registration with credentials are required to upload data to the DataPlatform through the Osiris Ingress API.
Login with the Azure CLI with the following command:
az login
You can also specify a username and password with:
az login -u <username> -p <password>
The App Registration serves as a registration of trust for your application (or data publishing service) towards the Microsoft Identity Platform (allowing authentication).
This is the "identity" of your application. Note that an App Registration is globally unique.
Run the following command:
az ad app create --display-name "<YOUR APP NAME>"
The application name should be descriptive correlate to the application/service you intend to upload data with.
Take note of the appId
GUID in the returned object.
The Service Principal and credentials are what enables authorization to the Data Platform.
Create a Service Principal using the appId
GUID from when creating the App Registration:
az ad sp create --id "<appID>"
Then create a credential for the App Registration:
az ad app credential reset --id "<appID>"
NOTE: Save the output somewhere secure. The credentials you receive are required to authenticate with the Osiris Ingress API.
The application must be granted read- and write-access to the dataset on the Data Platform.
Add the application you created earlier, using the <YOUR APP NAME>
name, to the read- and write-access lists.
Here are some simple examples on how to use the SDK.
The following is a simple example which shows how you can upload files using the Osiris SDK:
from osiris.apis.ingress import Ingress
from osiris.core.azure_client_authorization import ClientAuthorization
client_auth = ClientAuthorization(tenant_id=<TENANT_ID>,
client_id=<CLIENT_ID>,
client_secret=<CLIENT_SECRET>)
ingress = Ingress(client_auth=client_auth,
ingress_url=<INGRESS_URL>,
dataset_guid=<DATASET_GUID>)
file = open('test_file.json', 'rb')
# Without schema validation and a JSON file
ingress.upload_json_file(file, False)
# With schema validation and a JSON file
ingress.upload_json_file(file, True)
# With schema validation, a JSON file and event time
ingress.upload_json_file_event_time(file, '2021-01-01', True)
# Arbitrary file
ingress.upload_file(file)
# Save state file
with open('state.json', 'r') as state:
ingress.save_state(state)
# Retrieve state
state = ingress.retrieve_state()
The following is a simple example which shows how you can download files using the Osiris SDK:
from osiris.apis.egress import Egress
from osiris.core.azure_client_authorization import ClientAuthorization
client_auth = ClientAuthorization(tenant_id=<TENANT_ID>,
client_id=<CLIENT_ID>,
client_secret=<CLIENT_SECRET>)
egress = Egress(client_auth=client_auth,
egress_url=<EGRESS_URL>,
dataset_guid=<DATASET_GUID>)
# JSON file
content_json = egress.download_json_file('2021-01-01', '2021-01-03')
The full list of methods available in Egress can be found in the source code.
The following is a simple example which shows how you can create a new ingress adapter.
import json
from osiris.adapters.ingress_adapter import IngressAdapter
class MyAdapter(IngressAdapter):
def retrieve_data(self) -> bytes:
return json.dumps('Hello World').encode('UTF-8')
def main():
client_auth = ClientAuthorization(tenant_id=<TENANT_ID>,
client_id=<CLIENT_ID>,
client_secret=<CLIENT_SECRET>)
adapter = MyAdapter(client_auth=client_auth,
ingress_url=<INGRESS_URL>,
dataset_guid=<DATASET_GUID>)
# as json data
adapter.upload_json_data(schema_validate=False)
# or as arbitrary data
adapter.upload_data()
# or json data with a path corresponding to the given event time
adapter.upload_json_data_event_time(schema_validate=False)
# or data with a path corresponding to the given event time
adapter.upload_data_event_time()
if __name__ == '__main__':
main()
FAQs
Python SDK for Osiris (Energinet DataPlatform).
We found that osiris-sdk demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.