#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() { } ~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 ReadInject(const v8::Arguments& args); static v8::Handle ReadExtract(const v8::Arguments& args); static v8::Handle ReadPending(const v8::Arguments& args); static v8::Handle WriteCanExtract(const v8::Arguments& args); static v8::Handle WriteExtract(const v8::Arguments& args); static v8::Handle WriteInject(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() { } ~SecureStream() { } private: BIO *pbioRead; BIO *pbioWrite; SSL *pSSL; bool server; bool shouldVerify; }; void InitCrypto(v8::Handle target); } #endif // SRC_NODE_CRYPTO_H_