Skip to content

th2-net/th2-sim-template

Repository files navigation

th2 sim template

This project demonstrates how to organize your project with custom rules for th2-sim.

This project implemented gRPC API, which is described in th2-grpc-sim-template

Fork this project and follow instructions to start your custom project

How to use

  1. Fork th2-grpc-sim-template project and edit proto files if needed.
  2. Edit dependencies in build.gradle file to include all the required libraries with generated gRPC sources.
  3. Edit rootProject.name variable in settings.gradle file.
  4. Edit services classes and their methods
  5. Edit services file in META-INF if needed

Rules

Rules consists of two methods:

  1. checkTriggered - it is used for checking if rule will generate the messages
  2. handle or handleTriggered - it is used for generating outgoing messages

Rules can also use arguments. In order to do this you should use constructor in your custom class.

The rules are divided into 3 types and the only difference between them is the login method for checkTriggered:

  1. Compare rule (Example)
  2. Predicate rule (Example)
  3. Abstract rule (Example)

Compare rule

This type contains the most simple logic for check. The rules of this type will be triggered only if the message type and the fields from the incoming message are equals to the values that we had set in the rule.

Predicate rule

This type contains the most flexible check conditions. The rules of this type will only be triggered if the message type and the message fields logical functions, which are set in rule, return a true value. The logical functions of the fields in this rule are isolated between each other.

Abstract rule

This type contains the most flexible check conditions. The rules of this type will be triggered if your custom logic in method checkTriggered will return a value equal to true.

Service

If you want to add the possibility of creating a rule via gRPC you should edit th2-grpc-sim-template and class TemplateService. For adding a rule to simulator you can use the utility method ServiceUtils.addRule or the method from Simulator class with the name addRule. On the gRPC request you should return RuleID.

Work example

On the picture is presented an example of simulator work with the rule TemplateFixRule enabled. This rule sends an ExecutionReport message if the income message is a NewOrderSingle. If the income message is wrong (not NewOrderSingle), the rule in simulator will not generate an outgoing message. If the income message is correct (NewOrderSingle), the rule will generate one ExecutionReport.

picture

Release notes

3.7.0

  • Update th2-common to version 3.44.0
  • Update bom to version 4.1.0
  • Update kotlin.jvm to 1.6.21

3.6.0

  • Updated th2-sim to version 5.2.3
  • Update th2-common to version 3.41.1
  • Update bom to version 4.0.2

3.5.1

  • Add tests examples

3.4.0

  • Add Gradle plugin for proto descriptors creation

3.2.2

  • Update libraries version

3.2.0

  • Update th2-sim to version 3.7.0
    • Added IRuleContext.removeRule() method which allows a rule to remove itself
    • Added ability to schedule execution of arbitrary actions via IRuleContext.execute methods
  • Update th2-common to version 3.19.0
    • Update th2-grpc-common and th2-grpc-service-generator versions to 3.2.0 and 3.1.12 respectively
    • Disable waiting for connection recovery when closing the SubscribeMonitor
    • Change the way channels are stored (they mapped to the pin instead of the thread). It might increase the average number of channels used by the box, but it also limits the max number of channels to the number of pins
    • Added the property workers, which changes the count of gRPC server's threads
    • Added session alias and direction labels to incoming metrics
    • Rework logging for incoming and outgoing messages
    • Resets embedded log4j configuration before configuring it from a file
    • Fixed a bug with message filtering by message_type