cerk_config_loader_file 0.2.0

This is a package for CERK. CERK is an open source CloudEvents Router written in Rust with a MicroKernel architecture.
Documentation
# cerk_config_loader_file 0.1.0

[![Build status](https://badge.buildkite.com/4494e29d5f2c47e3fe998af46dff78a447800a76a68024e392.svg?branch=master)](https://buildkite.com/ce-rust/cerk)
[![Crates.io](https://img.shields.io/crates/v/cerk)](https://docs.rs/cerk_config_loader_file/*/cerk_config_loader_file/)
[![Docs status](https://docs.rs/cerk/badge.svg)](https://docs.rs/cerk_config_loader_file/)


This is a package for [CERK](https://github.com/ce-rust/cerk).
CERK is an open source [CloudEvents](https://github.com/cloudevents/spec) Router written in Rust with a MicroKernel architecture.

## Introduction

CERK lets you route your [CloudEvents](https://github.com/cloudevents/spec) between different different ports.
Ports are transport layer bindings over which CloudEvents can be exchanged.
It is built with modularity and portability in mind.

## Components

CERK comes with a couple of prefabricated components, but implementing custom components is easy.

A good overview is provided on [GitHub](https://github.com/ce-rust/cerk/).

## This Component: File Based Config Loader

This port loads configurations from a json file.

The file path could be set with the env variable `CONFIG_PATH`, default is `./config.json`.

### Example Config

```json
{
  "routing_rules": [
    "dummy-logger-output"
  ],
  "ports": {
    "ampq-input": {
      "uri": "amqp://127.0.0.1:5672/%2f",
      "consume_channels": [
        {
          "name": "test",
          "ensure_queue": true,
          "bind_to_exchange": "test"
        }
      ],
      "publish_channels": [
        {
          "name": "test",
          "ensure_exchange": true
        }
      ]
    },
    "dummy-logger-output": null
  }
}
```

### Examples

 * [AMQP to Printer]https://github.com/ce-rust/cerk/tree/master/examples/src/amqp_to_printer/


## Update Readme

The original readme text is a Rust doc comment in the [lib.rs](./src/lib.rs) file

1. `cargo install cargo-readme`
2. `cargo readme  > README.md`

## License

Apache-2.0