Compare commits

...

2 Commits

Author SHA1 Message Date
wmasilva b3315ebd84
Merge 23bd922055 into 5cb74797fe 2025-01-17 16:41:26 +00:00
Antonio Silva 23bd922055 mod_hash: add select_limit and delete_limit to api command 2024-07-03 15:14:45 +01:00
1 changed files with 18 additions and 1 deletions

View File

@ -469,7 +469,7 @@ SWITCH_STANDARD_APP(hash_function)
switch_safe_free(hash_key);
}
#define HASH_API_USAGE "insert|insert_ifempty|select|delete|delete_ifmatch/realm/key[/value]"
#define HASH_API_USAGE "insert|insert_ifempty|select|delete|delete_ifmatch|select_limit|delete_limit/realm/key[/value]"
SWITCH_STANDARD_API(hash_api_function)
{
int argc = 0;
@ -547,6 +547,23 @@ SWITCH_STANDARD_API(hash_api_function)
stream->write_function(stream, "%s", value);
}
switch_thread_rwlock_unlock(globals.db_hash_rwlock);
} else if (!strcasecmp(argv[0], "select_limit")) {
limit_hash_item_t *item = NULL;
switch_thread_rwlock_rdlock(globals.limit_hash_rwlock);
if ((item = switch_core_hash_find(globals.limit_hash, hash_key))) {
stream->write_function(stream, "%d", item->total_usage);
}
switch_thread_rwlock_unlock(globals.limit_hash_rwlock);
} else if (!strcasecmp(argv[0], "delete_limit")) {
limit_hash_item_t *item = NULL;
switch_thread_rwlock_rdlock(globals.limit_hash_rwlock);
if ((item = switch_core_hash_find(globals.limit_hash, hash_key))) {
switch_core_hash_delete(globals.limit_hash, hash_key);
stream->write_function(stream, "+OK\n");
} else {
stream->write_function(stream, "-ERR Not found\n");
}
switch_thread_rwlock_unlock(globals.limit_hash_rwlock);
} else {
goto usage;
}