|
|
@ -2308,15 +2308,18 @@ static char *cmd_auth_do(PGconn *conn, char *cmd, char *id, char *by, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
|
K_TREE *trf_root) |
|
|
|
K_TREE *trf_root) |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
K_TREE_CTX ctx[1]; |
|
|
|
char reply[1024] = ""; |
|
|
|
char reply[1024] = ""; |
|
|
|
size_t siz = sizeof(reply); |
|
|
|
size_t siz = sizeof(reply); |
|
|
|
K_ITEM *i_poolinstance, *i_username, *i_workername, *i_clientid; |
|
|
|
K_ITEM *i_poolinstance, *i_username, *i_workername, *i_clientid; |
|
|
|
K_ITEM *i_enonce1, *i_useragent, *i_preauth, *u_item, *oc_item; |
|
|
|
K_ITEM *i_enonce1, *i_useragent, *i_preauth, *u_item, *oc_item, *w_item; |
|
|
|
USERS *users = NULL; |
|
|
|
USERS *users = NULL; |
|
|
|
char *username; |
|
|
|
char *username; |
|
|
|
WORKERS *workers = NULL; |
|
|
|
WORKERS *workers = NULL; |
|
|
|
OPTIONCONTROL *optioncontrol; |
|
|
|
OPTIONCONTROL *optioncontrol; |
|
|
|
bool ok; |
|
|
|
size_t len, off; |
|
|
|
|
|
|
|
char *buf; |
|
|
|
|
|
|
|
bool ok, first; |
|
|
|
|
|
|
|
|
|
|
|
LOGDEBUG("%s(): cmd '%s'", __func__, cmd); |
|
|
|
LOGDEBUG("%s(): cmd '%s'", __func__, cmd); |
|
|
|
|
|
|
|
|
|
|
@ -2378,12 +2381,14 @@ static char *cmd_auth_do(PGconn *conn, char *cmd, char *id, char *by, |
|
|
|
if (!ok) { |
|
|
|
if (!ok) { |
|
|
|
LOGDEBUG("%s() %s.failed.DBE", __func__, id); |
|
|
|
LOGDEBUG("%s() %s.failed.DBE", __func__, id); |
|
|
|
return strdup("failed.DBE"); |
|
|
|
return strdup("failed.DBE"); |
|
|
|
} else { |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Only flag a successful auth
|
|
|
|
// Only flag a successful auth
|
|
|
|
ck_wlock(&last_lock); |
|
|
|
ck_wlock(&last_lock); |
|
|
|
setnow(&last_auth); |
|
|
|
setnow(&last_auth); |
|
|
|
ck_wunlock(&last_lock); |
|
|
|
ck_wunlock(&last_lock); |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (switch_state < SWITCH_STATE_AUTHWORKERS) { |
|
|
|
snprintf(reply, siz, |
|
|
|
snprintf(reply, siz, |
|
|
|
"ok.authorise={\"secondaryuserid\":\"%s\"," |
|
|
|
"ok.authorise={\"secondaryuserid\":\"%s\"," |
|
|
|
"\"difficultydefault\":%d}", |
|
|
|
"\"difficultydefault\":%d}", |
|
|
@ -2392,6 +2397,37 @@ static char *cmd_auth_do(PGconn *conn, char *cmd, char *id, char *by, |
|
|
|
return strdup(reply); |
|
|
|
return strdup(reply); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
APPEND_REALLOC_INIT(buf, off, len); |
|
|
|
|
|
|
|
snprintf(reply, siz, |
|
|
|
|
|
|
|
"ok.authorise={\"secondaryuserid\":\"%s\"," |
|
|
|
|
|
|
|
"\"workers\":[", |
|
|
|
|
|
|
|
users->secondaryuserid); |
|
|
|
|
|
|
|
APPEND_REALLOC(buf, off, len, reply); |
|
|
|
|
|
|
|
first = true; |
|
|
|
|
|
|
|
K_RLOCK(workers_free); |
|
|
|
|
|
|
|
w_item = first_workers(users->userid, ctx); |
|
|
|
|
|
|
|
DATA_WORKERS_NULL(workers, w_item); |
|
|
|
|
|
|
|
while (w_item && workers->userid == users->userid) { |
|
|
|
|
|
|
|
if (CURRENT(&(workers->expirydate))) { |
|
|
|
|
|
|
|
snprintf(reply, siz, |
|
|
|
|
|
|
|
"%s{\"workername\":\"%s\"," |
|
|
|
|
|
|
|
"\"difficultydefault\":%"PRId32"}", |
|
|
|
|
|
|
|
first ? EMPTY : ",", |
|
|
|
|
|
|
|
workers->workername, |
|
|
|
|
|
|
|
workers->difficultydefault); |
|
|
|
|
|
|
|
APPEND_REALLOC(buf, off, len, reply); |
|
|
|
|
|
|
|
first = false; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
w_item = next_in_ktree(ctx); |
|
|
|
|
|
|
|
DATA_WORKERS_NULL(workers, w_item); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
K_RUNLOCK(workers_free); |
|
|
|
|
|
|
|
APPEND_REALLOC(buf, off, len, "]}"); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LOGDEBUG("%s.%s", id, buf); |
|
|
|
|
|
|
|
return buf; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static char *cmd_auth(PGconn *conn, char *cmd, char *id, |
|
|
|
static char *cmd_auth(PGconn *conn, char *cmd, char *id, |
|
|
|
__maybe_unused tv_t *now, char *by, |
|
|
|
__maybe_unused tv_t *now, char *by, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
@ -2404,13 +2440,16 @@ static char *cmd_addrauth_do(PGconn *conn, char *cmd, char *id, char *by, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
|
K_TREE *trf_root) |
|
|
|
K_TREE *trf_root) |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
K_TREE_CTX ctx[1]; |
|
|
|
char reply[1024] = ""; |
|
|
|
char reply[1024] = ""; |
|
|
|
size_t siz = sizeof(reply); |
|
|
|
size_t siz = sizeof(reply); |
|
|
|
K_ITEM *i_poolinstance, *i_username, *i_workername, *i_clientid; |
|
|
|
K_ITEM *i_poolinstance, *i_username, *i_workername, *i_clientid; |
|
|
|
K_ITEM *i_enonce1, *i_useragent, *i_preauth; |
|
|
|
K_ITEM *i_enonce1, *i_useragent, *i_preauth, *w_item; |
|
|
|
USERS *users = NULL; |
|
|
|
USERS *users = NULL; |
|
|
|
WORKERS *workers = NULL; |
|
|
|
WORKERS *workers = NULL; |
|
|
|
bool ok; |
|
|
|
size_t len, off; |
|
|
|
|
|
|
|
char *buf; |
|
|
|
|
|
|
|
bool ok, first; |
|
|
|
|
|
|
|
|
|
|
|
LOGDEBUG("%s(): cmd '%s'", __func__, cmd); |
|
|
|
LOGDEBUG("%s(): cmd '%s'", __func__, cmd); |
|
|
|
|
|
|
|
|
|
|
@ -2456,12 +2495,14 @@ static char *cmd_addrauth_do(PGconn *conn, char *cmd, char *id, char *by, |
|
|
|
if (!ok) { |
|
|
|
if (!ok) { |
|
|
|
LOGDEBUG("%s() %s.failed.DBE", __func__, id); |
|
|
|
LOGDEBUG("%s() %s.failed.DBE", __func__, id); |
|
|
|
return strdup("failed.DBE"); |
|
|
|
return strdup("failed.DBE"); |
|
|
|
} else { |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Only flag a successful auth
|
|
|
|
// Only flag a successful auth
|
|
|
|
ck_wlock(&last_lock); |
|
|
|
ck_wlock(&last_lock); |
|
|
|
setnow(&last_auth); |
|
|
|
setnow(&last_auth); |
|
|
|
ck_wunlock(&last_lock); |
|
|
|
ck_wunlock(&last_lock); |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (switch_state < SWITCH_STATE_AUTHWORKERS) { |
|
|
|
snprintf(reply, siz, |
|
|
|
snprintf(reply, siz, |
|
|
|
"ok.addrauth={\"secondaryuserid\":\"%s\"," |
|
|
|
"ok.addrauth={\"secondaryuserid\":\"%s\"," |
|
|
|
"\"difficultydefault\":%d}", |
|
|
|
"\"difficultydefault\":%d}", |
|
|
@ -2470,6 +2511,37 @@ static char *cmd_addrauth_do(PGconn *conn, char *cmd, char *id, char *by, |
|
|
|
return strdup(reply); |
|
|
|
return strdup(reply); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
APPEND_REALLOC_INIT(buf, off, len); |
|
|
|
|
|
|
|
snprintf(reply, siz, |
|
|
|
|
|
|
|
"ok.addrauth={\"secondaryuserid\":\"%s\"," |
|
|
|
|
|
|
|
"\"workers\":[", |
|
|
|
|
|
|
|
users->secondaryuserid); |
|
|
|
|
|
|
|
APPEND_REALLOC(buf, off, len, reply); |
|
|
|
|
|
|
|
first = true; |
|
|
|
|
|
|
|
K_RLOCK(workers_free); |
|
|
|
|
|
|
|
w_item = first_workers(users->userid, ctx); |
|
|
|
|
|
|
|
DATA_WORKERS_NULL(workers, w_item); |
|
|
|
|
|
|
|
while (w_item && workers->userid == users->userid) { |
|
|
|
|
|
|
|
if (CURRENT(&(workers->expirydate))) { |
|
|
|
|
|
|
|
snprintf(reply, siz, |
|
|
|
|
|
|
|
"%s{\"workername\":\"%s\"," |
|
|
|
|
|
|
|
"\"difficultydefault\":%"PRId32"}", |
|
|
|
|
|
|
|
first ? EMPTY : ",", |
|
|
|
|
|
|
|
workers->workername, |
|
|
|
|
|
|
|
workers->difficultydefault); |
|
|
|
|
|
|
|
APPEND_REALLOC(buf, off, len, reply); |
|
|
|
|
|
|
|
first = false; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
w_item = next_in_ktree(ctx); |
|
|
|
|
|
|
|
DATA_WORKERS_NULL(workers, w_item); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
K_RUNLOCK(workers_free); |
|
|
|
|
|
|
|
APPEND_REALLOC(buf, off, len, "]}"); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
LOGDEBUG("%s.%s", id, buf); |
|
|
|
|
|
|
|
return buf; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static char *cmd_addrauth(PGconn *conn, char *cmd, char *id, |
|
|
|
static char *cmd_addrauth(PGconn *conn, char *cmd, char *id, |
|
|
|
__maybe_unused tv_t *now, char *by, |
|
|
|
__maybe_unused tv_t *now, char *by, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
|
char *code, char *inet, tv_t *cd, |
|
|
|