dmax
Project description
An (incomplete) alternative API client for data management systems at the Advanced Photon Source that supports both synchronous and asynchronous API calls.
Why dmax?
The aps-dm-api package is available for accessing the various APIs in python. Compared to aps-dm-api, dmax is:
Awaitable - dmax has both a block and asynchronous client that share the same logic
Explicit - parameters can be passed to a client rather than relying primarily on environmental variables.
On PyPI - aps-dm-api can only be installed from conda-forge.
While we hope that dmax is useful, it is not intended as a complete replacement for aps-dm-api. Features are added only as needed.
Installation
The following will download the package and load it into the python environment.
pip install dmax
Usage
The main interface for dmax is the dmax.Client class, or its asynchronous counterpart dmax.AsyncClient.
dmax can be used either by as a stand-alone library, where the data management API parameters are passed in explicitly, or embedded in an existing data-management environment, where the API connection parameters are defined in environmental variables.
Stand-alone
The client is given the login credentials, along with the station name and any API URIs that it needs to connect.
import dmax
client = dmax.Client(
username="spam",
password="secret",
station_name="255IDZ",
scheduling_uri: str = "https://example.com:11337",
data_storage_uri: str = "https://example.com:22237",
processing_uri: str = "https://example.com:55536",
)
proposals = client.proposals(cycle="2026-3")
experiments = client.experiments()
experiment = client.experiment(name="cabana-2026-3")
If the URI’s are omitted, the client will attempt to guess sensible defaults from the station name, for example station_name=”255IDZ” will produce URIs like https://s255idzdm.xray.aps.anl.gov:55536.
Embedded in a DM Environment
The APS data management system uses an extensive set of environmental variables to handle the API parameters. If any parameters or not provided to the client, environmental variables will be used if available:
import dmax
client = dmax.Client()
esafs = client.esafs(year=2026)
Running the Tests
uv run --dev pytest
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dmax-0.0.4.tar.gz.
File metadata
- Download URL: dmax-0.0.4.tar.gz
- Upload date:
- Size: 113.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
34d030dbde0bda1074d44deafa2dec3b4761e5f63b77d9a380b28e91b0446801
|
|
| MD5 |
c9e87891e4334f6d4e3c6d6572340630
|
|
| BLAKE2b-256 |
ee6a038ccdd105dfb132cb439d6c04030ab62d87f5dd8b9aa4bbcd34ca89f45f
|
File details
Details for the file dmax-0.0.4-py3-none-any.whl.
File metadata
- Download URL: dmax-0.0.4-py3-none-any.whl
- Upload date:
- Size: 13.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7770838fbd7cd996ba9362205c0aa6fdaaa9caadfe2e6fccea2aed50b7fab05d
|
|
| MD5 |
2ff3ed5f08ca40151a5143595de4b9e4
|
|
| BLAKE2b-256 |
2119147ddfae20eaf3f82cf4d4f3c3a2f7c7d22e8f6eef63bbf697c54a9fd203
|