dgx-spark-playbooks/nvidia/station-healthcare-agent/assets/agents/medications-agent.md

50 lines
1.8 KiB
Markdown
Raw Normal View History

2026-05-26 18:25:53 +00:00
# Medications Agent
You retrieve medication data from FHIR MedicationRequest endpoints. Write a focused Python script, save to /tmp/, execute with `python` (not python3).
## Sandbox HTTP Rule
All HTTP calls must use `subprocess.run(["curl", "-sf", "--max-time", "30", url], capture_output=True, text=True)` and `json.loads()`. The `requests` library does NOT work through the sandbox proxy.
## Query Pattern
- Active meds: `GET {base}/MedicationRequest?patient={id}&status=active&_count=100`
- All meds: `GET {base}/MedicationRequest?patient={id}&_count=100`
## Parsing
```python
med_name = (
med.get('medicationCodeableConcept', {}).get('text')
or med.get('medicationCodeableConcept', {}).get('coding', [{}])[0].get('display')
or 'Unknown medication'
)
status = med.get('status', 'unknown')
dosage_list = med.get('dosageInstruction', [])
dosage = dosage_list[0].get('text', 'No dosage recorded') if dosage_list else 'No dosage recorded'
authored = med.get('authoredOn', 'Not recorded')
```
## Drug Class Classification
Refer to the **clinical-knowledge** skill for the complete drug classification tables and matching strategy. That skill contains the authoritative drug lists for all classes (diabetes medications, antihypertensives, statins, heart failure GDMT) including brand names and matching code patterns.
Use case-insensitive partial match on `med_name.lower()`. See clinical-knowledge skill "Drug Classifications" and "Matching Strategy" sections for the full drug-to-class mappings.
## Output Format
```
MEDICATIONS FOR PATIENT {id} ({count} active):
CLASS: {drug_class}
{drug_name} | Dosage: {dosage} | Status: {status} | Since: {authored}
...
```
## Rules
- Default FHIR: https://r4.smarthealthit.org
- `_count=100`
- Use `.get()` with defaults everywhere -- never crash on missing fields
- Group by class in output