mirror of
https://git.haproxy.org/git/haproxy.git/
synced 2025-08-11 01:26:58 +02:00
CLEANUP: peers: factor error handling in peer_treat_definedmsg()
This is a trivial code refactoring of similar parsing error code under a single label.
This commit is contained in:
parent
1e82a14c34
commit
6f731f33ac
54
src/peers.c
54
src/peers.c
@ -1396,25 +1396,16 @@ static inline int peer_treat_definemsg(struct appctx *appctx, struct peer *p,
|
||||
uint64_t table_data;
|
||||
|
||||
table_id = intdecode(msg_cur, msg_end);
|
||||
if (!*msg_cur) {
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
if (!*msg_cur)
|
||||
goto malformed_exit;
|
||||
|
||||
table_id_len = intdecode(msg_cur, msg_end);
|
||||
if (!*msg_cur) {
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
if (!*msg_cur)
|
||||
goto malformed_exit;
|
||||
|
||||
p->remote_table = NULL;
|
||||
if (!table_id_len || (*msg_cur + table_id_len) >= msg_end) {
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
if (!table_id_len || (*msg_cur + table_id_len) >= msg_end)
|
||||
goto malformed_exit;
|
||||
|
||||
for (st = p->tables; st; st = st->next) {
|
||||
/* Reset IDs */
|
||||
@ -1430,32 +1421,20 @@ static inline int peer_treat_definemsg(struct appctx *appctx, struct peer *p,
|
||||
goto ignore_msg;
|
||||
|
||||
*msg_cur += table_id_len;
|
||||
if (*msg_cur >= msg_end) {
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
if (*msg_cur >= msg_end)
|
||||
goto malformed_exit;
|
||||
|
||||
table_type = intdecode(msg_cur, msg_end);
|
||||
if (!*msg_cur) {
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
if (!*msg_cur)
|
||||
goto malformed_exit;
|
||||
|
||||
table_keylen = intdecode(msg_cur, msg_end);
|
||||
if (!*msg_cur) {
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
if (!*msg_cur)
|
||||
goto malformed_exit;
|
||||
|
||||
table_data = intdecode(msg_cur, msg_end);
|
||||
if (!*msg_cur) {
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
if (!*msg_cur)
|
||||
goto malformed_exit;
|
||||
|
||||
if (p->remote_table->table->type != table_type
|
||||
|| p->remote_table->table->key_size != table_keylen) {
|
||||
@ -1470,6 +1449,11 @@ static inline int peer_treat_definemsg(struct appctx *appctx, struct peer *p,
|
||||
ignore_msg:
|
||||
co_skip(si_oc(si), totl);
|
||||
return 0;
|
||||
|
||||
malformed_exit:
|
||||
/* malformed message */
|
||||
appctx->st0 = PEER_SESS_ST_ERRPROTO;
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user