privatekeypublicationhandler.cxx
来自「这是国外的resip协议栈」· CXX 代码 · 共 75 行
CXX
75 行
#if defined(USE_SSL)#include "resip/stack/Security.hxx"#include "resip/stack/Pkcs8Contents.hxx"#include "resip/dum/ServerPublication.hxx"#include "repro/stateAgents/PrivateKeyPublicationHandler.hxx"using namespace repro;using namespace resip;PrivateKeyPublicationHandler::PrivateKeyPublicationHandler(Security& security) : mSecurity(security){}void PrivateKeyPublicationHandler::onInitial(ServerPublicationHandle h, const Data& etag, const SipMessage& pub, const Contents* contents, const SecurityAttributes* attrs, UInt32 expires){ add(h, contents);}void PrivateKeyPublicationHandler::onExpired(ServerPublicationHandle h, const Data& etag){ mSecurity.removeUserPrivateKey(h->getPublisher());}void PrivateKeyPublicationHandler::onRefresh(ServerPublicationHandle, const Data& etag, const SipMessage& pub, const Contents* contents, const SecurityAttributes* attrs, UInt32 expires){}void PrivateKeyPublicationHandler::onUpdate(ServerPublicationHandle h, const Data& etag, const SipMessage& pub, const Contents* contents, const SecurityAttributes* attrs, UInt32 expires){ add(h, contents);}void PrivateKeyPublicationHandler::onRemoved(ServerPublicationHandle h, const Data& etag, const SipMessage& pub, UInt32 expires){ mSecurity.removeUserPrivateKey(h->getPublisher());}void PrivateKeyPublicationHandler::add(ServerPublicationHandle h, const Contents* contents){ if (h->getDocumentKey() == h->getPublisher()) { const Pkcs8Contents* pkcs8 = dynamic_cast<const Pkcs8Contents*>(contents); assert(pkcs8); mSecurity.addUserPrivateKeyDER(h->getPublisher(), pkcs8->getBodyData()); } else { h->send(h->accept(403)); // !jf! is this the correct code? }}#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?