2018-12-05 10:37:20 +01:00
# D4 core
2019-01-25 11:51:41 +01:00
data:image/s3,"s3://crabby-images/f494d/f494df966a51b9c98e041122cf1c143d2ba90aeb" alt=""
2019-01-24 21:06:26 +01:00
D4 core are software components used in the D4 project. The software includes everything to create your own sensor network or connect
to an existing sensor network using simple clients.
2018-12-05 10:37:20 +01:00
2019-02-14 16:27:06 +01:00
data:image/s3,"s3://crabby-images/4d9a4/4d9a4e45c1f025bb53e69e62b21cbbb722a7ba81" alt="https://github.com/D4-project/d4-core/releases/latest "
data:image/s3,"s3://crabby-images/02d88/02d884c90cc528c16f48c73cdc92396700a3a4bd" alt="https://github.com/D4-project/d4-core/blob/master/LICENSE "
2018-12-05 10:37:20 +01:00
## D4 core client
2019-01-24 21:42:46 +01:00
[D4 core client ](https://github.com/D4-project/d4-core/tree/master/client ) is a simple and minimal implementation of the [D4 encapsulation protocol ](https://github.com/D4-project/architecture/tree/master/format ). There is also a [portable D4 client ](https://github.com/D4-project/d4-goclient ) in Go including the support for the SSL/TLS connectivity.
2019-01-24 21:06:26 +01:00
2019-07-11 14:40:40 +02:00
< p align = "center" >
< img alt = "d4-cclient" src = "https://raw.githubusercontent.com/D4-project/d4-core/master/client/media/d4c-client.png" height = "140" / >
< / p >
2019-01-24 21:06:26 +01:00
### Requirements
- Unix-like operating system
- make
- a recent C compiler
2019-01-24 21:42:46 +01:00
### Usage
The D4 client can be used to stream any byte stream towards a D4 server.
As an example, you directly stream tcpdump output to a D4 server with the following
script:
````
tcpdump -n -s0 -w - | ./d4 -c ./conf | socat - OPENSSL-CONNECT:$D4-SERVER-IP-ADDRESS:$PORT,verify=0
````
~~~~
d4 - d4 client
Read data from the configured < source > and send it to < destination >
Usage: d4 -c config_directory
Configuration
The configuration settings are stored in files in the configuration directory
specified with the -c command line switch.
Files in the configuration directory
key - is the private HMAC-SHA-256-128 key.
The HMAC is computed on the header with a HMAC value set to 0
which is updated later.
snaplen - the length of bytes that is read from the < source >
version - the version of the d4 client
type - the type of data that is send. pcap, netflow, ...
source - the source where the data is read from
destination - the destination where the data is written to
~~~~
2019-01-24 21:06:26 +01:00
### Installation
2018-12-05 10:37:20 +01:00
~~~~
2019-01-24 21:06:26 +01:00
cd client
2018-12-05 10:37:20 +01:00
git submodule init
git submodule update
~~~~
2019-01-24 21:06:26 +01:00
## D4 core server
D4 core server is a complete server to handle clients (sensors) including the decapsulation of the [D4 protocol ](https://github.com/D4-project/architecture/tree/master/format ), control of
sensor registrations, management of decoding protocols and dispatching to adequate decoders/analysers.
2018-12-05 10:37:20 +01:00
### Requirements
2019-01-24 21:06:26 +01:00
- Python 3.6
- GNU/Linux distribution
### Installation
2019-02-28 11:47:29 +01:00
- [Install D4 Server ](https://github.com/D4-project/d4-core/tree/master/server )
2018-12-05 10:37:20 +01:00
2019-01-25 11:47:45 +01:00
### Screenshots of D4 core server management
data:image/s3,"s3://crabby-images/5de96/5de963b1b27cd23d4ce61f4bbff4cc6c3e640977" alt=""
data:image/s3,"s3://crabby-images/8bf88/8bf88d6830eeb75e5318ff0669c12484a6cfe7cd" alt=""
data:image/s3,"s3://crabby-images/da7f5/da7f56ac78a54e7d9c93e2cf805f27ae72ffe1de" alt=""
2019-02-14 16:38:08 +01:00
data:image/s3,"s3://crabby-images/f454a/f454a8ae8806f7c37b290787baf959335dcf9bff" alt=""
data:image/s3,"s3://crabby-images/9918a/9918a90310e4e6834d5832516b712c75b9905c67" alt=""