| Index: talk/app/webrtc/webrtcsessiondescriptionfactory.h
|
| diff --git a/talk/app/webrtc/webrtcsessiondescriptionfactory.h b/talk/app/webrtc/webrtcsessiondescriptionfactory.h
|
| index 860532dec93e56253f09b95bab031ab2df477e44..4a98f2025349fa84fcb834e630e977f22b87e9f2 100644
|
| --- a/talk/app/webrtc/webrtcsessiondescriptionfactory.h
|
| +++ b/talk/app/webrtc/webrtcsessiondescriptionfactory.h
|
| @@ -28,6 +28,8 @@
|
| #ifndef TALK_APP_WEBRTC_WEBRTCSESSIONDESCRIPTIONFACTORY_H_
|
| #define TALK_APP_WEBRTC_WEBRTCSESSIONDESCRIPTIONFACTORY_H_
|
|
|
| +#include "talk/app/webrtc/dtlscertificate.h"
|
| +#include "talk/app/webrtc/dtlsidentitystore.h"
|
| #include "talk/app/webrtc/peerconnectioninterface.h"
|
| #include "webrtc/p2p/base/transportdescriptionfactory.h"
|
| #include "talk/session/media/mediasession.h"
|
| @@ -57,7 +59,7 @@ class WebRtcIdentityRequestObserver : public DTLSIdentityRequestObserver,
|
| rtc::scoped_ptr<rtc::SSLIdentity> identity) override;
|
|
|
| sigslot::signal1<int> SignalRequestFailed;
|
| - sigslot::signal1<rtc::SSLIdentity*> SignalIdentityReady;
|
| + sigslot::signal1<rtc::scoped_refptr<DtlsCertificate>> SignalCertificateReady;
|
| };
|
|
|
| struct CreateSessionDescriptionRequest {
|
| @@ -89,9 +91,10 @@ class WebRtcSessionDescriptionFactory : public rtc::MessageHandler,
|
| public:
|
| WebRtcSessionDescriptionFactory(
|
| rtc::Thread* signaling_thread,
|
| + rtc::Thread* worker_thread,
|
| cricket::ChannelManager* channel_manager,
|
| MediaStreamSignaling* mediastream_signaling,
|
| - DTLSIdentityServiceInterface* dtls_identity_service,
|
| + rtc::scoped_refptr<DtlsCertificate> certificate,
|
| // TODO(jiayl): remove the dependency on session once b/10226852 is fixed.
|
| WebRtcSession* session,
|
| const std::string& session_id,
|
| @@ -113,19 +116,19 @@ class WebRtcSessionDescriptionFactory : public rtc::MessageHandler,
|
| void SetSdesPolicy(cricket::SecurePolicy secure_policy);
|
| cricket::SecurePolicy SdesPolicy() const;
|
|
|
| - sigslot::signal1<rtc::SSLIdentity*> SignalIdentityReady;
|
| + sigslot::signal1<rtc::scoped_refptr<DtlsCertificate>> SignalCertificateReady;
|
|
|
| // For testing.
|
| - bool waiting_for_identity() const {
|
| - return identity_request_state_ == IDENTITY_WAITING;
|
| + bool waiting_for_certificate() const {
|
| + return certificate_request_state_ == CERTIFICATE_WAITING;
|
| }
|
|
|
| private:
|
| - enum IdentityRequestState {
|
| - IDENTITY_NOT_NEEDED,
|
| - IDENTITY_WAITING,
|
| - IDENTITY_SUCCEEDED,
|
| - IDENTITY_FAILED,
|
| + enum CertificateRequestState {
|
| + CERTIFICATE_NOT_NEEDED,
|
| + CERTIFICATE_WAITING,
|
| + CERTIFICATE_SUCCEEDED,
|
| + CERTIFICATE_FAILED,
|
| };
|
|
|
| // MessageHandler implementation.
|
| @@ -143,21 +146,24 @@ class WebRtcSessionDescriptionFactory : public rtc::MessageHandler,
|
| SessionDescriptionInterface* description);
|
|
|
| void OnIdentityRequestFailed(int error);
|
| - void SetIdentity(rtc::SSLIdentity* identity);
|
| + void SetCertificate(rtc::scoped_refptr<DtlsCertificate> certificate);
|
|
|
| std::queue<CreateSessionDescriptionRequest>
|
| create_session_description_requests_;
|
| rtc::Thread* const signaling_thread_;
|
| + rtc::Thread* const worker_thread_;
|
| MediaStreamSignaling* const mediastream_signaling_;
|
| cricket::TransportDescriptionFactory transport_desc_factory_;
|
| cricket::MediaSessionDescriptionFactory session_desc_factory_;
|
| uint64 session_version_;
|
| + rtc::scoped_refptr<DtlsCertificate> certificate_;
|
| + rtc::scoped_ptr<DtlsIdentityStore> identity_store_;
|
| rtc::scoped_ptr<DTLSIdentityServiceInterface> identity_service_;
|
| rtc::scoped_refptr<WebRtcIdentityRequestObserver> identity_request_observer_;
|
| WebRtcSession* const session_;
|
| const std::string session_id_;
|
| const cricket::DataChannelType data_channel_type_;
|
| - IdentityRequestState identity_request_state_;
|
| + CertificateRequestState certificate_request_state_;
|
|
|
| DISALLOW_COPY_AND_ASSIGN(WebRtcSessionDescriptionFactory);
|
| };
|
|
|