Skip to main content

A library that contains common functionality used in services of GHGA

Project description

tests PyPI version shields.io PyPI pyversions Coverage Status

ghga-service-commons

This Python library serves as a collection of common utilities used by the microservices developed at German Human Genome-Phenome Archive (GHGA).

It collects boilerplate code for common functionalities such as API server setup, authentication and authorization.

This library is primarily intended for internal use at GHGA and should not be seen as a general-purpose microservice chassis. However, if this library matches your specific needs as well, please feel free to use it. It is open source.

Installation

This package is available at PyPI: https://pypi.org/project/ghga_service_commons

You can install it from there using:

pip install ghga_service_commons

Thereby, you may specify following extra(s):

  • api: dependencies needed to use the API server functionalities
  • auth: dependencies needed for dealing with authentication and authorization

Development

For setting up the development environment, we rely on the devcontainer feature of vscode.

To use it, you have to have Docker as well as vscode with its "Remote - Containers" extension (ms-vscode-remote.remote-containers) extension installed. Then, you just have to open this repo in vscode and run the command Remote-Containers: Reopen in Container from the vscode "Command Palette".

This will give you a full-fledged, pre-configured development environment including:

  • infrastructural dependencies of the service (databases, etc.)
  • all relevant vscode extensions pre-installed
  • pre-configured linting and auto-formatting
  • a pre-configured debugger
  • automatic license-header insertion

Moreover, inside the devcontainer, there is following convenience command available (please type it in the integrated terminal of vscode):

  • dev_install - install the lib with all development dependencies and pre-commit hooks (please run that if you are starting the devcontainer for the first time or if added any python dependencies to the ./setup.cfg)

If you prefer not to use vscode, you could get a similar setup (without the editor specific features) by running the following commands:

# Execute in the repo's root dir:
cd ./.devcontainer

# build and run the environment with docker-compose
docker build -t ghga-service-commons .
docker run -it ghga-service-commons /bin/bash

License

This repository is free to use and modify according to the Apache 2.0 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

ghga_service_commons-0.1.0.tar.gz (17.2 kB view details)

Uploaded Source

Built Distribution

ghga_service_commons-0.1.0-py3-none-any.whl (29.0 kB view details)

Uploaded Python 3

File details

Details for the file ghga_service_commons-0.1.0.tar.gz.

File metadata

  • Download URL: ghga_service_commons-0.1.0.tar.gz
  • Upload date:
  • Size: 17.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for ghga_service_commons-0.1.0.tar.gz
Algorithm Hash digest
SHA256 e3c4a62730c3ef9b2806d9b0cda7f3fb326eab82069f1ee45a500ad6c25d2fdf
MD5 17898b284f43153a3dce79f11b595ebf
BLAKE2b-256 6b009b25710c5e72f0d90b8fbea2cb1e37d6031cc8720a950b1eaf75165fd8ec

See more details on using hashes here.

File details

Details for the file ghga_service_commons-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ghga_service_commons-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a15b7bb27a36c85b8fa8a7aaddb4cd5beb9c0cc395a7eefebd6f6210cca21313
MD5 cb586f3feebeab5f99eb849dd413d3f1
BLAKE2b-256 367eebe3de73e66577a28f273b6c94b1d3c8e493e8e965ff2c36171876237733

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