DAS api client.
Project description
DAS Python Client
A Python library and CLI for interacting with the Data Archive System (DAS) API.
Table of Contents
- Quickstart
- Installation
- CLI Usage
- Python API
- Configuration
- Examples
- Troubleshooting
- Development
- Contributing
- License
Quickstart
# Install
pip install das-cli
# Login (prompts for credentials if omitted)
das login --api-url https://your-das-instance/api
# Search entries
das search entries --attribute Name --query 'name(*core*)' --format table
# Get an entry
das entry get --code 7b.b.4c
Installation
Requirements
- Python 3.13 or higher
Install from PyPI
pip install das-cli
Install from Source
git clone https://git.nioz.nl/ict-projects/das-cli.git
cd das-cli
pip install -e .
CLI Usage
The package installs a das executable for interacting with the DAS API.
Authentication
das login --api-url https://your-das-instance/api --username your_username --password your_password
- Omit
--username/--passwordto be prompted securely.
Search
das search entries --attribute <AttributeName> --query '<SearchQuery>' \
--max-results 10 --page 1 --sort-by Name --sort-order asc --format table
Options:
--max-results <n>: Maximum results per page (default: 10)--page <num>: Page number (default: 1)--sort-by <field>: Field to sort by (default: Name)--sort-order <order>:ascordesc(default: asc)--format <format>:table,json, orcompact(default: table)--raw: Print raw API response
Get a specific entry by ID:
das search entry <ID> --format table
Help for query syntax:
das search help
Example queries:
- Name contains pattern:
name(*pattern*) - Multiple conditions:
name(*pattern*);code(*ABC*) - Date comparison:
Created at(>2023-01-01)
Entries
# Get entry by code
das entry get --code CODE
# Get entry by ID
das entry get --id ID
# Delete an entry
das entry delete CODE
# Create entries from file or data
das entry create --attribute <AttributeName> <file_path>
# Examples:
# JSON file (can contain a list of entries)
# das entry create --attribute core c:\data\entries.json
# CSV file (rows become entries)
# das entry create --attribute core c:\data\entries.csv
# Excel file (rows become entries)
# das entry create --attribute core c:\data\entries.xls
# Single entry from data string
# das entry create --attribute core --data { 'Name': 'Entry 1', ... }
# Multiple entries from data string
# das entry create --attribute core --data [{ 'Name': 'Entry 1' }, { 'Name': 'Entry 2' }]
# Update entries from file or data
das entry update --attribute <AttributeName> [--code CODE] <file_path>
# Notes:
# - For bulk updates, each entry must include a Code field
# - For single updates via --data, you can pass --code or include Code in data
# Examples:
# JSON file (each object must include Code)
# das entry update --attribute core c:\data\entries.json
# CSV file (must have Code column)
# das entry update --attribute core c:\data\entries.csv
# Excel file (must have Code column)
# das entry update --attribute core c:\data\entries.xls
# Single entry with explicit code
# das entry update --attribute core --code ENT001 --data { 'Grant Public Access': Yes }
# Single entry with Code in data
# das entry update --attribute core --data { 'Code': 'ENT001', 'Grant Public Access': Yes }
# Multiple entries from data string (each must include Code)
# das entry update --attribute core --data [{ 'Code': 'ENT001' }, { 'Code': 'ENT002' }]
Hangfire
das hangfire sync-doi ID
Attributes
# By ID
das attribute get --id 123
# By name
das attribute get --name "temperature"
# By alias
das attribute get --alias "temp"
# By table name
das attribute get --table-name "measurements"
# Converters
das attribute get-name 123
das attribute get-id "temperature"
Cache
das cache list
das cache clear "cache-name"
das cache clear-all
Configuration
# Enable SSL certificate verification (recommended)
das config ssl-verify true
# Disable SSL certificate verification (development/testing only)
das config ssl-verify false
# Show current SSL verification status
das config ssl-status
# Reset all configuration (clears credentials and settings)
das config reset --force
Python API
Basic Usage
from das.app import Das
client = Das("https://your-das-instance/api")
# Authenticate
token = client.authenticate("username", "password")
# Entries
entry = client.entries.get_entry("7b.b.4c") # by code
entry = client.entries.get_entry(id=123) # by id
client.entries.delete("7b.b.4c")
# Search
from das.managers.search_manager import SearchManager
search_manager = SearchManager()
results = search_manager.search_entries(
attribute="Cores",
query="name(*64*)",
max_results=10,
page=1,
sort_by="Name",
sort_order="asc",
)
# Downloads
from das.managers.download_manager import DownloadManager
download_manager = DownloadManager()
# Create a download request
request_data = {
'name': 'My Download Request',
'ENT001': ['FILE001', 'FILE002'],
'ENT002': [] # All files from this entry
}
request_id = download_manager.create_download_request(request_data)
# Delete a download request
download_manager.delete_download_request("6b0e68e6-00cd-43a7-9c51-d56c9c091123")
# List your download requests
my_requests = download_manager.get_my_requests()
# Hangfire
client.hangfire.sync_doi("123")
# Attributes
attribute = client.attributes.get_attribute(id=123)
attribute = client.attributes.get_attribute(name="temperature")
attribute = client.attributes.get_attribute(alias="temp")
attribute = client.attributes.get_attribute(table_name="measurements")
name = client.attributes.get_name(123)
attr_id = client.attributes.get_id("temperature")
# Cache
cache_entries = client.cache.get_all()
client.cache.clear_cache("cache-name")
client.cache.clear_all()
# SSL verification
from das.common.config import save_verify_ssl, load_verify_ssl
save_verify_ssl(True) # enable (recommended)
save_verify_ssl(False) # disable (dev/testing)
current_setting = load_verify_ssl()
Configuration
SSL certificate verification
# Enable (default)
das config ssl-verify true
# Disable (development/testing only)
das config ssl-verify false
# Check status
das config ssl-status
Downloads
# Create a download request
das download request --entry ENT001 --name "My Download Request"
# Create a request with specific files
das download request --entry ENT001 --file FILE001 --file FILE002
# Create a request with multiple entries
das download request --entry ENT001 --entry ENT002 --name "Multiple Entries"
# Create a request from JSON file
das download request --from-file request.json
# List your download requests
das download my-requests --format table
# Delete a download request
das download delete-request 6b0e68e6-00cd-43a7-9c51-d56c9c091123
Examples
# List cache and clear a specific cache
das cache list
das cache clear "attributes"
# Dump a single entry as JSON
das search entry 123 --format json
# Paginate through search results
das search entries --attribute Name --query 'name(*core*)' --max-results 50 --page 2
# List your download requests
das download my-requests --format table
# Reset all configuration
das config reset --force
Troubleshooting
- Authentication failed:
- Ensure
--api-urlpoints to the correct DAS instance base URL (often ends with/api). - Try re-running
das loginwithout passing password to be prompted.
- Ensure
- SSL certificate errors:
- Use
das config ssl-verify falsetemporarily in non-production environments. - Consider configuring your corporate CA store instead of disabling verification.
- Use
- Proxy/network issues:
- Respect environment variables
HTTP_PROXY,HTTPS_PROXY, andNO_PROXYif required.
- Respect environment variables
- Windows PowerShell quoting:
- Prefer single quotes for queries, or escape
*and;as needed (e.g.,\*).
- Prefer single quotes for queries, or escape
- Unexpected output formatting:
- Switch format with
--format jsonor--format compact.
- Switch format with
Dependencies
Runtime and development dependencies are declared in requirements.txt and pyproject.toml. Install via pip install das-cli or pip install -e . for development.
Development
Setting Up Development Environment
# Clone the repository
git clone https://git.nioz.nl/ict-projects/das-cli.git
cd das-cli
# Create and activate a virtual environment
python -m venv venv
.\venv\Scripts\activate # On Windows
source venv/bin/activate # On Unix/macOS
# Install in editable mode
pip install -e .
# (Optional) Install dev/test tooling
pip install -e .[dev]
Running Tests
# Run all tests
python run_tests.py
# Run a specific test file
python -m pytest tests/specific_test_file.py
Contributing
Contributions are welcome! Please open a Pull Request.
Report bugs or request features via the DAS CLI issue tracker.
License
MIT License
Maintainers
This project is maintained by the Royal Netherlands Institute for Sea Research (NIOZ).
Project details
Release history Release notifications | RSS feed
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 das_cli-1.0.12.tar.gz.
File metadata
- Download URL: das_cli-1.0.12.tar.gz
- Upload date:
- Size: 32.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f8aaa9595a0d9b01542655935f555ee4cd762117bb1e753d473971ea1fd9e4c1
|
|
| MD5 |
0e69629daf07e846874728138aebde5e
|
|
| BLAKE2b-256 |
df89a5ba574c045c9a85c769b0b66ef7774dc55c65f42a38ed4ea5206e7e165d
|
File details
Details for the file das_cli-1.0.12-py3-none-any.whl.
File metadata
- Download URL: das_cli-1.0.12-py3-none-any.whl
- Upload date:
- Size: 37.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
39dbe8e27ebeb6cf5046d8dbf045d109b7e2f492efcedf1abedbb3863f662a58
|
|
| MD5 |
825d38463badc20c274ff9d4f824ce1f
|
|
| BLAKE2b-256 |
ada740a9c3aa27e2975f130717a1e6eb54b5f9dc991e71f680bd5b6b0d476869
|