Feature/cds config (#857)
* Added MCP support using SSE on http://localhost:8080/sse * Reverted change that IntelliJ complains about * Pre-rework * Cleaned up the code a fair bit * Renamed * Renamed * Running spotless * Reuse FhirContext in result serialization to make MCP server work with R5 * Added support for transactions * PoC tool for CDS Hooks * some cleanup * Upgrade of model protocol * Added comments * Removed field injection ... CDS to be changed to AutoConfig eventually * Adjusted to new builder pattern * Update src/main/java/ca/uhn/fhir/rest/server/MCPBridge.java Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * A bit of restructuring * More rework * Removing (suspected unnecessary) formatting * Add more example doc * Added a smoke- / passthrough-test * Applied spotless * Update src/main/java/ca/uhn/fhir/jpa/starter/mcp/RequestBuilder.java Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/main/java/ca/uhn/fhir/jpa/starter/mcp/RequestBuilder.java Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/main/java/ca/uhn/fhir/jpa/starter/mcp/ToolFactory.java Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/main/java/ca/uhn/fhir/rest/server/McpCdsBridge.java Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/main/java/ca/uhn/fhir/rest/server/McpCdsBridge.java Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Formatting * Added some documentation * spotless cares about MD? * Reverting back to default values * minor refinements * Fixed CDS hooks configuration * Fixed some wirings * Readded missing elements * getting closer to get test running again ... * applying review * Readded exclude * Bumped spring-ai deps * added agents file * Updated according to review --------- Co-authored-by: Ádám Z. Kövér <adamzkover@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
This commit is contained in:
committed by
GitHub
parent
d29b9f80af
commit
d76662c9e9
38
AGENTS.md
Normal file
38
AGENTS.md
Normal file
@@ -0,0 +1,38 @@
|
||||
# Repository Guidelines
|
||||
|
||||
## Project Structure & Module Organization
|
||||
- `src/main/java`: Spring Boot entry point `ca.uhn.fhir.jpa.starter.Application`, resource providers, config.
|
||||
- `src/main/resources`: Application YAML, search parameter bundles, capability statements packaged with the WAR.
|
||||
- `src/main/webapp`: HAPI Testpage overlay shipped for the default UI.
|
||||
- `src/test/java` & `src/test/resources`: JUnit 5 suites (interceptors, MCP, MDM) plus matching fixtures grouped by FHIR version.
|
||||
- `charts/`, `docker-compose.yml`, `configs/`: Deployment templates for Helm, Docker, and Tomcat/server overrides.
|
||||
- `Dockerfile`, `build-docker-image.sh`: Reference container build scripts used by CI/CD.
|
||||
|
||||
## Build, Test, and Development Commands
|
||||
- `mvn clean install`: Compile, run Surefire + Failsafe, and emit `target/ROOT.war`.
|
||||
- `mvn spring-boot:run -Pboot`: Start the server on port 8080 with hot reload-friendly Boot profile.
|
||||
- `mvn clean package spring-boot:repackage -Pboot && java -jar target/ROOT.war`: Build and exercise the bootable WAR.
|
||||
- `docker-compose up -d --build`: Launch JPAServer + PostgreSQL using the local Dockerfile.
|
||||
- `docker run -p 8080:8080 hapiproject/hapi:latest`: Compare against the upstream binary distribution.
|
||||
|
||||
## Coding Style & Naming Conventions
|
||||
- Target Java 17, four-space indents, alphabetized imports, no wildcards.
|
||||
- Keep code under `ca.uhn.fhir.jpa.starter` and mirror packages in tests.
|
||||
- Prefer descriptive class suffixes (`*Provider`, `*Service`, `*Config`) and constructor injection with `final` collaborators.
|
||||
- YAML keys stay kebab-case; JSON fixtures use lower_snake_case filenames.
|
||||
|
||||
## Testing Guidelines
|
||||
- `mvn test`: Runs JUnit Jupiter unit suites such as `CustomBeanTest` and `ParallelUpdatesVersionConflictTest`.
|
||||
- `mvn verify`: Adds integration coverage through Failsafe with the default H2 datasource; if you pivot to PostgreSQL, run `mvn install -DskipTests` until fixtures are updated.
|
||||
- Store integration suites as `*IT.java` so Failsafe detects them and colocate datasets in `src/test/resources`.
|
||||
- Leverage Testcontainers and HAPI FHIR test utilities already declared in `pom.xml`.
|
||||
|
||||
## Commit & Pull Request Guidelines
|
||||
- Follow repository precedent: imperative summary, optional scope (`Feature/mcp`), and linked issue `(#123)` when applicable.
|
||||
- Keep commits narrowly scoped and include config or fixture updates with the code they support.
|
||||
- PRs should describe runtime impact (profiles, ports, env vars), reference issues, and include UI screenshots when behaviour changes.
|
||||
- Run `mvn verify` or the relevant Docker workflow before review; note any skipped checks and how to reproduce the result.
|
||||
|
||||
## Security & Configuration Tips
|
||||
- Do not commit secrets; stash overrides under `configs/` and explain required env vars in the PR.
|
||||
- When enabling external services, update `src/main/resources/application.yaml` plus sample overrides and mention connection expectations for reviewers.
|
||||
Reference in New Issue
Block a user