#ifndef SRC_NODE_CRYPTO_H_ #define SRC_NODE_CRYPTO_H_ #include #include #include #include #include #include #include #include #include #define EVP_F_EVP_DECRYPTFINAL 101 namespace node { class SecureContext : ObjectWrap { public: static void Initialize(v8::Handle target); SSL_CTX *pCtx; X509_STORE *caStore; protected: static v8::Handle New(const v8::Arguments& args); static v8::Handle Init(const v8::Arguments& args); static v8::Handle SetKey(const v8::Arguments& args); static v8::Handle SetCert(const v8::Arguments& args); static v8::Handle AddCACert(const v8::Arguments& args); static v8::Handle SetCiphers(const v8::Arguments& args); static v8::Handle Close(const v8::Arguments& args); SecureContext() : ObjectWrap() { pCtx = NULL; caStore = NULL; } ~SecureContext() { // Free up } private: }; class SecureStream : ObjectWrap { public: static void Initialize(v8::Handle target); protected: static v8::Handle New(const v8::Arguments& args); static v8::Handle EncIn(const v8::Arguments& args); static v8::Handle ClearOut(const v8::Arguments& args); static v8::Handle ClearPending(const v8::Arguments& args); static v8::Handle EncPending(const v8::Arguments& args); static v8::Handle EncOut(const v8::Arguments& args); static v8::Handle ClearIn(const v8::Arguments& args); static v8::Handle GetPeerCertificate(const v8::Arguments& args); static v8::Handle IsInitFinished(const v8::Arguments& args); static v8::Handle VerifyPeer(const v8::Arguments& args); static v8::Handle GetCurrentCipher(const v8::Arguments& args); static v8::Handle Shutdown(const v8::Arguments& args); static v8::Handle Close(const v8::Arguments& args); SecureStream() : ObjectWrap() { pbioRead = pbioWrite = NULL; pSSL = NULL; } ~SecureStream() { } private: BIO *pbioRead; BIO *pbioWrite; SSL *pSSL; bool server; /* coverity[member_decl] */ bool shouldVerify; /* coverity[member_decl] */ }; void InitCrypto(v8::Handle target); } #endif // SRC_NODE_CRYPTO_H_