Example pipeline configurations and templates for Harmony/Runbeam, demonstrating healthcare data integration patterns including FHIR, DICOM, DICOMweb, and JMIX.
Harmony Examples contains 17 ready-to-use pipeline configurations that demonstrate Harmony's core capabilities. Each example includes a complete pipeline definition with middleware configuration, backend setup, and comprehensive documentation. Examples are organized by use case:
- Basic Patterns: HTTP proxying, echo endpoints, content-type handling
- Healthcare Integration: FHIR, DICOM, DICOMweb, JMIX
- Data Transformation: JOLT-based transformations, format conversion
- Security: Authentication, authorization, rate limiting, access control
Each pipeline example can be used as a starting point for your own deployments. To use any example:
- Copy the pipeline directory to your Harmony configuration directory
- Review the example's README.md for specific setup instructions
- Customize configuration files for your environment
- Deploy using your preferred method
For detailed instructions on adding and managing pipelines, see the Adding Pipelines guide.
Runbeam provides a template system for easily creating pipelines. Templates can contain:
- Single pipeline templates: A template that creates one pipeline configuration
- Multiple pipeline templates: A template that creates multiple related pipelines at once
To create a pipeline from a template in Runbeam:
- Navigate to the Templates section
- Select a template
- For single-pipeline templates: Click "Create Pipeline"
- For multi-pipeline templates: Click "Create Pipeline" to create individual pipelines, or "Create All Pipelines" to create them all at once
- Review the created pipelines and customize as needed
If you're creating a template with multiple related pipelines (e.g., a checkout flow with separate pipelines for checkout creation, payment processing, and order confirmation), use the files configuration in your template definition:
{
"my-multi-pipeline-template": {
"name": "Multi-Pipeline Template",
"description": "Template with multiple related pipelines",
"files": [
"my-template/pipelines/pipeline-one.toml",
"my-template/pipelines/pipeline-two.toml",
"my-template/pipelines/pipeline-three.toml"
],
"type": "pipeline",
"prerequisites": [],
"tags": []
}
}Single-pipeline templates continue to work with the file configuration:
{
"my-single-pipeline-template": {
"name": "Single Pipeline Template",
"description": "Simple single pipeline template",
"file": "my-template/pipelines/pipeline.toml",
"type": "pipeline",
"prerequisites": [],
"tags": []
}
}Harmony is a high-performance API gateway and proxy runtime built in Rust, designed for healthcare data integration, protocol translation, and advanced middleware processing.
Runbeam provides the cloud platform and ecosystem for deploying and managing Harmony instances.
This repository contains example pipelines that showcase Harmony's capabilities for:
- Healthcare Protocol Integration: FHIR, DICOM, DICOMweb, JMIX
- HTTP Proxying & API Gateway: REST API proxying with authentication and transformation
- Data Transformation: JOLT-based JSON transformations
- Security: Authentication, authorization, rate limiting, IP filtering
- Content Type Support: JSON, XML, CSV, form data, multipart, binary
- basic-echo - Simple echo service for testing request/response flow
- http-external - HTTP proxy with external backend and access control
- http-internal - HTTP proxy restricted to internal networks
- http-http - Comprehensive HTTP proxy with combined security policies
- http3-backend - HTTP to HTTP/3 backend proxy (QUIC outbound)
- http3-listener - HTTP/3 to HTTP backend proxy (QUIC inbound)
- http-file-upload - HTTP file upload handling with storage backend
- http-with-middleware - Complete middleware chain demonstration
- transform - JOLT transform middleware demonstrations
- soap-to-json - SOAP/XML to JSON conversion with JWT authentication
- content-types - Multi-content-type parsing (JSON, XML, CSV, multipart, binary)
- webhook - Webhook middleware for audit trails and event integration
- fhir - FHIR endpoint with authentication and JSON extraction
- fhir_dicom - FHIR ImagingStudy integration with DICOM backend
- dicom-scp - DICOM SCP endpoint (C-ECHO, C-FIND, C-GET, C-MOVE)
- dicom-backend - HTTP to DICOM protocol translation (SCU)
- dicomweb - DICOMweb QIDO-RS and WADO-RS to DIMSE bridge
- jmix - High-performance JMIX packaging and delivery
- au-erequesting - Australian eRequesting FHIR integration
- cstore-filesystem - DICOM C-STORE to filesystem storage
├── pipelines/ # Pipeline configurations organized by example
│ ├── basic-echo/
│ ├── fhir/
│ ├── dicom-scp/
│ └── ...
├── transforms/ # Shared JOLT transform specifications
├── src/ # PHP utilities for template loading
├── tests/ # PHPUnit test suite
├── pipelines.json # Pipeline catalog metadata
└── transforms.json # Transform catalog metadata
- Harmony Proxy (Rust-based runtime)
- PHP 8.3+ (for template utilities)
- Composer (for PHP dependencies)
- Node.js 18+ (if consuming as an npm package)
# Install PHP dependencies
composer install
# Run tests
composer testnpm install @aurabx/harmony-examplesEach pipeline example includes its own configuration and documentation:
# Example: Run the basic echo pipeline
cd pipelines/basic-echo
harmony-proxy --config config.toml
# Test it
curl http://127.0.0.1:8080/echoRefer to individual README.md files in each pipeline directory for specific instructions.
const examples = require('@aurabx/harmony-examples');
// Catalog objects
console.log(Object.keys(examples.pipelines));
// Resolve a file path inside the installed package
console.log(examples.resolvePipelinePath('basic-echo'));The TemplateLoader class provides utilities for loading pipeline and transform metadata:
use Runbeam\HarmonyExamples\TemplateLoader;
$loader = new TemplateLoader();
// Load pipeline catalog
$pipelines = $loader->loadPipelines();
// Load transform catalog
$transforms = $loader->loadTransforms();# Run all tests
composer test
# Run specific test
vendor/bin/phpunit tests/TemplateLoaderTest.phpTest coverage includes:
- Pipeline metadata validation
- JSON loading and error handling
- Category label formatting
- Required field validation
Define network listeners for HTTP, DICOM, or management APIs:
[network.default]
enable_wireguard = false
[network.default.http]
bind_address = "0.0.0.0"
bind_port = 8080Chain middleware for request/response processing:
[pipelines.my_pipeline]
middleware = [
"auth",
"transform",
"passthru"
]Configure target services:
[backends.my_backend]
service = "http"
target_ref = "my_target"
[targets.my_target]
connection.host = "api.example.com"
connection.port = 443
connection.protocol = "https"Contributions welcome! Please:
- Follow existing configuration patterns
- Include comprehensive README documentation
- Add tests for new utilities
- Update
pipelines.jsonmetadata
MIT License - see LICENSE file for details
- Documentation: Harmony Docs
- Issues: GitHub Issues
- Email: hello@aurabox.cloud