Skip to main content

A service to read files on dls_sw from a blueapi container

Project description

Frontend CI Backend CI Coverage PyPI License

DAQ Config Server

A service to read files on Diamond's filesystem from a BlueAPI container. Currently this service is only able to read files on /dls_sw/. Writing to configuration files will come in a future release.

Source https://github.com/DiamondLightSource/daq-config-server
Docker docker run ghcr.io/DiamondLightSource/daq-config-server:latest
Releases https://github.com/DiamondLightSource/daq-config-server/releases
Documentation https://DiamondLightSource.github.io/daq-config-server

Here is a minimal example to read a file from the centrally hosted service after installing this package

from daq_config_server import ConfigClient

config_client = ConfigClient("https://daq-config.diamond.ac.uk")

file_contents = config_client.get_file_contents({ABSOLUTE_PATH_TO_CONFIG_FILE}, desired_return_type=str)

The output will come out as a raw string - you should format it as required in your own code. You may also request that the file contents is returned as a dict or in bytes - this will raise an http exception if the file cannot be converted to that type. To be able to read a file, you must first add it to the whitelist.

Testing

To run unit tests, type tox -e unit_tests from within the dev container

There is a convenient script in ./deployment/build_and_push.sh which can be used to easily build and run the container locally for testing, and optionally push the container to a repository. In general we should rely on the CI to be pushing new containers - however it is sometimes useful to push a development image to a private repo for development or debugging.

To run local system tests, start a local container by running ./deployment/build_and_push.sh -r -b. Then, in the dev container, forward port 8555. There are instructions on port forwarding within vscode here. Next, in a terminal in the devcontainer, run tox -e system_tests_local from the daq-config-server directory.

To run a test deployment on argus, log in to argus in your namespace and run:

helm install daq-config ./helmchart/ --values dev-values.yaml

followed by:

kubectl port-forward service/daq-config-server-svc 8555

after which you should be able to access the API on http://localhost:8555/docs

See https://DiamondLightSource.github.io/daq-config-server for more detailed documentation.

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

daq_config_server-1.3.2.tar.gz (231.1 kB view details)

Uploaded Source

Built Distribution

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

daq_config_server-1.3.2-py3-none-any.whl (32.2 kB view details)

Uploaded Python 3

File details

Details for the file daq_config_server-1.3.2.tar.gz.

File metadata

  • Download URL: daq_config_server-1.3.2.tar.gz
  • Upload date:
  • Size: 231.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for daq_config_server-1.3.2.tar.gz
Algorithm Hash digest
SHA256 a91920166eb5e633072acbb75a1a34ce829582aa77db714565ff53012260de5d
MD5 37a528bec3a2ea3a0674fefb207d4366
BLAKE2b-256 61dc0d6496a0ae1e4c88ec5fb964a506ea7676bd0f10800becbacc955a2f4aff

See more details on using hashes here.

File details

Details for the file daq_config_server-1.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for daq_config_server-1.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 bcc87dcc451d746ff4effcd708b440d41b7f843ee84e0c3fb0642a5054c338cb
MD5 ca36a88f6f6e568ff36f96c5a708e97e
BLAKE2b-256 6050cb646d19a7a266a9ae520024ae31ef976d6011901031c439d7b76bfc5a5a

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