mod_mongo: add support for query options

This commit is contained in:
Chris Rienzo 2013-11-13 11:42:30 -05:00
parent e603c17de8
commit b90f2446d4
1 changed files with 36 additions and 3 deletions

View File

@ -43,6 +43,33 @@ static struct {
char *finalize; char *finalize;
} globals; } globals;
static int parse_query_options(char *query_options_str)
{
int query_options = 0;
if (strstr(query_options_str, "cursorTailable")) {
query_options |= QueryOption_CursorTailable;
}
if (strstr(query_options_str, "slaveOk")) {
query_options |= QueryOption_SlaveOk;
}
if (strstr(query_options_str, "oplogReplay")) {
query_options |= QueryOption_OplogReplay;
}
if (strstr(query_options_str, "noCursorTimeout")) {
query_options |= QueryOption_NoCursorTimeout;
}
if (strstr(query_options_str, "awaitData")) {
query_options |= QueryOption_AwaitData;
}
if (strstr(query_options_str, "exhaust")) {
query_options |= QueryOption_Exhaust;
}
if (strstr(query_options_str, "partialResults")) {
query_options |= QueryOption_PartialResults;
}
return query_options;
}
SWITCH_STANDARD_API(mongo_mapreduce_function) SWITCH_STANDARD_API(mongo_mapreduce_function)
{ {
switch_status_t status = SWITCH_STATUS_SUCCESS; switch_status_t status = SWITCH_STATUS_SUCCESS;
@ -101,11 +128,11 @@ SWITCH_STANDARD_API(mongo_mapreduce_function)
return status; return status;
} }
SWITCH_STANDARD_API(mongo_find_one_function) SWITCH_STANDARD_API(mongo_find_one_function)
{ {
switch_status_t status = SWITCH_STATUS_SUCCESS; switch_status_t status = SWITCH_STATUS_SUCCESS;
char *ns = NULL, *json_query = NULL, *json_fields = NULL; char *ns = NULL, *json_query = NULL, *json_fields = NULL, *query_options_str = NULL;
int query_options = 0;
ns = strdup(cmd); ns = strdup(cmd);
switch_assert(ns != NULL); switch_assert(ns != NULL);
@ -114,6 +141,12 @@ SWITCH_STANDARD_API(mongo_find_one_function)
*json_query++ = '\0'; *json_query++ = '\0';
if ((json_fields = strchr(json_query, DELIMITER))) { if ((json_fields = strchr(json_query, DELIMITER))) {
*json_fields++ = '\0'; *json_fields++ = '\0';
if ((query_options_str = strchr(json_fields, DELIMITER))) {
*query_options_str++ = '\0';
if (!zstr(query_options_str)) {
query_options = parse_query_options(query_options_str);
}
}
} }
} }
@ -127,7 +160,7 @@ SWITCH_STANDARD_API(mongo_find_one_function)
conn = mongo_connection_pool_get(globals.conn_pool); conn = mongo_connection_pool_get(globals.conn_pool);
if (conn) { if (conn) {
BSONObj res = conn->findOne(ns, Query(query), &fields); BSONObj res = conn->findOne(ns, Query(query), &fields, query_options);
mongo_connection_pool_put(globals.conn_pool, conn, SWITCH_FALSE); mongo_connection_pool_put(globals.conn_pool, conn, SWITCH_FALSE);
stream->write_function(stream, "-OK\n%s\n", res.jsonString().c_str()); stream->write_function(stream, "-OK\n%s\n", res.jsonString().c_str());