Getting Started


What is PADAS?

PADAS is built on top of robust Confluent Kafka Platform and enables organizations to transform, analyze, and filter TBs of streaming data in real-time. The goal is to keep things simple and take some of the burden away from existing SIEM and Analytics platforms by running various pipelines (combination of tasks that perform transformations and detections). PADAS comes with out-of-the-box integration examples (e.g. Winlogbeat, Splunk) and ready-to-implement rules pertinent to MITRE ATT&CK Framework. Any other custom rules can also be added (via PDL) without any dependency to existing SIEM or Analytics infrastructure.



Components

Padas has 2 main components:

  1. Manager UI: All configuration changes (CRUD - Create, Read, Update, Delete operations) can be performed through Manager web interface. This is an optional but recommended component to manage configurations through Engine API.
  2. Engine: Reads configurations from existing Padas topics and runs assigned (based on group setting) and enabled topologies. Each topology reads from a single source topic, runs one or more pipeline(s), and writes the resulting outputs to one or more output topic(s). Each pipeline consists of one or more task(s) where each task can perform a filter, transform, enrichment, or detection (rules) function. Please see below for details on concepts.

A Manager UI can be configured to connect to a single Engine component. Engine components can be scaled up or down as needed with group assignments to distribute work-load.

Basic Concepts

Let’s take a closer look at Padas configuration and engine’s processing concepts. At a high-level, Padas Engine reads an input topic, processes data (pipelines and tasks) and writes to one or more output topics.

Topologies, Pipelines, Tasks



Quick start

This quick start guide assumes all components (Confluent Kafka and Padas) will be installed on the same machine. In production, it is recommended to separate out these components on different nodes/hosts.

This quickstart consists of the following steps:

  1. Step 1: Download and define components
  2. Step 2: Start Manager
  3. Step 3: Start Detect Engine
  4. Step 4: Start Transform Engine
  5. Step 5: Generate Events
  6. Step 6: View Alerts


Prerequisites

  • Internet connectivity
  • Supported Operating System
  • A supported version of Java. Java 8 and Java 11 are supported in this version.
  • Confluent Kafka must be installed and running (locally) as described in Quick Start for Confluent Platform. You should have at least the following services up and running.
      confluent local services status
      ...
      Kafka is [UP]
      Schema Registry is [UP]
      ZooKeeper is [UP]
      ...
    


Overview of Quickstart

Below diagram shows what will be accomplished with this quick start guide.


Step 1: Download and define components

  1. Download the latest version (e.g. padas-0.0.1.tgz)
  2. Use the tar command to decompress the archive file

     tar -xvzf padas-0.0.1.tgz
    
  3. Since we have everything on a single host, make a copy of the extracted folder for manager, transform engine, and detect engine

     cp -r padas padas-manager
     cp -r padas padas-transform
     mv padas padas-detect
    

    NOTE: Last renaming step is not necessary but gives a descriptive name to the folder’s functionality.

  4. Edit manager properties (padas-manager/etc/padas.properties) to make sure the padas.instance.role is set to manager and padas.license is set to the license you received.

     vi padas-manager/etc/padas.properties
     ...
    

    After editing, properties file (padas-manager/etc/padas.properties) entries should be:

     padas.instance.role=manager
     bootstrap.servers=localhost:9092
     schema.registry.url=http://localhost:8081
     padas.license=<LICENSE KEY SHOULD GO HERE>
    
  5. Edit transform properties (padas-transform/etc/padas.properties) to make sure the padas.instance.role is set to transform.

     vi padas-transform/etc/padas.properties
     ...
    

    After editing, properties file (padas-transform/etc/padas.properties) entries should be:

     padas.instance.role=transform
     bootstrap.servers=localhost:9092
     schema.registry.url=http://localhost:8081
    
  6. From your current working directory, now you should have 3 PADAS folders, e.g.

     ls
     padas-detect   padas-manager   padas-transform
    

    Note that you don’t have to make any configuration changes to padas-detect folder, as the default behavior is set to Detect Engine with localhost.

At this stage, make sure you have Confluent Kafka running locally as mentioned in prerequisites.


Step 2: Start Manager

  1. Start manager node on the console. The script will ask you to accept the license agreement (enter y) and define an administrator user to login; enter the desired password to continue
    cd padas-manager/
    
    bin/padas start-console
    PADAS Software License Agreement
    ...
    Displayed Padas Software License Agreement contents can also be found at https://padas.io/legal/eula.html OR in file /<YOUR INSTALL DIR>/padas-manager/etc/license.txt
    Do you agree with this license? [y/n]: y
    INFO  Starting PADAS Manager...
    INFO  Validating license string...    
    This appears to be your first time running this version of Padas.
    Padas Manager requires an administrator account to run. Please create credentials.
    Please enter an administrator username? [admin]:
    Password must contain at least 8 total printable ASCII characters.
    Please enter a new password:
    Please repeat the password:
    Successfully saved password.
    INFO  Verifying Kafka broker connection...
    INFO  Verifying Schema Registry connection...
    INFO  Starting web interface...
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@*@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@:**@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@:****:@@@@@@@@@@@**:****@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@**********:::**********@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@:***********************@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@************************:@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@**************************@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@*****************************@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@********************************&@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@#***********************************::@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@**:************************************@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@******************************@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@&*@@@@@@@@@@*************************@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@:**********@@@@@@@@@@@***********************@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@***********:@@@@@@@@@@@@********************o@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@***********@@@@@@@@@@@@@*******************:@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      **************o@@@@@@@@@@@@@*******************:@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      **************@@@@@@@@@@@@@********************:@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @:::o:********@@@@@@@@@@@@:********************:@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@o*******@@@@@@@@@@**************o@@@#****8@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@*******:@@@@@@@:***********@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@8
      @@@@@@@@**********:@**************@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@*
      @@@@@@@:*****************************:8@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@&
      @@@@@@:***********************************@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@:@
      @@@@@@o****************************************@@@@@@@@@@@@@@@@@@@@@@@@@:*@@
      @@@@@@o********************************************:*@@@@@@@@@@@@@@@@@:**@@@
      @@@@@@@@@******************************@::****************************:@@@@@
      @@@@@@@@@@*@@:******#@@@@@@@@@*********@@@@@@@@8**:****************@@@@@@@@@
      @@@@@@@@@*****@@*****:8@@@@@@@@@8*********@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@*****@@@:******@@@@@@@@@@@@:*****@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@****&@@@@@@*****@@@@@@@@@@@@@@****@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@**@@@****@@@@@@@@#***#@@@@@@@@@@@@@@****@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@******:***@@@@@@@@***@@@@@@@@@@@@@@@****@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@:&@@@@@@@@@@::@@*****:o@@@@@@@o***********@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@:*****8#@:*#@@@@@@8*@*8@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@&@*@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      ____   _    ____    _    ____
    |  _ \ / \  |  _ \  / \  / ___|
    | |_) / _ \ | | | |/ _ \ \___ \
    |  __/ ___ \| |_| / ___ \ ___) |
    |_| /_/   \_\____/_/   \_\____/
    INFO  Starting Manager using Java 11.0.10 on padas.local with PID 96539 (/<YOUR INSTALL DIR>/padas-manager/libs/padas-manager-0.0.2.jar started by user1 in /<YOUR INSTALL DIR>)
    INFO  No active profile set, falling back to default profiles: default
    INFO  Started Manager in 7.973 seconds (JVM running for 118.08)
    
  2. Login: Go to http://localhost:9000 and login with the credentials used in previous step (e.g. admin)

  3. Create Topics: Upon initial login, Manager will go to Topics menu in order to create necessary Kafka topics.


    Hit Save button to continue with defaults.

  4. Create a Rule: Go to Rules menu link in order to add a sample rule. Enter the following values for the required fields:
    • Rule Name: Test Rule
    • PDL Query: field1="value"
    • Datamodel List: testdm

    Other provided fields are optional but feel free to review and add/modify as needed. A list of rules for MITRE ATT&CK can be found here: padasRules.json


    Hit Save button to continue.


    You should be able to view the rule you specified, similar to the following screenshot.

  5. Add a Transformation: Go to Properties and first hit Edit, then select Add New Transformation. Expand “Input Topic: 0” and enter the following values for the required fields:
    • Topic Name: testtopic
    • Datamodel Name: testdm



    You should be able to view the newly added property (Input Topic: testtopic, similar to the following screenshot.


Step 3: Start Detect Engine

  1. Start Detect Engine on the console (separate window, since Manager is running on the console as well). The script will ask you to accept the license agreement (enter y).
    cd padas-detect/
    
    bin/padas start-console
    PADAS Software License Agreement
    ...
    Displayed Padas Software License Agreement contents can also be found at https://padas.io/legal/eula.html OR in file /<YOUR INSTALL DIR>/padas-detect/etc/license.txt
    Do you agree with this license? [y/n]: y
    INFO  Starting Detect Engine...
    


Step 4: Start Transform Engine

  1. Before starting Transform Engine we must first create the specified input topic (i.e. testtopic) in Kafka. You can do this from Confluent Control Center or from the console as shown below.

     kafka-topics --create --bootstrap-server localhost:9092 --topic testtopic --partitions 1 --replication-factor 1
     Created topic testtopic.
    
  2. Start Transform Engine on the console (separate window, since Manager and Detect Engine are running on the console as well). The script will ask you to accept the license agreement (enter y).

    cd padas-transform/
    
    bin/padas start-console
    PADAS Software License Agreement
    ...
    Displayed Padas Software License Agreement contents can also be found at https://padas.io/legal/eula.html OR in file /<YOUR INSTALL DIR>/padas-transform/etc/license.txt
    Do you agree with this license? [y/n]: y
    INFO  Starting Transform Engine...
    


Step 5: Generate Sample Event

  1. Let’s generate a sample event with a simple JSON message. Note that this JSON will match the PDL (field1="value1") specified above.
    echo '{"field1":"value1","field2":"value1"}' |  kafka-console-producer --bootstrap-server localhost:9092 --topic testtopic
    


Step 6: View Alerts

  1. Once the sample event is ingested, PADAS Detect Engine will run the rules for matching datamodels in real-time and populate padas_alerts topic with matching event and alert information. You can simply view this alert with the following command:

     kafka-avro-console-consumer --bootstrap-server localhost:9092 --topic padas_alerts --from-beginning | jq
    

    Output will be similar to the following. Note the use of jq above for pretty display of JSON data.

     {
       "timestamp": "2021-11-28T14:25:23.199+0300",
       "name": "Test Rule",
       "description": "",
       "references": null,
       "customAnnotations": null,
       "mitreAnnotations": null,
       "platforms": {
         "string": ""
       },
       "domain": "mitre_attack",
       "analyticType": {
         "string": ""
       },
       "severity": {
         "string": ""
       },
       "datamodelReferences": null,
       "events": [
         {
           "timestamp": "2021-11-28T14:18:30.309+0300",
           "datamodel": "testdm",
           "source": "unknown",
           "host": "padas.local",
           "src": null,
           "dest": null,
           "user": null,
           "rawdata": "{\"field1\":\"value1\",\"field2\":\"value1\"}",
           "jsondata": "{\"field1\":\"value1\",\"field2\":\"value1\"}"
         }
       ]
     }
    


Next Steps: