Skip to main content

The HEA settings service.

Project description

HEA Server Settings Microservice

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

The HEA Server Settings Microservice manages user and system settings.

Version 1.1.0

  • Make settings show based on permissions.
  • Make Credentials settings object expect CredentialsView actual objects.
  • Remove integration tests because they are duplicative.

Version 1

  • Initial release.

Runtime requirements

  • Python 3.10 or 3.11

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 or 3.11: Download and install Python 3.10 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/components/ -Method GET -Headers @{'accept' = 'application/json'}`

In MacOS or Linux, the equivalent command is:

curl -X GET http://localhost:8080/components/ -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_settings-1.1.0.tar.gz (20.7 kB view details)

Uploaded Source

Built Distribution

heaserver_settings-1.1.0-py3-none-any.whl (12.0 kB view details)

Uploaded Python 3

File details

Details for the file heaserver_settings-1.1.0.tar.gz.

File metadata

  • Download URL: heaserver_settings-1.1.0.tar.gz
  • Upload date:
  • Size: 20.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.6

File hashes

Hashes for heaserver_settings-1.1.0.tar.gz
Algorithm Hash digest
SHA256 579479582bd6a19b25400a6a24d19010956e8e6f1c116b1905300b865dec18e4
MD5 9987e938eb2cf60eda107c437b4dcd22
BLAKE2b-256 d7224ac557345b3b5cdca8205f75d0806bcc88ec131c72d8c6a4b20feff6c75d

See more details on using hashes here.

File details

Details for the file heaserver_settings-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for heaserver_settings-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 695705e94cf9ac480a61b698415c41b028a9d63f6fe754e1386f56beec6439fe
MD5 0c33cd07edd1323ac7b8b2c9f7799975
BLAKE2b-256 718419f8974b9a7c507d9d21f79e86fcf233d036d31909bef93952784e8b8468

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