Skip to content

linkorb/data-router

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DataRouter

Simple library to route data based on nested routing rules

Use-cases:

  • Advanced alert/support routing based on schedules, escalation, priorities, etc
  • Q/A routing
  • Self-service
  • On-call scheduling

Concepts

Using the DataRouter library you create a nested tree structure of Routes.

Every Route has a name, expression (for matching), and optionally child routes and output data.

The expressions are evaluated hierarchically using the Symfony Expression Language Component allowing for arbitrarily complex routing rules.

You can pass in your own "ExpressionLanguage" instance to support your own custom functions to enrich your expressions.

Example

Check example/example.php for a simple example for a common usage scenario:

  1. Loading routes from a YAML config file (included test-routes.yaml)
  2. Instantiating a custom ExpressionLanguage instance with a custom method
  3. Instantiating a Router
  4. Routing / output
  5. Logging / debugging
php example/example.php

License

MIT. Please refer to the license file for details.

Brought to you by the LinkORB Engineering team


Check out our other projects at linkorb.com/engineering.

Btw, we're hiring!

About

DataRouter: library for routing arbitrary data based on hierarchical rules

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages