X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/07bd133ff9a290ff7475c94c1578db3d0d91b853..519fd4f22bc83ba85a8377a7ada53fac4e2e2b39:/projects/sgauthstress/user.cpp diff --git a/projects/sgauthstress/user.cpp b/projects/sgauthstress/user.cpp index b36da5e1..944907fe 100644 --- a/projects/sgauthstress/user.cpp +++ b/projects/sgauthstress/user.cpp @@ -1,5 +1,7 @@ +#include #include #include +#include // close #include #include @@ -15,11 +17,12 @@ USER::USER(const std::string & l, : login(l), password(pwd), ip(i), - aliveTimeout(0), - userTimeout(0), + aliveTimeout(5), + userTimeout(60), phase(1), phaseChangeTime(0), - rnd(0) + rnd(0), + sock(-1) { unsigned char key[IA_PASSWD_LEN]; memset(key, 0, IA_PASSWD_LEN); @@ -35,7 +38,8 @@ USER::USER(const USER & rvalue) userTimeout(rvalue.userTimeout), phase(1), phaseChangeTime(0), - rnd(0) + rnd(0), + sock(-1) { unsigned char key[IA_PASSWD_LEN]; memset(key, 0, IA_PASSWD_LEN); @@ -45,10 +49,11 @@ Blowfish_Init(&ctx, key, IA_PASSWD_LEN); USER::~USER() { -close(sock); +if (sock > 0) + close(sock); } -const USER & USER::operator=(const USER & rvalue) +USER & USER::operator=(const USER & rvalue) { login = rvalue.login; password = rvalue.password; @@ -58,6 +63,7 @@ userTimeout = rvalue.userTimeout; phase = 1; phaseChangeTime = 0; rnd = 0; +sock = -1; unsigned char key[IA_PASSWD_LEN]; memset(key, 0, IA_PASSWD_LEN); @@ -71,6 +77,11 @@ bool USER::InitNetwork() { sock = socket(AF_INET, SOCK_DGRAM, 0); +if (sock < 0) + { + throw std::runtime_error(std::string("USER::USER() - socket creation error: '") + strerror(errno) + "', ip: " + inet_ntostring(ip) + ", login: " + login); + } + struct sockaddr_in addr; addr.sin_family = AF_INET; @@ -82,4 +93,6 @@ if (res == -1) { throw std::runtime_error(std::string("USER::USER() - bind error: '") + strerror(errno) + "', ip: " + inet_ntostring(ip) + ", login: " + login); } + +return true; }