From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- dom/media/webrtc/RTCCertificate.h | 98 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 98 insertions(+) create mode 100644 dom/media/webrtc/RTCCertificate.h (limited to 'dom/media/webrtc/RTCCertificate.h') diff --git a/dom/media/webrtc/RTCCertificate.h b/dom/media/webrtc/RTCCertificate.h new file mode 100644 index 000000000..63869849c --- /dev/null +++ b/dom/media/webrtc/RTCCertificate.h @@ -0,0 +1,98 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef mozilla_dom_RTCCertificate_h +#define mozilla_dom_RTCCertificate_h + +#include "nsCycleCollectionParticipant.h" +#include "nsWrapperCache.h" +#include "nsIGlobalObject.h" +#include "nsNSSShutDown.h" +#include "prtime.h" +#include "sslt.h" +#include "ScopedNSSTypes.h" + +#include "mozilla/ErrorResult.h" +#include "mozilla/UniquePtr.h" +#include "mozilla/RefPtr.h" +#include "mozilla/dom/CryptoKey.h" +#include "mozilla/dom/RTCCertificateBinding.h" +#include "mtransport/dtlsidentity.h" +#include "js/StructuredClone.h" +#include "js/TypeDecls.h" + +namespace mozilla { +namespace dom { + +class ObjectOrString; + +class RTCCertificate final + : public nsISupports, + public nsWrapperCache, + public nsNSSShutDownObject +{ +public: + NS_DECL_CYCLE_COLLECTING_ISUPPORTS + NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_CLASS(RTCCertificate) + + // WebIDL method that implements RTCPeerConnection.generateCertificate. + static already_AddRefed GenerateCertificate( + const GlobalObject& aGlobal, const ObjectOrString& aOptions, + ErrorResult& aRv, JSCompartment* aCompartment = nullptr); + + explicit RTCCertificate(nsIGlobalObject* aGlobal); + RTCCertificate(nsIGlobalObject* aGlobal, SECKEYPrivateKey* aPrivateKey, + CERTCertificate* aCertificate, SSLKEAType aAuthType, + PRTime aExpires); + + nsIGlobalObject* GetParentObject() const { return mGlobal; } + virtual JSObject* WrapObject(JSContext* aCx, + JS::Handle aGivenProto) override; + + // WebIDL expires attribute. Note: JS dates are milliseconds since epoch; + // NSPR PRTime is in microseconds since the same epoch. + uint64_t Expires() const + { + return mExpires / PR_USEC_PER_MSEC; + } + + // Accessors for use by PeerConnectionImpl. + RefPtr CreateDtlsIdentity() const; + const UniqueCERTCertificate& Certificate() const { return mCertificate; } + + // For nsNSSShutDownObject + virtual void virtualDestroyNSSReference() override; + void destructorSafeDestroyNSSReference(); + + // Structured clone methods + bool WriteStructuredClone(JSStructuredCloneWriter* aWriter) const; + bool ReadStructuredClone(JSStructuredCloneReader* aReader); + +private: + ~RTCCertificate(); + void operator=(const RTCCertificate&) = delete; + RTCCertificate(const RTCCertificate&) = delete; + + bool ReadCertificate(JSStructuredCloneReader* aReader, + const nsNSSShutDownPreventionLock& /*lockproof*/); + bool ReadPrivateKey(JSStructuredCloneReader* aReader, + const nsNSSShutDownPreventionLock& aLockProof); + bool WriteCertificate(JSStructuredCloneWriter* aWriter, + const nsNSSShutDownPreventionLock& /*lockproof*/) const; + bool WritePrivateKey(JSStructuredCloneWriter* aWriter, + const nsNSSShutDownPreventionLock& aLockProof) const; + + RefPtr mGlobal; + UniqueSECKEYPrivateKey mPrivateKey; + UniqueCERTCertificate mCertificate; + SSLKEAType mAuthType; + PRTime mExpires; +}; + +} // namespace dom +} // namespace mozilla + +#endif // mozilla_dom_RTCCertificate_h -- cgit v1.2.3