Skip to main content

a service manages storage information details

Project description

HEA Server AWS Storage Microservice

Research Informatics Shared Resource, Huntsman Cancer Institute, Salt Lake City, UT

The HEA Server AWS Storage Microservice is a service manages AWS storage information details.

Version 1.1.1

  • Performance improvements.

Version 1.1.0

  • Added support for Python 3.12.
  • Removed integration tests because they are too duplicative of the unit tests.

Version 1.0.4

  • Dependency upgrades for compatibility with heaserver-keychain 1.5.0.

Version 1.0.3

  • Fixed coroutine not awaited error.

Version 1.0.2

  • Avoid timeouts loading storage stats, which sporadically caused them not to be returned.
  • Return storage objects with read-only permissions.

Version 1.0.1

  • Resume retrieving usage summary if the user's previous attempt is still in progress.
  • Return permissions information for storage items.

Version 1

Initial release.

Runtime requirements

  • Python 3.10, 3.11, or 3.12.

Development environment

Build requirements

  • Any development environment is fine.
  • On Windows, you also will need:
  • On Mac, Xcode or the command line developer tools is required, found in the Apple Store app.
  • Python 3.10, 3.11, or 3.12: Download and install Python from https://www.python.org, and select the options to install for all users and add Python to your environment variables. The install for all users option will help keep you from accidentally installing packages into your Python installation's site-packages directory instead of to your virtualenv environment, described below.
  • Create a virtualenv environment using the python -m venv <venv_directory> command, substituting <venv_directory> with the directory name of your virtual environment. Run source <venv_directory>/bin/activate (or <venv_directory>/Scripts/activate on Windows) to activate the virtual environment. You will need to activate the virtualenv every time before starting work, or your IDE may be able to do this for you automatically. Note that PyCharm will do this for you, but you have to create a new Terminal panel after you newly configure a project with your virtualenv.
  • From the project's root directory, and using the activated virtualenv, run pip install wheel followed by pip install -r requirements_dev.txt. Do NOT run python setup.py develop. It will break your environment.

Running tests

Run tests with the pytest command from the project root directory. To improve performance, run tests in multiple processes with pytest -n auto.

Running integration tests

Trying out the APIs

This microservice has Swagger3/OpenAPI support so that you can quickly test the APIs in a web browser. Do the following:

  • Install Docker, if it is not installed already.
  • Run the run-swaggerui.py file in your terminal. This file contains some test objects that are loaded into a MongoDB Docker container.
  • Go to http://127.0.0.1:8080/docs in your web browser.

Once run-swaggerui.py is running, you can also access the APIs via curl or other tool. For example, in Windows PowerShell, execute:

Invoke-RestMethod -Uri http://localhost:8080/storage/ -Method GET -Headers @{'accept' = 'application/json'}`

In MacOS or Linux, the equivalent command is:

curl -X GET http://localhost:8080/storage/ -H 'accept: application/json'

Packaging and releasing this project

See the RELEASING.md file for details.

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

heaserver_storage-1.1.1.tar.gz (18.4 MB view details)

Uploaded Source

Built Distribution

heaserver_storage-1.1.1-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file heaserver_storage-1.1.1.tar.gz.

File metadata

  • Download URL: heaserver_storage-1.1.1.tar.gz
  • Upload date:
  • Size: 18.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for heaserver_storage-1.1.1.tar.gz
Algorithm Hash digest
SHA256 0e33126a7bc59a9544a1db13c7330f4c6b8118eb311ae8918631425085417cb0
MD5 b3f998505edcb14e54c45ebc3c404750
BLAKE2b-256 24965d36e9552d8afdaadedb04df864023c7f5adc9475b7da9f415ef9e3b646f

See more details on using hashes here.

File details

Details for the file heaserver_storage-1.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for heaserver_storage-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2d5cd79be8bb1d3278634dc96ca219ddcd88da7118bbd93b339861a7018e6e37
MD5 4093144b766934d0b11c0c167625e791
BLAKE2b-256 c584b01a136d4c847a49651659beecb5454bd2e5dca17b931744d660acc8d098

See more details on using hashes here.

Supported by

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