diff options
author | Adam Midvidy <amidvidy@gmail.com> | 2015-05-15 19:23:05 -0400 |
---|---|---|
committer | Adam Midvidy <amidvidy@gmail.com> | 2015-05-18 21:13:30 -0400 |
commit | 83fcf0163af5b2e87715afc589e730ccb9fd6a35 (patch) | |
tree | 026ce9c2ad70a02ef4303f6243521252e52903a4 /src/mongo/scripting | |
parent | 635897bdc5276db6f32a0a347644813b753644f4 (diff) | |
download | mongo-83fcf0163af5b2e87715afc589e730ccb9fd6a35.tar.gz |
SERVER-17608 implement OP_COMMAND in the shell
Diffstat (limited to 'src/mongo/scripting')
-rw-r--r-- | src/mongo/scripting/v8_db.cpp | 44 | ||||
-rw-r--r-- | src/mongo/scripting/v8_db.h | 4 |
2 files changed, 47 insertions, 1 deletions
diff --git a/src/mongo/scripting/v8_db.cpp b/src/mongo/scripting/v8_db.cpp index b33f9ddfac2..c4b45d29ad9 100644 --- a/src/mongo/scripting/v8_db.cpp +++ b/src/mongo/scripting/v8_db.cpp @@ -35,8 +35,9 @@ #include <boost/shared_ptr.hpp> #include "mongo/base/init.h" -#include "mongo/client/sasl_client_authenticate.h" +#include "mongo/base/status_with.h" #include "mongo/client/native_sasl_client_session.h" +#include "mongo/client/sasl_client_authenticate.h" #include "mongo/client/sasl_scramsha1_client_conversation.h" #include "mongo/db/namespace_string.h" #include "mongo/s/d_state.h" @@ -120,6 +121,9 @@ namespace mongo { scope->injectV8Method("logout", mongoLogout, proto); scope->injectV8Method("cursorFromId", mongoCursorFromId, proto); scope->injectV8Method("copyDatabaseWithSCRAM", mongoCopyDatabaseWithSCRAM, proto); + scope->injectV8Method("getClientRPCProtocols", mongoGetClientRPCProtocols, proto); + scope->injectV8Method("setClientRPCProtocols", mongoSetClientRPCProtocols, proto); + scope->injectV8Method("getServerRPCProtocols", mongoGetServerRPCProtocols, proto); fassert(16468, _mongoPrototypeManipulatorsFrozen); for (size_t i = 0; i < _mongoPrototypeManipulators.size(); ++i) @@ -495,6 +499,44 @@ namespace mongo { return scope->mongoToLZV8(inputObj, true); } + v8::Handle<v8::Value> mongoGetClientRPCProtocols(V8Scope* scope, const v8::Arguments& args) { + argumentCheck(args.Length() == 0, "getClientRPCProtocols takes no args"); + auto conn = getConnection(scope, args); + auto clientRPCProtocols = rpc::toString(conn->getClientRPCProtocols()); + if (!clientRPCProtocols.isOK()) { + return v8AssertionException(clientRPCProtocols.getStatus().reason()); + } + + // make an owned copy so we can safely pass a null-terminated string to v8 + auto protoStr = clientRPCProtocols.getValue().toString(); + return v8::String::New(protoStr.c_str()); + } + + v8::Handle<v8::Value> mongoSetClientRPCProtocols(V8Scope* scope, const v8::Arguments& args) { + argumentCheck(args.Length() == 1, "setClientRPCProtocols needs 1 arg"); + argumentCheck(args[0]->IsString(), + "first argument to setClientRPCProtocols must be a string"); + auto conn = getConnection(scope, args); + const auto rpcProtosStr = toSTLString(args[0]); + auto clientRPCProtocols = rpc::parseProtocolSet(rpcProtosStr); + if (!clientRPCProtocols.isOK()) { + return v8AssertionException(clientRPCProtocols.getStatus().reason()); + } + conn->setClientRPCProtocols(clientRPCProtocols.getValue()); + return v8::Undefined(); + } + + v8::Handle<v8::Value> mongoGetServerRPCProtocols(V8Scope* scope, const v8::Arguments& args) { + argumentCheck(args.Length() == 0, "getServerRPCProtocols takes no args"); + auto conn = getConnection(scope, args); + auto serverRPCProtocols = rpc::toString(conn->getServerRPCProtocols()); + if (!serverRPCProtocols.isOK()) { + return v8AssertionException(serverRPCProtocols.getStatus().reason()); + } + auto protoStr = serverRPCProtocols.getValue().toString(); + return v8::String::New(protoStr.c_str()); + } + /** * get cursor from v8 argument */ diff --git a/src/mongo/scripting/v8_db.h b/src/mongo/scripting/v8_db.h index 20094dbe663..07c9cb80a5c 100644 --- a/src/mongo/scripting/v8_db.h +++ b/src/mongo/scripting/v8_db.h @@ -54,6 +54,10 @@ namespace mongo { v8::Handle<v8::Value> mongoLogout(V8Scope* scope, const v8::Arguments& args); v8::Handle<v8::Value> mongoCursorFromId(V8Scope* scope, const v8::Arguments& args); v8::Handle<v8::Value> mongoCopyDatabaseWithSCRAM(V8Scope* scope, const v8::Arguments& args); + v8::Handle<v8::Value> mongoGetClientRPCProtocols(V8Scope* scope, const v8::Arguments& args); + v8::Handle<v8::Value> mongoSetClientRPCProtocols(V8Scope* scope, const v8::Arguments& args); + v8::Handle<v8::Value> mongoGetServerRPCProtocols(V8Scope* scope, const v8::Arguments& args); + // Cursor object v8::Handle<v8::Value> internalCursorCons(V8Scope* scope, const v8::Arguments& args); |