Skip to content
@PIR-IDS

PIR-IDS

Research project on the analysis of the evolution of information systems and on a proposed IDS (Intrusion Detection System) design method adapted to these.

About The Project

Research project on the analysis of the evolution of information systems, on the critical analysis of the ability of existing attack detection solutions to support this evolution and on a proposal for an IDS (Intrusion Detection System) design method adapted to these evolutions.

Usage

This project contains 4 main repositories, each of them providing an important feature.

  • The IDS logic, the detection system, is located in the 2 mobile applications, the IDS Android App and the IDS iOS App. These two applications are alike and are the control center of the data we will gather. We can add as many compatible Services and Devices (Probes) as we want, we just have to follow the Android Guide and the iOS Guide. Each Device will be a BLE Probe that will collect data and sometimes process it before sending it to the Apps.
  • The third main repository is the only compatible Device yet, the Wallet Card. It will use a ML model to produce a binary for a specified board.
  • The last main repository is the training algorithm used to produce our ML model for the Wallet Card, the Wallet Model. It will output a C++ code that will be compiled by the Wallet Card toolchain. It uses input data previously gathered.

This input data is obtained by using two other repositories, the Wallet Data Collector, which runs on the same board as the Wallet Card's and the BLE Reader which reads the data sent using a Bluetooth compatible computer observing the Wallet Data Collector. See the Documentation of the Wallet Data Collector to learn more about the data we collect.

The other repositories are used as utilities and tools to do statistics about the project and to help us to achieve a better understanding on how the things work.

You can check the Release sections of each repository to get all the binaries compiled with our dataset, or if you want to use your own data, you can follow the detailled steps below.

How to use your own dataset?

Note All these steps have already been applied with the data we collected. This data is considered as a build artefact by the repository which produces it and as a resource by the repository which depends on it. Following this assumption, when the data is a resource, it is commited and versioned. If you want to use your own dataset, you can replace these resources by recreating the data by yourself.

  1. For the Wallet Card, as it is the only compatible device yet, assuming that all the repositories prerequisites and installation steps have been satisfied and the board is plugged, we collect the data like this:

    cd wallet-data-collector
    pio run -e release -t upload
    cd ble-reader
    pipenv run read <address> <filename> # with <address> the device address and <filename> the file where you want the output to go in the out directory
  2. When enough data is collected, we can use it to create a model. Place the content of the ble-reader/out directory in the wallet-model/train subdirectories, in wallet when it is a positive dataset or negative when it is a negative dataset, making sure the names of the data files match the pattern used by the Python scripts, then run:

    cd wallet-model
    pipenv run prepare && pipenv run split && pipenv run train && pipenv run generate
  3. When the training is finished, copy the model file wallet-model/output/model.cc in the wallet-card/res directory and rename it wallet_model_data.cpp.

  4. Also replace the array declaration with this one:

    // Keep model aligned to 8 bytes to guarantee aligned 64-bit accesses.
    alignas(8) const unsigned char wallet_model_data[]
  5. Then you can build your own binary for the board. You can run it with:

    cd wallet-card
    pio run -e release -t upload

Credits

Romain Monier [ GitHub ] – Co-developer | Noé Chauveau [ GitHub ] – Co-developer | Amélie Muller [ GitHub ] – Co-developer | Quentin Douarre [ GitHub ] – Co-developer | Morgan Pelloux [ GitHub ] – Co-developer | David Violes [ GitHub ] – Co-developer | Malik Sedira [ GitHub ] – Co-developer | Pierre Favary [ GitHub ] – Co-developer

Contact

Organization Link : https://github.com/PIR-IDS

Pinned Loading

  1. IDS-Android-App IDS-Android-App Public

    IDS Android App

    Kotlin 2

  2. IDS-iOS-App IDS-iOS-App Public

    IDS iOS App

    Swift 1

  3. wallet-card wallet-card Public

    Code for the Arduino Nano 33 BLE board

    C++ 1

  4. wallet-model wallet-model Public

    Code for the ML "wallet out" model training

    Python 1

  5. wallet-data-collector wallet-data-collector Public

    Code to collect the data for the wallet model

    C++

  6. ble-reader ble-reader Public

    Code for the BLE reader used during the training phase of our model

    Python

Repositories

Showing 10 of 10 repositories
  • wallet-model Public

    Code for the ML "wallet out" model training

    PIR-IDS/wallet-model’s past year of commit activity
    Python 1 0 0 0 Updated Aug 30, 2022
  • IDS-iOS-App Public

    IDS iOS App

    PIR-IDS/IDS-iOS-App’s past year of commit activity
    Swift 1 0 0 0 Updated Aug 25, 2022
  • IDS-Android-App Public

    IDS Android App

    PIR-IDS/IDS-Android-App’s past year of commit activity
    Kotlin 2 0 0 0 Updated Aug 23, 2022
  • ble-reader Public

    Code for the BLE reader used during the training phase of our model

    PIR-IDS/ble-reader’s past year of commit activity
    Python 0 0 0 0 Updated Aug 12, 2022
  • wallet-data-collector Public

    Code to collect the data for the wallet model

    PIR-IDS/wallet-data-collector’s past year of commit activity
    C++ 0 0 0 0 Updated Aug 12, 2022
  • wallet-card Public

    Code for the Arduino Nano 33 BLE board

    PIR-IDS/wallet-card’s past year of commit activity
    C++ 1 0 0 0 Updated Aug 11, 2022
  • .github Public
    PIR-IDS/.github’s past year of commit activity
    0 0 0 0 Updated Aug 8, 2022
  • PIR-IDS/ble-frequency-analyzer’s past year of commit activity
    Python 0 0 0 0 Updated Aug 5, 2022
  • ble-scanner Public
    PIR-IDS/ble-scanner’s past year of commit activity
    C++ 0 0 0 0 Updated Aug 5, 2022
  • PIR-IDS/data-visualizer’s past year of commit activity
    Python 0 0 0 0 Updated Aug 5, 2022

Top languages

Loading…

Most used topics

Loading…