aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/kvstorage_server.c42
-rw-r--r--src/kvstorage_server.h1
2 files changed, 40 insertions, 3 deletions
diff --git a/src/kvstorage_server.c b/src/kvstorage_server.c
index 620c5c73f..d91eaa1c8 100644
--- a/src/kvstorage_server.c
+++ b/src/kvstorage_server.c
@@ -204,7 +204,7 @@ parse_kvstorage_command (struct kvstorage_session *session, f_str_t *in)
state = 100;
continue;
}
- if (g_ascii_strncasecmp (c, "sync", 4) == 0) {
+ if (g_ascii_strncasecmp (c, "sync", 4) == 0 || g_ascii_strncasecmp (c, "save", 4) == 0) {
session->command = KVSTORAGE_CMD_SYNC;
state = 100;
continue;
@@ -214,7 +214,12 @@ parse_kvstorage_command (struct kvstorage_session *session, f_str_t *in)
if (g_ascii_strncasecmp (c, "delete", 6) == 0) {
session->command = KVSTORAGE_CMD_DELETE;
}
-
+ else if (g_ascii_strncasecmp (c, "select", 6) == 0) {
+ session->command = KVSTORAGE_CMD_SELECT;
+ state = 99;
+ next_state = 6;
+ continue;
+ }
else {
return FALSE;
}
@@ -311,6 +316,21 @@ parse_kvstorage_command (struct kvstorage_session *session, f_str_t *in)
}
}
break;
+ case 6:
+ /* Read index of storage */
+ if (g_ascii_isdigit (*p)) {
+ p ++;
+ }
+ else {
+ if (g_ascii_isspace (*p) || end == p) {
+ session->id = strtoul (c, NULL, 10);
+ state = 100;
+ }
+ else {
+ return FALSE;
+ }
+ }
+ break;
case 99:
/* Skip spaces state */
if (g_ascii_isspace (*p)) {
@@ -374,8 +394,14 @@ kvstorage_read_socket (f_str_t * in, void *arg)
session->cf = get_kvstorage_config (session->id);
if (session->cf == NULL) {
thr_info ("%ud: bad keystorage: %ud", thr->id, session->id);
- return rspamd_dispatcher_write (session->dispather, ERROR_INVALID_KEYSTORAGE,
+ if (!is_redis) {
+ return rspamd_dispatcher_write (session->dispather, ERROR_INVALID_KEYSTORAGE,
sizeof (ERROR_INVALID_KEYSTORAGE) - 1, FALSE, TRUE);
+ }
+ else {
+ return rspamd_dispatcher_write (session->dispather, "-ERR unknown keystorage" CRLF,
+ sizeof ("-ERR unknown keystorage" CRLF) - 1, FALSE, TRUE);
+ }
}
if (session->command == KVSTORAGE_CMD_SET) {
session->state = KVSTORAGE_STATE_READ_DATA;
@@ -495,6 +521,16 @@ kvstorage_read_socket (f_str_t * in, void *arg)
}
g_static_rw_lock_writer_lock (&session->cf->storage->rwlock);
}
+ else if (session->command == KVSTORAGE_CMD_SELECT) {
+ if (!is_redis) {
+ return rspamd_dispatcher_write (session->dispather, "SELECTED" CRLF,
+ sizeof ("SELECTED" CRLF) - 1, FALSE, TRUE);
+ }
+ else {
+ return rspamd_dispatcher_write (session->dispather, "+OK" CRLF,
+ sizeof ("+OK" CRLF) - 1, FALSE, TRUE);
+ }
+ }
else if (session->command == KVSTORAGE_CMD_QUIT) {
/* Quit session */
free_kvstorage_session (session);
diff --git a/src/kvstorage_server.h b/src/kvstorage_server.h
index 3b475ebd0..2d4a3fa89 100644
--- a/src/kvstorage_server.h
+++ b/src/kvstorage_server.h
@@ -66,6 +66,7 @@ struct kvstorage_session {
KVSTORAGE_CMD_GET,
KVSTORAGE_CMD_DELETE,
KVSTORAGE_CMD_SYNC,
+ KVSTORAGE_CMD_SELECT,
KVSTORAGE_CMD_QUIT
} command;
guint id;