void SecureCellSeal::New(const Nan::FunctionCallbackInfo<v8::Value>& args) { if (args.IsConstructCall()) { if (args.Length() < 1) { ThrowParameterError("Secure Cell (Seal) constructor", "not enough arguments, expected master key"); args.GetReturnValue().SetUndefined(); return; } if (!args[0]->IsUint8Array()) { ThrowParameterError("Secure Cell (Seal) constructor", "master key is not a byte buffer, use ByteBuffer or Uint8Array"); args.GetReturnValue().SetUndefined(); return; } if (node::Buffer::Length(args[0]) == 0) { ThrowParameterError("Secure Cell (Seal) constructor", "master key is empty"); args.GetReturnValue().SetUndefined(); return; } std::vector<uint8_t> key((uint8_t*)(node::Buffer::Data(args[0])), (uint8_t*)(node::Buffer::Data(args[0]) + node::Buffer::Length(args[0]))); SecureCellSeal* obj = new SecureCellSeal(key); obj->Wrap(args.This()); args.GetReturnValue().Set(args.This()); } else { const int argc = 1; v8::Local<v8::Value> argv[argc] = {args[0]}; v8::Local<v8::Function> cons = Nan::New<v8::Function>(constructor); args.GetReturnValue().Set(Nan::NewInstance(cons, argc, argv).ToLocalChecked()); } }
void SecureCellContextImprint::New(const Nan::FunctionCallbackInfo<v8::Value>& args) { if (args.IsConstructCall()) { std::vector<uint8_t> key((uint8_t*)(node::Buffer::Data(args[0])), (uint8_t*)(node::Buffer::Data(args[0])+node::Buffer::Length(args[0]))); SecureCellContextImprint* obj = new SecureCellContextImprint(key); obj->Wrap(args.This()); args.GetReturnValue().Set(args.This()); } else { const int argc = 1; v8::Local<v8::Value> argv[argc] = { args[0]}; v8::Local<v8::Function> cons = Nan::New<v8::Function>(constructor); args.GetReturnValue().Set(cons->NewInstance(argc, argv)); } }
void MeCab_Tagger::New(const Nan::FunctionCallbackInfo<v8::Value>& info) { if (info.IsConstructCall()) { v8::String::Utf8Value option(info[0]); MeCab_Tagger* mecabTagger = new MeCab_Tagger(*option); mecabTagger->Wrap(info.This()); info.GetReturnValue().Set(info.This()); } else { const int argc = 1; v8::Local<v8::Value> argv[argc] = { info[0] }; v8::Local<v8::Function> cons = Nan::New<v8::Function>(constructor); info.GetReturnValue().Set(cons->NewInstance(argc, argv)); } }
void Client::New(const Nan::FunctionCallbackInfo<v8::Value>& info) { if (info.IsConstructCall()) { v8::String::Utf8Value param0(info[0]->ToString()); std::string* param0String = new std::string(*param0); const char* conf = param0String->c_str(); Client* obj = new Client(conf); obj->Wrap(info.This()); info.GetReturnValue().Set(info.This()); } else { const int argc = 1; v8::Local<v8::Value> argv[argc] = { info[0] }; v8::Local<v8::Function> cons = Nan::New<v8::Function>(constructor); info.GetReturnValue().Set(cons->NewInstance(argc, argv)); } }
void SecureCellSeal::encrypt(const Nan::FunctionCallbackInfo<v8::Value>& args) { themis_status_t status = THEMIS_FAIL; SecureCellSeal* obj = Nan::ObjectWrap::Unwrap<SecureCellSeal>(args.This()); if (args.Length() < 1) { ThrowParameterError("Secure Cell (Seal) failed to encrypt", "not enough arguments, expected message"); args.GetReturnValue().SetUndefined(); return; } if (!args[0]->IsUint8Array()) { ThrowParameterError("Secure Cell (Seal) failed to encrypt", "message is not a byte buffer, use ByteBuffer or Uint8Array"); args.GetReturnValue().SetUndefined(); return; } if (node::Buffer::Length(args[0]) == 0) { ThrowParameterError("Secure Cell (Seal) failed to encrypt", "message is empty"); args.GetReturnValue().SetUndefined(); return; } size_t length = 0; const uint8_t* context = NULL; size_t context_length = 0; if (args.Length() == 2) { if (!args[1]->IsUint8Array()) { ThrowParameterError("Secure Cell (Seal) failed to encrypt", "context is not a byte buffer, use ByteBuffer or Uint8Array"); args.GetReturnValue().SetUndefined(); return; } context = (const uint8_t*)(node::Buffer::Data(args[1])); context_length = node::Buffer::Length(args[1]); } status = themis_secure_cell_encrypt_seal(&(obj->key_)[0], obj->key_.size(), context, context_length, (const uint8_t*)(node::Buffer::Data(args[0])), node::Buffer::Length(args[0]), NULL, &length); if (status != THEMIS_BUFFER_TOO_SMALL) { ThrowError("Secure Cell (Seal) failed to encrypt", status); args.GetReturnValue().SetUndefined(); return; } uint8_t* data = (uint8_t*)(malloc(length)); status = themis_secure_cell_encrypt_seal(&(obj->key_)[0], obj->key_.size(), context, context_length, (const uint8_t*)(node::Buffer::Data(args[0])), node::Buffer::Length(args[0]), data, &length); if (status != THEMIS_SUCCESS) { ThrowError("Secure Cell (Seal) failed to encrypt", status); free(data); args.GetReturnValue().SetUndefined(); return; } args.GetReturnValue().Set(Nan::NewBuffer((char*)(data), length).ToLocalChecked()); }
void SecureCellContextImprint::decrypt(const Nan::FunctionCallbackInfo<v8::Value>& args) { SecureCellContextImprint* obj = Nan::ObjectWrap::Unwrap<SecureCellContextImprint>(args.This()); size_t length=0; const uint8_t* context=(const uint8_t*)(node::Buffer::Data(args[1])); size_t context_length=node::Buffer::Length(args[1]); if(themis_secure_cell_decrypt_context_imprint(&(obj->key_)[0], obj->key_.size(), (const uint8_t*)(node::Buffer::Data(args[0])), node::Buffer::Length(args[0]), context, context_length, NULL, &length)!=THEMIS_BUFFER_TOO_SMALL){ Nan::ThrowError("Secure Cell (Context Imprint) failed decrypting"); args.GetReturnValue().SetUndefined(); return; } uint8_t* data=(uint8_t*)(malloc(length)); if(themis_secure_cell_decrypt_context_imprint(&(obj->key_)[0], obj->key_.size(), (const uint8_t*)(node::Buffer::Data(args[0])), node::Buffer::Length(args[0]), context, context_length, data, &length)!=THEMIS_SUCCESS){ Nan::ThrowError("Secure Cell (Context Imprint) failed decrypting"); free(data); args.GetReturnValue().SetUndefined(); return; } args.GetReturnValue().Set(Nan::NewBuffer((char*)(data), length).ToLocalChecked()); }
static void Method( const Nan::FunctionCallbackInfo<v8::Value>& info) { T* obj = ObjectWrap::Unwrap<T>(info.This()); (obj->*m)(info); }