Dont save request if trigger is not set

This commit is contained in:
ruti 2024-10-15 06:20:58 +03:00
parent 6ce89b63aa
commit ed7708c4e7
3 changed files with 22 additions and 15 deletions

View File

@ -220,7 +220,7 @@ int on_torst(struct poolhd *pool, struct eval *val)
bool can_reconn = (
val->pair->buff.data && !val->recv_count
);
if (can_reconn || params.auto_level >= 1) {
if (can_reconn || params.auto_level > AUTO_NOSAVE) {
for (; m < params.dp_count; m++) {
struct desync_params *dp = &params.dp[m];
if (!dp->detect) {
@ -260,7 +260,7 @@ int on_fin(struct poolhd *pool, struct eval *val)
bool can_reconn = (
val->pair->buff.data && !val->recv_count
);
if (!can_reconn && params.auto_level < 1) {
if (!can_reconn && params.auto_level <= AUTO_NOSAVE) {
return -1;
}
bool ssl_err = 0;
@ -338,7 +338,7 @@ static inline void free_first_req(struct eval *client)
}
ssize_t on_first_send(struct eval *client, char *buffer, ssize_t bfsize)
ssize_t on_first_send(struct eval *client, char *buffer, ssize_t n, ssize_t bfsize)
{
int m = client->attempt;
@ -354,8 +354,8 @@ ssize_t on_first_send(struct eval *client, char *buffer, ssize_t bfsize)
if (m >= params.dp_count) {
return -1;
}
if (params.auto_level > 0 && params.dp_count > 1) {
client->mark = is_tls_chello(client->buff.data, client->buff.size);
if (params.auto_level > AUTO_NOSAVE && params.dp_count > 1) {
client->mark = is_tls_chello(buffer, n);
}
client->attempt = m;
@ -363,10 +363,12 @@ ssize_t on_first_send(struct eval *client, char *buffer, ssize_t bfsize)
&& set_timeout(client->pair->fd, params.timeout)) {
return -1;
}
assert(bfsize >= client->buff.size);
memcpy(buffer, client->buff.data, client->buff.size);
return client->buff.size;
if (client->buff.locked) {
assert(bfsize >= client->buff.size);
memcpy(buffer, client->buff.data, client->buff.size);
return client->buff.size;
}
return n;
}
@ -387,7 +389,7 @@ ssize_t tcp_send_hook(struct poolhd *pool, struct eval *remote,
int m = client->attempt;
if (client->recv_count == n) {
n = on_first_send(client, buffer, bfsize);
n = on_first_send(client, buffer, n, bfsize);
if (n < 0) {
return -1;
}
@ -427,7 +429,9 @@ ssize_t tcp_recv_hook(struct poolhd *pool, struct eval *val,
return -1;
}
if (val->flag != FLAG_CONN && val->pair->recv_count == 0)
if (val->flag != FLAG_CONN
&& params.auto_level > AUTO_NOBUFF
&& val->pair->recv_count == 0)
{
val->buff.size += n;
@ -452,7 +456,7 @@ ssize_t tcp_recv_hook(struct poolhd *pool, struct eval *val,
}
free_first_req(val->pair);
}
if (params.timeout && params.auto_level < 1 &&
if (params.timeout && params.auto_level <= AUTO_NOSAVE &&
set_timeout(val->fd, 0)) {
return -1;
}

6
main.c
View File

@ -56,7 +56,7 @@ struct params params = {
},
.repeats = 1,
.debug = 0,
.auto_level = -1
.auto_level = AUTO_NOBUFF
};
@ -659,8 +659,8 @@ int main(int argc, char **argv)
end = strchr(end, ',');
if (end) end++;
}
if (dp->detect && params.auto_level == -1) {
params.auto_level = 0;
if (dp->detect && params.auto_level == AUTO_NOBUFF) {
params.auto_level = AUTO_NOSAVE;
}
break;

View File

@ -31,6 +31,9 @@
#define DETECT_TLS_ERR 2
#define DETECT_TORST 8
#define AUTO_NOBUFF -1
#define AUTO_NOSAVE 0
enum demode {
DESYNC_NONE,
DESYNC_SPLIT,