This is a diagram that I have used to build this lab.
data:image/s3,"s3://crabby-images/bd06f/bd06f213b3c595658f433fc11bc3ce695671dc19" alt=""
There are a couple of steps in this lab.
- Configure IPSEC VPN site-to-site IKEv2 between FortiGate and AWS.
- Implementing Graylog open-source log management on a Linux instance on AWS.
- Download FortiGate Content Pack (.json file) for Graylog.
- Upload the file into Graylog.
- Configure FortiGate to send logs to Graylog via Graylog’s IP address and the destination UDP port 1500.
Use the link below to know how to deploy the VPN site-to-site between FortiGate on-prem and AWS.
https://tungle.ca/?p=2753
Create a new Linux instance (4GB RAM) to install Graylog.
On Security Group, create a couple of following rules to allow FortiGate LAN subnets to communicate with Graylog on AWS LAN subnets.
data:image/s3,"s3://crabby-images/1832b/1832b530925033a22110786ccdfe39a5b3e16900" alt=""
data:image/s3,"s3://crabby-images/92299/922992e8d6f9d7bef70a46912d2dcb63c76b4211" alt=""
SSH to the Linux instance.
data:image/s3,"s3://crabby-images/3cc35/3cc35f35c0acd88151bbda4427742de52b41658e" alt=""
data:image/s3,"s3://crabby-images/a494c/a494c3acc0518c0d6387a18527c84ab972f0e440" alt=""
+ Update your system and install needed packages.
sudo hostnamectl set-hostname graylog
sudo yum update -y
sudo yum install epel-release
sudo wget https://download-ib01.fedoraproject.org/pub/epel/7/x86_64/Packages/p/pwgen-2.08-1.el7.x86_64.rpm
sudo rpm -ivh pwgen-2.08-1.el7.x86_64.rpm
data:image/s3,"s3://crabby-images/d2242/d2242dd5d2055d8a2dee240d28c8ca19d34980db" alt=""
data:image/s3,"s3://crabby-images/4c7a4/4c7a4acee805a8634662490da750f810773f4916" alt=""
+ Install JAVA
sudo yum install java-1.8.0-openjdk-headless.x86_64 -y
sudo java -version
data:image/s3,"s3://crabby-images/abd0b/abd0b9f56b77701f82ef7cf211fe16409fe2f083" alt=""
+ Create a repository file. Then add the content below to this repository.
sudo nano /etc/yum.repos.d/mongodb-org.repo
[mongodb-org-4.2]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/7/mongodb-org/4.2/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc
+ Install MongoDB.
sudo yum install mongodb-org -y
data:image/s3,"s3://crabby-images/25059/25059fa7a23d8503d69a36399f50c59ae5435516" alt=""
+ Enable and start the mongoDB service on the system.
sudo systemctl daemon-reload
sudo systemctl enable mongod.service
sudo systemctl start mongod.service
sudo systemctl --type=service --state=active | grep mongod
data:image/s3,"s3://crabby-images/8837b/8837b22ea9fa9a6836b6495e820ae9449f7c91af" alt=""
+ Check MongoDB service port.
netstat -antp | grep 27017
data:image/s3,"s3://crabby-images/50a66/50a66eb0d2db680d212d1965227fc32af31a7c78" alt=""
+ Installing Elasticsearch.
Create a repository, then add the following contents to the file.
sudo nano /etc/yum.repos.d/elasticsearch.repo
[elasticsearch-6.x]
name=Elasticsearch repository for 6.x packages
baseurl=https://artifacts.elastic.co/packages/oss-6.x/yum
gpgcheck=1
gpgkey=https://artifacts.elastic.co/GPG-KEY-elasticsearch
enabled=1
autorefresh=1
Install the open-source version of Elasticsearch.
sudo yum install elasticsearch-oss -y
data:image/s3,"s3://crabby-images/7335f/7335f6c8397da22a3d51743b4448f1f6f7807e0d" alt=""
#Edit the elasticsearch.yml file on /etc/elasticsearch/elasticsearch.yml
sudo nano /etc/elasticsearch/elasticsearch.yml
Modify the Elasticsearch configuration file. Set the cluster name to graylog and add “action.auto_create_index: false” to the file.
data:image/s3,"s3://crabby-images/e7666/e76667a2af0a2bac6ea99819496dd597cf433251" alt=""
data:image/s3,"s3://crabby-images/677d2/677d2f7462eed9e6d2857802a2063b286fbd6489" alt=""
Save and exit the file. Enable, start and check the status of elastic search on the system.
sudo systemctl daemon-reload
sudo systemctl enable elasticsearch.service
sudo systemctl restart elasticsearch.service
sudo systemctl --type=service --state=active | grep elasticsearch
data:image/s3,"s3://crabby-images/a1396/a1396dffb9a4e5d3a2eabf1173330cca294599d8" alt=""
Check elastic search health.
curl -XGET 'http://localhost:9200/_cluster/health?pretty=true'
data:image/s3,"s3://crabby-images/a1972/a19728adbd2f28d68b7f719183ee7a28d512d252" alt=""
+ Installing the Graylog.
Now install the Graylog repository configuration with the following command.
sudo rpm -Uvh https://packages.graylog2.org/repo/packages/graylog-4.2-repository_latest.rpm
Install Graylog-server.
sudo yum install graylog-server -y
data:image/s3,"s3://crabby-images/e3777/e3777af1dc10b804e32d6f9db291f9d5230d12f3" alt=""
data:image/s3,"s3://crabby-images/da06e/da06e5ae87221098be1792159fb6a8673df50bc7" alt=""
Configure Graylog.
Generate password_secret.
pwgen -N 1 -s 96
[ec2-user@ip-10-0-0-64 ~]$ pwgen -N 1 -s 96
Bv6a46BXTALlfI3VRZ3ACfzBoIZOo3evqd7v7FY0fsrSXNZDflPcWRtYoxRrm5BZfMvq2TKffWEobYL6iSwBW908gpSC9z79
Generate root_password_sha2.
echo -n graylog@123 | sha256sum | cut -d” ” -f1
[ec2-user@ip-10-0-0-64 ~]$ echo -n graylog@123 | sha256sum | cut -d” ” -f1
cc41de147e5c624c6a7c230648545f6d14f82fa0e591148dc96993b3e539abfc
data:image/s3,"s3://crabby-images/664c4/664c4436cb82720eb083a00ff0906f78b556d29c" alt=""
Edit etc/graylog/server/server.conf file.
sudo nano /etc/graylog/server/server.conf
data:image/s3,"s3://crabby-images/82247/822477320548b3c4a26b6e074a4e940cf15385ba" alt=""
data:image/s3,"s3://crabby-images/78f0a/78f0ac7d3c42dcd1ff75bca066b4128baeac61b9" alt=""
Comment the following line.
#http_bind_address = 127.0.0.1:9000
Add the following line with IP address of Graylog.
http_bind_address = 10.0.0.64:9000
data:image/s3,"s3://crabby-images/8fb89/8fb89a53b8020a378fe78fdc3805d44c14112a5e" alt=""
Enable and start Graylog service.
sudo systemctl enable graylog-server.service
sudo systemctl start graylog-server.service
data:image/s3,"s3://crabby-images/4e48e/4e48eec6a03769044cdbd3bde8d54ce64e053f11" alt=""
Check Graylog Server listening port.
netstat -antp | grep 9000
data:image/s3,"s3://crabby-images/408ed/408ed38e13a92d63ed94c0ecb5580544a1e2e5f6" alt=""
data:image/s3,"s3://crabby-images/32fcb/32fcb2b1ac5c770593d171857cc3e2e9f7e39ad8" alt=""
Access Graylog web interface from Kali’s machine on FortiGate LAN subnets.
http://10.0.0.4:9000
user:admin
password:graylog@123
data:image/s3,"s3://crabby-images/0e4d9/0e4d9214180d2d4293aa9c0bb8895f0844cfc890" alt=""
Back to FortiGate, configure the Syslog setting to send logs via the Graylog server on its IP address 10.0.0.64 with a destination port is 1500.
config log syslogd setting
set status enable
set server 10.0.0.64
set port 1500
end
data:image/s3,"s3://crabby-images/cdc13/cdc138f0fffdcc7baf459aa165c80f468d96e3fc" alt=""
show log syslogd setting
data:image/s3,"s3://crabby-images/875f3/875f3f0ab6edb55cdaa2a6c6d69b51b4647ece61" alt=""
data:image/s3,"s3://crabby-images/b0a51/b0a51ef45468031d472ff085902d394d44789dcb" alt=""
On Graylog.
data:image/s3,"s3://crabby-images/f82a5/f82a5ded21d5654cb90a21111430df110c79d7de" alt=""
Download FortiGate Content Pack from Github.
https://marketplace.graylog.org/addons/f1b25e9c-c908-41e4-b5de-4549c500a9d0
https://github.com/teon85/fortigate6.4_graylog4
Download the JSON file (fortigate6.4_graylog4.json)
Go to System – Content Packs – Upload. Select the file (fortigate6.4_graylog4.json) and upload.
data:image/s3,"s3://crabby-images/5bfd4/5bfd49273235cd0ba1b9aa98c02e36899f2759f4" alt=""
data:image/s3,"s3://crabby-images/bbddc/bbddc5e3ecc261173515112918ba60298dc53865" alt=""
Click Install.
data:image/s3,"s3://crabby-images/c9482/c94822c95dbfd12fc277e570d69fc0ab0369a8ea" alt=""
Change the Syslog port to 1500.
data:image/s3,"s3://crabby-images/63cfd/63cfd7e7988c8bb7a46a12e23b615b6913dd9c11" alt=""
data:image/s3,"s3://crabby-images/96525/965254cd0d903f8f4e8e8aca770cbfef6f629db1" alt=""
FortiGate dashboard.
data:image/s3,"s3://crabby-images/2539f/2539f7c68390ecabec1aced7181f03caf13fe344" alt=""
data:image/s3,"s3://crabby-images/11b9b/11b9bdf3641d671402825d8f71ae968f664aa91b" alt=""