Skip to content

Latest commit

 

History

History
170 lines (108 loc) · 5.83 KB

File metadata and controls

170 lines (108 loc) · 5.83 KB

Customer Movement Decision Service

This project is have-fun-with kind of experiment intended to familiarize myself with Kogito.

The service developed here is a part of imaginary scenario:

Let's assume that there is a retail store that has customer tracking ability (through beacons and mobile app used by the customer). The app informs the system about current customer location (with MQTT messages). Based on that data, we want to be able to determine, if a given customer is interested in any particular kind of goods (in our case: is spending significant time in a given Department.)

Service overview

The decision process begins with a MQTT message. The message reflects a customer movement around a store.

Then business rules (DRL) are used to:

  • identify the department that the customers is currently in
  • check how much time he spent in that department (more accurately: how many consequent "moves" he made in that area); if he spent some desired time there, the service rules out that he is focused in a given area (so, we could probably send him a promo coupon, send notification to the staff to help him out, etc.)

When a focused customer is identified, a proper Kafka message is sent.

Local development/testing

Prerequisites

You will need:

  • Java 11+ installed
  • Environment variable JAVA_HOME set accordingly
  • Maven 3.6.2+ installed

The service assumes that Kafka and MQTT brokers are up and running. It assumes they are accessible on localhost and use default ports. If you want to supply different settings, use application.properties

Compile and Run in Local Dev Mode

mvn clean compile quarkus:dev

NOTE: With dev mode of Quarkus you can take advantage of hot reload for business assets like processes, rules, decision tables and java code. No need to redeploy or restart your running application.

Use the application

The service listens to 'customer/move' MQTT topic. In order to start the decision process (is given a customer focused?) one should publish a message to that topic.

In case that the decision process finds out that the customer is focused, the result is published to Kafka topic (' CUSTOMER_FOCUS' by default). In order to verify that, one could use kafka-consumer CLI to see the incoming messages.

Changing configuration

MQTT and Kafka brokers addresses and topics are defined in application.properties.

org.demo.rsotf.CustomerUnit class holds definition of the departments (symbols, area on the map) and the number of consequent steps (that customer makes in the same department) to decide, he is focused there.

Change the following fragments according to your needs:

private int requiredNumberOfSteps=3;
private static List<Department> getDepartments(){
        List<Department> departments=new LinkedList<>();
        departments.add(new Department("Women",new Area(444,443,666,879),""));
        departments.add(new Department("Boys",new Area(672,443,992,658),""));
        departments.add(new Department("Girls",new Area(998,443,1317,658),""));
        departments.add(new Department("Men",new Area(672,664,1317,879),""));
        departments.add(new Department("Sports",new Area(614,984,1186,1292),""));
        return departments;
        }

(The config should be externalized and available through a config file/environment variables...)

Additional info

Testing with MQTT broker in docker

Quick way to set up a simple MQTT broker is to use Docker containers:

docker run -d --rm -p 1883:1883 --name mosquitto eclipse-mosquitto mosquitto -c /mosquitto-no-auth.conf

To publish to a topic:

docker exec mosquitto mosquitto_pub -h 127.0.0.1 -t test -m "test message"

To subscribe to a topic:

docker exec mosquitto mosquitto_sub -h 127.0.0.1 -t "test"

For this particular use case, the following command sends the "user movement" event:

docker exec mosquitto mosquitto_pub -h 127.0.0.1 -t "customer/move" -m '{"id":"3","ts":0,"x":550,"y":550}}'

Publishing the same message a few times:

docker exec mosquitto /bin/sh -c "for i in 1 2 3 4 5; do mosquitto_pub -i client_id -h 127.0.0.1 -t \"customer/move\" -m '{\"id\":\"3\",\"ts\":0,\"x\":550,\"y\":550}'; done"

Testing with Kafka in docker-compose

Quick way to set up Kafka cluster for development purposes was to use Docker containers.

The procedure to set up the cluster boils down to:

curl --silent --output docker-compose.yml \
  https://raw.githubusercontent.com/confluentinc/cp-all-in-one/6.1.0-post/cp-all-in-one/docker-compose.yml

docker-compose up -d

See https://docs.confluent.io/platform/current/quickstart/ce-docker-quickstart.html for the details.

To create a topic, run the following (in the directory, where docker-compose.yml is located):

docker-compose exec broker kafka-topics --create --bootstrap-server localhost:9092 --replication-factor 1 --partitions 1 --topic FOCUS_EVENT

where

  • broker is the name of the container hosting Kafka broker instance
  • localhost:9092 is the broker's URL
  • FOCUS_EVENT is the topic name

To subscribe to a topic, one can issue the following command:

docker-compose exec broker bash -c "kafka-console-consumer --bootstrap-server localhost:9092 --topic FOCUS_EVENT"
  • broker is the name of the container hosting Kafka broker instance
  • localhost:9092 is the broker's URL
  • FOCUS_EVENT is the topic name

Building and packaging

For building and packaging information see: packaging.md

Implementation walkthrough

For the details about how particular parts of the service were implemented, take a look at implemantation_walkthrough.md.