Skip to main content
Version: 4.0.0

Quickstart

In this QuickStart Guide we give a shortened overview on how to setup a Tributech Agent with a Simulated Source and connect it to a Tributech Node to display the random generated data. For a more detailed description on how to setup the Tributech Agent visit Setup.

**"Configure Agent**

Requirements

In Order to link a Tributech Agent to a Tributech node we need the following:

⚠️ We will use different Container Images and configurations in our examples for the quick start compared to the Setup documentation. Please use a new empty folder for the files to prevent any configuration mix up.

Docker-Compose Up

We start by setting up the docker-compose environment for the Tributech Agent and Tributech Simulated Source as follows:

  • Authenticate docker to retrieve the relevant docker images from the private Tributech Docker Registry.

    terminal
    echo <Client Secret> | docker login --username <Client ID> --password-stdin <Endpoint>
  • Setup the docker-compose.yml file by creating a docker-compose.yml file with the following content (adjustments required):

    docker-compose.yml
    version: "3.6"

    services:
    source-simulated:
    image: ${DOCKER_REGISTRY-tributech.azurecr.io/}tributech-source-simulated:${SOURCE_TAG:-latest}
    depends_on:
    - mosquitto-server-simulated
    - tributech-agent
    environment:
    - MqttOptions__MQTTHost=mosquitto-server-simulated
    - Logging__LogLevel__Default=Debug
    networks:
    - simulated-net
    restart: unless-stopped
    logging:
    driver: "json-file"
    options:
    max-size: "2m"
    max-file: "5"

    tributech-agent:
    image: ${DOCKER_REGISTRY-tributech.azurecr.io/}tributech-agent-play:${AGENT_TAG:-latest}
    depends_on:
    - mosquitto-server-simulated
    environment:
    - Logging__LogLevel__Default=Debug
    - Logging__Console__FormatterName=simple
    - MqttOptions__MQTTHost=mosquitto-server-simulated
    - EdgeDeviceOptions__AgentID=${AGENT_ID:?"The Tributech Agent requires a GUID"}
    - EdgeDeviceOptions__NodeUrl=${NODE_URL:?"The Tributech Node Url is required"}
    ports:
    - "5000:8080"
    networks:
    - simulated-net
    volumes:
    - ./volumes/simulated/agent/:/app/data # volume mapping for permanent storage of keys and datatwin file
    restart: unless-stopped
    logging:
    driver: "json-file"
    options:
    max-size: "2m"
    max-file: "5"

    mosquitto-server-simulated:
    image: eclipse-mosquitto:${MQTT_TAG:-1.6}
    networks:
    - simulated-net
    # ports:
    # - '1883:1883' # MQTT
    # - "127.0.0.1:9001:9001" # web-socket
    restart: unless-stopped

    networks:
    simulated-net:

    Replace the placeholder values for EdgeDeviceOptions__AgentID with a GUID for the agent unique Id thats not used by any other agent connected to the Node and the EdgeDeviceOptions__NodeUrl points to the Triubtech Node Url, for example

    env specific settings
    tributech-agent:
    ...
    environment:
    ...
    - EdgeDeviceOptions__AgentID=00000000-0000-0000-0000-000000000007
    - EdgeDeviceOptions__NodeUrl=https://my-environment.tributech-node.com
  • Startup the environment

    terminal
    docker-compose up -d
  • Validate that all containers are running. The output should return that every container is in the state Up

    terminal
    docker compose ps

Activate Agent

After starting the Tributech Agent we need to accept the Agent in the Tributech Node in order to receive data. For this we need to go to the Enrollment section of the Tributech Node and search for our agent. The Agent should be in the top most entries of the list and should be in the "Pending" state. Clicking on the Activate button is enough to enrole the agent on the Tributech Node.

***Activate Tributech Agent***

Source Configuration

The previous steps established the communication between a Tributech Agent and a Tributech Node. Next we will setup a Tributech Source to provide data for the Tributech Agent. The Tributech Agent will then be used to send the data to the Tributech Node. In the following section we complete our Tributech Agent QuickStart Setup by configuring a simple double stream for the Tributech Simulated Source (The Agent name depends on the value of the EdgeDeviceOptions__AgentID agent environment variable defined in the previous section).

**&quot;Activate Overview**

Next we need to configure the Agent to receive data for the Tributech Simulated Source we defined in the docker-compose setup:

**&quot;Configure Agent**

We have prepared a Simulated Source configuration containing a double data stream, save the following TwinConfiguration Template File locally and import it in the Agent Configuration:

**&quot;Configure Agent**

After successfully importing the TwinConfiguration Template File click the APPLY CONFIGURATION Button in the top right corner to persist the changes.

**&quot;Apply configuration**

We can now select the Simulated Stream of our newly configured QuickStart Simulated Source Agent

**&quot;Select stream**

The Stream generates a new data point between 1 and 10 every second.

**&quot;QuickStart Stream Data**

Verify

In order to detect data tampering we provide the possibility to audit each stream proofs individually. We provide the two possibilities to view the audit results:

  • A Graph view, which displays pending validation in grey, successful validations in green and failed in red. ***Audit Graph***

  • A Table view, which includes a list of all proofs. For each proof the validation can be retriggered with a button click or display the history of validations by selecting a table entry. ***Select audit***

    ***Audit overview***

This completes the QuickStart, for a more detailed guide and information about the audit process visit Stream Verification. For more information on how to add other types of Tributech Sources visit Source Integration.