Skip to main content

A client library for IoT projects in the RCER initiative

Project description

SAVIIA Library

Sistema de Administración y Visualización de Información para la Investigación y Análisis

GitHub release (latest by date)

Installation

This library is designed for use with the SAVIIA Home Assistant Integration. It provides an API to retrieve files from a THIES Data Logger via an FTP server and upload them to a Microsoft SharePoint folder using the SharePoint REST API.

pip install saviialib

Usage

Initialize the EPii API Client

To start using the library, you need to create an EpiiAPI client instance:

from saviialib import EpiiAPI

api_client = EpiiAPI()

Update THIES Data Logger Files

The library provides a method to synchronize THIES Data Logger files with the RCER SharePoint client. This method updates the folder containing binary files with meteorological data:

from saviialib import EpiiUpdateThiesConfig
import asyncio

async def update_thies_data():
    config = EpiiUpdateThiesConfig(
        ftp_port=FTP_PORT,
        ftp_host=FTP_HOST,
        ftp_user=FTP_USER,
        ftp_password=FTP_PASSWORD,
        sharepoint_client_id=SHAREPOINT_CLIENT_ID,
        sharepoint_client_secret=SHAREPOINT_CLIENT_SECRET,
        sharepoint_tenant_id=SHAREPOINT_TENANT_ID,
        sharepoint_tenant_name=SHAREPOINT_TENANT_NAME,
        sharepoint_site_name=SHAREPOINT_SITE_NAME
    )
    response = await api_client.update_thies_data(config)
    return response

asyncio.run(update_thies_data())

Notes:

  • Store sensitive data like FTP_PASSWORD, FTP_USER, and SharePoint credentials securely. Use environment variables or a secrets management tool to avoid hardcoding sensitive information in your codebase.

Development

This project includes a Makefile to simplify common tasks. Below are the available commands:

Install Basic Dependencies

To install the basic dependencies required for the project, run the following command:

make install-deps

This will ensure that all necessary libraries and tools are installed for the project to function properly.

Install Development Requirements

For setting up a development environment with additional tools and libraries, execute:

make dev

This command installs all the dependencies needed for development, including testing and linting tools.

Run Tests

To verify that the code is functioning as expected, you can run the test suite using:

make test

This will execute all the tests in the project and provide a summary of the results.

Lint the Code

To ensure that the code adheres to the project's style guidelines and is free of common errors, run:

make lint

This command checks the codebase for linting issues and outputs any problems that need to be addressed.

Contributing

If you're interested in contributing to this project, please follow the contributing guidelines. Contributions are welcome and appreciated!

Interested in contributing? Check out the contributing guidelines. Please note that this project is released with a Code of Conduct. By contributing to this project, you agree to abide by its terms.

License

saviialib was created by Pedro Pablo Zavala Tejos. It is licensed under the terms of the MIT license.

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

saviialib-0.6.2.tar.gz (11.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

saviialib-0.6.2-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file saviialib-0.6.2.tar.gz.

File metadata

  • Download URL: saviialib-0.6.2.tar.gz
  • Upload date:
  • Size: 11.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.8

File hashes

Hashes for saviialib-0.6.2.tar.gz
Algorithm Hash digest
SHA256 e6a5254e942b4c980a2567bf69809683f1ddf6af451df0bfd802c98b023e6135
MD5 66a1c140af95e2bd8c2e98a0f257eae7
BLAKE2b-256 9fa58fee565286e5fc38756b2633cf417a89757f13e49cdc83b223086b6f4cfc

See more details on using hashes here.

File details

Details for the file saviialib-0.6.2-py3-none-any.whl.

File metadata

  • Download URL: saviialib-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 20.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.8

File hashes

Hashes for saviialib-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 13ceb387d1497c3c3d4894baf253a8fd3018cc54c7f55cc75a18137c0ac7fcf8
MD5 9bd7e9c860f6e8be8a3ec83f7b1b5b0c
BLAKE2b-256 906a506929704b1c9a45b4ada11e6ee8f1159af7b757734a467c9491e5ca450a

See more details on using hashes here.

Supported by

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