#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 *ctx_; X509_STORE *ca_store_; 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 AddRootCerts(const v8::Arguments& args); static v8::Handle SetCiphers(const v8::Arguments& args); static v8::Handle Close(const v8::Arguments& args); SecureContext() : ObjectWrap() { ctx_ = NULL; ca_store_ = NULL; } ~SecureContext() { if (ctx_) { SSL_CTX_free(ctx_); ctx_ = NULL; } if (ca_store_) { X509_STORE_free(ca_store_); ca_store_ = NULL; } } 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 VerifyPeerError(const v8::Arguments& args); static v8::Handle GetCurrentCipher(const v8::Arguments& args); static v8::Handle Shutdown(const v8::Arguments& args); static v8::Handle Start(const v8::Arguments& args); static v8::Handle Close(const v8::Arguments& args); SecureStream() : ObjectWrap() { bio_read_ = bio_write_ = NULL; ssl_ = NULL; } ~SecureStream() { if (ssl_ != NULL) { SSL_free(ssl_); ssl_ = NULL; } } private: BIO *bio_read_; BIO *bio_write_; SSL *ssl_; bool is_server_; /* coverity[member_decl] */ bool should_verify_; /* coverity[member_decl] */ }; void InitCrypto(v8::Handle target); } #endif // SRC_NODE_CRYPTO_H_