@aurabx/harmony-examples
v0.8.1
Published
Example pipeline configurations and templates for Harmony/Runbeam
Maintainers
Readme
Harmony Examples
Example pipeline configurations and templates for Harmony/Runbeam, demonstrating healthcare data integration patterns including FHIR, DICOM, DICOMweb, and JMIX.
What are these pipelines?
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
How to add these pipelines to your Harmony instance
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.
About Harmony and Runbeam
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.
Overview
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
Pipeline Examples
HTTP API Gateway Patterns
- 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
- http-file-upload - HTTP file upload handling with storage backend
- http-with-middleware - Complete middleware chain demonstration
Data Transformation
- 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
Healthcare 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
Specialized Healthcare Systems
- au-erequesting - Australian eRequesting FHIR integration
- cstore-filesystem - DICOM C-STORE to filesystem storage
Project Structure
├── 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 metadataGetting Started
Prerequisites
- Harmony Proxy (Rust-based runtime)
- PHP 8.3+ (for template utilities)
- Composer (for PHP dependencies)
- Node.js 18+ (if consuming as an npm package)
Installation
PHP (Composer)
# Install PHP dependencies
composer install
# Run tests
composer testNode.js (npm)
npm install @aurabx/harmony-examplesRunning an Example
Each 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.
Template Loading
Node.js
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'));PHP
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();Testing
# 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
Configuration Patterns
Networks
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 = 8080Middleware
Chain middleware for request/response processing:
[pipelines.my_pipeline]
middleware = [
"auth",
"transform",
"passthru"
]Backends
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"Contributing
Contributions welcome! Please:
- Follow existing configuration patterns
- Include comprehensive README documentation
- Add tests for new utilities
- Update
pipelines.jsonmetadata
License
MIT License - see LICENSE file for details
Support
- Documentation: Harmony Docs
- Issues: GitHub Issues
- Email: [email protected]
