diff options
Diffstat (limited to 'dom/media/webrtc/RTCCertificate.h')
-rw-r--r-- | dom/media/webrtc/RTCCertificate.h | 98 |
1 files changed, 98 insertions, 0 deletions
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<Promise> 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<JSObject*> 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<DtlsIdentity> 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<nsIGlobalObject> mGlobal; + UniqueSECKEYPrivateKey mPrivateKey; + UniqueCERTCertificate mCertificate; + SSLKEAType mAuthType; + PRTime mExpires; +}; + +} // namespace dom +} // namespace mozilla + +#endif // mozilla_dom_RTCCertificate_h |