Database, UFW metodes, and tested.

dev
marcelb 1 year ago
parent 33550ccc69
commit 8795b6ff29
  1. 1
      .gitignore
  2. 58
      .vscode/settings.json
  3. 28
      .vscode/tasks.json
  4. 2
      README.md
  5. 5
      clonelibs.sh
  6. 56
      lib/ipban.hpp
  7. 72
      src/ipban.cpp
  8. 1
      test/compile.sh
  9. 40
      test/gen_db.cpp
  10. 1
      test/ipban.db
  11. BIN
      test/test
  12. 31
      test/test.cpp

1
.gitignore vendored

@ -1 +1,2 @@
example
exec

@ -1,5 +1,61 @@
{
"files.associations": {
"*.tcc": "cpp"
"*.tcc": "cpp",
"ostream": "cpp",
"cctype": "cpp",
"clocale": "cpp",
"cmath": "cpp",
"cstdarg": "cpp",
"cstddef": "cpp",
"cstdio": "cpp",
"cstdlib": "cpp",
"ctime": "cpp",
"cwchar": "cpp",
"cwctype": "cpp",
"array": "cpp",
"atomic": "cpp",
"bit": "cpp",
"chrono": "cpp",
"compare": "cpp",
"concepts": "cpp",
"condition_variable": "cpp",
"cstdint": "cpp",
"deque": "cpp",
"map": "cpp",
"string": "cpp",
"unordered_map": "cpp",
"vector": "cpp",
"exception": "cpp",
"algorithm": "cpp",
"functional": "cpp",
"iterator": "cpp",
"memory": "cpp",
"memory_resource": "cpp",
"numeric": "cpp",
"random": "cpp",
"ratio": "cpp",
"string_view": "cpp",
"system_error": "cpp",
"tuple": "cpp",
"type_traits": "cpp",
"utility": "cpp",
"fstream": "cpp",
"future": "cpp",
"initializer_list": "cpp",
"iosfwd": "cpp",
"iostream": "cpp",
"istream": "cpp",
"limits": "cpp",
"mutex": "cpp",
"new": "cpp",
"numbers": "cpp",
"semaphore": "cpp",
"sstream": "cpp",
"stdexcept": "cpp",
"stop_token": "cpp",
"streambuf": "cpp",
"thread": "cpp",
"cinttypes": "cpp",
"typeinfo": "cpp"
}
}

28
.vscode/tasks.json vendored

@ -0,0 +1,28 @@
{
"tasks": [
{
"type": "cppbuild",
"label": "C/C++: g++ build active file",
"command": "/usr/bin/g++",
"args": [
"-fdiagnostics-color=always",
"-g",
"${file}",
"-o",
"${fileDirname}/${fileBasenameNoExtension}"
],
"options": {
"cwd": "${fileDirname}"
},
"problemMatcher": [
"$gcc"
],
"group": {
"kind": "build",
"isDefault": true
},
"detail": "Task generated by Debugger."
}
],
"version": "2.0.0"
}

@ -1,3 +1,3 @@
# ipban
Ban an IP in time over UFW
A library for managing IP address bans on UFW systems

@ -0,0 +1,5 @@
rm -rf exec
wget https://git.bitelex.co/marcelb/exec/archive/v0.1_beta.tar.gz
tar -xvf v0.1_beta.tar.gz
rm v0.1_beta.tar.gz

@ -6,10 +6,13 @@
#include <string>
#include <future>
#include <mutex>
#include <fstream>
#include <time.h>
#include <unistd.h>
#include "../exec/lib/exec.hpp"
using namespace std;
namespace marcelb {
@ -17,30 +20,79 @@ namespace marcelb {
#define BOT_LOOP_TIME 60 // 1 minutes
#define BOT_SLEEP_LOOP_TIME 1 // 1 second
/**
* Banovani objekt
* IP adresa i vrijeme banovanja
*/
struct _ban {
string ip;
time_t _time;
};
/**
* Biblioteka za ban IP adrese kroz UFW vatrozid na određeno vrijeme
* Automatski uklanja zabranu po isteku vremena
* Posjeduje vlastiti DB mehanizam za zaštitu od nepovratnog ban-a
*/
class ipban {
mutex io;
time_t ban_duration; // u sekundama
time_t ban_duration;
string db_file;
vector<_ban> banned;
future<void> unban_bot;
bool run_unban_bot = true;
// interface možda bude trebao za ban
/**
* Metoda učitava banovane IP adrese iz baze
*/
void load_db();
/**
* Metoda ažurira stanja baze sa stanjima iz memorije
*/
bool update_db();
/**
* Metoda uklanja ban za proslijeđeni iterator vektora banned i ažurira bazu
*/
bool unban(vector<_ban>::iterator ban_itr);
/**
* Metoda poziva exec i dodaje pravila u UFW vatrozid
*/
bool ufw_ban(const string& ip);
/**
* Metoda poziva exec i uklanja pravilo u UFW vatrozidu
*/
bool ufw_unban(const string& ip);
public:
ipban(const uint& _duration); // u minutama?
/**
* Konstruktor, prima zadanu vrijednost trajanja ban-a u minutama
* i putanju datoteke baze podataka
*/
ipban(const uint& _duration, const string& db_file = "ipban.db"); // u minutama?
/**
* Metoda koja banuje proslijeđenu IP adresu, dodaje je u vector banned, ažurira bazu
* Vraća status operacije
*/
bool ban(const string& ip);
/**
* Destruktor, uklanja sve zabrane.
*/
~ipban();
};
/**
* Funkcija za mirovanje tijeka, koj miruje do isteka vremena ili logičkog stanja uvijeta
* Prima vrijeme u sekundama, i logički uvijet
*/
static void sleep_if(const uint& _time, const bool& _condition);
}

@ -1,23 +1,23 @@
#include "../lib/ipban.hpp"
marcelb::ipban::ipban(const uint& _duration) {
marcelb::ipban::ipban(const uint& _duration, const string& _db_file) {
ban_duration = _duration*60;
db_file = _db_file;
load_db();
unban_bot = async(launch::async, [&]() {
while (run_unban_bot) {
sleep_if(BOT_LOOP_TIME, run_unban_bot);
cout << "Sleep" << endl;
io.lock();
for (uint i=0; i<banned.size(); i++) {
if (difftime(time(NULL), banned[i]._time) >= ban_duration) {
unban(banned.begin() + i);
if (!unban(banned.begin() + i)) {
cout << "[ERROR] Unban is not done properly! " << endl;
}
}
}
io.unlock();
}
return;
});
}
marcelb::ipban::~ipban() {
@ -28,27 +28,79 @@ marcelb::ipban::~ipban() {
}
}
void marcelb::ipban::load_db() {
string line;
ifstream mydb (db_file);
if (mydb.is_open()) {
while (getline(mydb, line) ) {
struct _ban saved_ban;
saved_ban.ip = line.substr(0, line.find('-'));
saved_ban._time = stol(line.substr(line.find('-')+1));
banned.push_back(saved_ban);
}
mydb.close();
}
}
bool marcelb::ipban::update_db() {
bool success = false;
ofstream mydb (db_file);
if (mydb.is_open()) {
for (int i=0; i<banned.size(); i++) {
mydb << banned[i].ip << "-" << banned[i]._time << "\n";
}
success = true;
mydb.close();
}
else {
success = false;
}
return success;
}
bool marcelb::ipban::ban(const string& ip) {
ufw_ban(ip);
bool status = ufw_ban(ip);
io.lock();
banned.push_back({ip, time(NULL)});
status = status && update_db();
io.unlock();
return status;
}
bool marcelb::ipban::unban(vector<_ban>::iterator ban_itr) {
ufw_unban(ban_itr->ip);
bool status = ufw_unban(ban_itr->ip);
io.lock();
banned.erase(ban_itr);
status = status && update_db();
io.unlock();
return status;
}
bool marcelb::ipban::ufw_ban(const string& ip) {
cout << "UFW ban IP: " << ip << endl;
string ufw_cmd = "sudo ufw deny from " + ip + " to any";
try {
string execute_res = exec(ufw_cmd);
if (execute_res == "Rule added\n") {
return true;
}
} catch (const string except) {
cout << except << endl;
}
return false;
}
bool marcelb::ipban::ufw_unban(const string& ip) {
cout << "UFW unban IP: " << ip << endl;
string ufw_cmd = "sudo ufw delete deny from " + ip + " to any";
try {
string execute_res = exec(ufw_cmd);
if (execute_res == "Rule deleted\n") {
return true;
}
} catch (const string except) {
cout << except << endl;
}
return false;
}
static void marcelb::sleep_if(const uint& _time, const bool& _condition) {

@ -0,0 +1 @@
g++ test.cpp ../src/*.cpp ../exec/src/*.cpp -o test

@ -0,0 +1,40 @@
#include <iostream>
#include <fstream>
#include <sstream>
#include <vector>
#include <ctime>
#include <cstdlib>
struct _ban {
std::string ip;
long int _time;
};
// Funkcija za generiranje pseudoslučajnih IP adresa
std::string generateRandomIP() {
return std::to_string(rand() % 256) + "." +
std::to_string(rand() % 256) + "." +
std::to_string(rand() % 256) + "." +
std::to_string(rand() % 256);
}
int main() {
//std::ofstream mydb("datoteka.txt");
// Postavka generiranja pseudoslučajnih brojeva
srand(static_cast<unsigned>(time(0)));
// Generiranje desetaka IP adresa i povezanih vremenskih brojeva
for (int i = 0; i < 10; ++i) {
_ban generated_ban;
generated_ban.ip = generateRandomIP();
generated_ban._time = static_cast<long int>(time(nullptr) - rand()%100);
// Ispisivanje u datoteku
std::cout << generated_ban.ip << "-" << generated_ban._time << std::endl;
}
std::cout << "Generiranje završeno." << std::endl;
return 0;
}

@ -0,0 +1 @@
90.163.88.49-1702323353

Binary file not shown.

@ -2,9 +2,36 @@
using namespace marcelb;
std::string generateRandomIP() {
return std::to_string(rand() % 256) + "." +
std::to_string(rand() % 256) + "." +
std::to_string(rand() % 256) + "." +
std::to_string(rand() % 256);
}
// time_t random_time (const uint& offset) {
// time_t _time = time(nullptr);
// if (_time %2 == 0) {
// return (time(nullptr) + rand()%offset);
// }
// else {
// return (time(nullptr) - rand()%offset);
// }
// }
int main() {
ipban myban(1);
myban.ban("192.168.2.74");
sleep(80);
// myban.ban("192.168.2.74");
// sleep(300);
uint i=0;
while (i<10) {
string ip = generateRandomIP();
cout << "Ban " << ip << endl;
myban.ban(ip);
sleep(30);
i++;
}
return 0;
}
Loading…
Cancel
Save