mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 00:28:26 -05:00
Modules: expose real client on conn events.
When REDISMODULE_EVENT_CLIENT_CHANGE events are delivered, modules may want to mutate the client state (e.g. perform authentication). This change links the module context with the real client rather than a fake client for these events.
This commit is contained in:
parent
cfccfbd6f4
commit
67b43f75e2
13
src/module.c
13
src/module.c
@ -7264,6 +7264,7 @@ void moduleFireServerEvent(uint64_t eid, int subid, void *data) {
|
||||
* cheap if there are no registered modules. */
|
||||
if (listLength(RedisModule_EventListeners) == 0) return;
|
||||
|
||||
int real_client_used = 0;
|
||||
listIter li;
|
||||
listNode *ln;
|
||||
listRewind(RedisModule_EventListeners,&li);
|
||||
@ -7273,7 +7274,15 @@ void moduleFireServerEvent(uint64_t eid, int subid, void *data) {
|
||||
RedisModuleCtx ctx = REDISMODULE_CTX_INIT;
|
||||
ctx.module = el->module;
|
||||
|
||||
if (ModulesInHooks == 0) {
|
||||
if (eid == REDISMODULE_EVENT_CLIENT_CHANGE) {
|
||||
/* In the case of client changes, we're pushing the real client
|
||||
* so the event handler can mutate it if needed. For example,
|
||||
* to change its authentication state in a way that does not
|
||||
* depend on specific commands executed later.
|
||||
*/
|
||||
ctx.client = (client *) data;
|
||||
real_client_used = 1;
|
||||
} else if (ModulesInHooks == 0) {
|
||||
ctx.client = moduleFreeContextReusedClient;
|
||||
} else {
|
||||
ctx.client = createClient(NULL);
|
||||
@ -7326,7 +7335,7 @@ void moduleFireServerEvent(uint64_t eid, int subid, void *data) {
|
||||
el->module->in_hook--;
|
||||
ModulesInHooks--;
|
||||
|
||||
if (ModulesInHooks != 0) freeClient(ctx.client);
|
||||
if (ModulesInHooks != 0 && !real_client_used) freeClient(ctx.client);
|
||||
moduleFreeContext(&ctx);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user