diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /security/manager/ssl/nsClientAuthRemember.h | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'security/manager/ssl/nsClientAuthRemember.h')
-rw-r--r-- | security/manager/ssl/nsClientAuthRemember.h | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/security/manager/ssl/nsClientAuthRemember.h b/security/manager/ssl/nsClientAuthRemember.h new file mode 100644 index 0000000000..ec9101739a --- /dev/null +++ b/security/manager/ssl/nsClientAuthRemember.h @@ -0,0 +1,101 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * + * 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 __NSCLIENTAUTHREMEMBER_H__ +#define __NSCLIENTAUTHREMEMBER_H__ + +#include <utility> + +#include "mozilla/Attributes.h" +#include "mozilla/DataMutex.h" +#include "mozilla/HashFunctions.h" +#include "mozilla/ReentrantMonitor.h" +#include "nsIClientAuthRememberService.h" +#include "nsIDataStorage.h" +#include "nsIObserver.h" +#include "nsNSSCertificate.h" +#include "nsString.h" +#include "nsTHashtable.h" +#include "nsWeakReference.h" + +namespace mozilla { +class OriginAttributes; +} + +using mozilla::OriginAttributes; + +class nsClientAuthRemember final : public nsIClientAuthRememberRecord { + public: + NS_DECL_THREADSAFE_ISUPPORTS + NS_DECL_NSICLIENTAUTHREMEMBERRECORD + + nsClientAuthRemember(const nsACString& aHostName, + const OriginAttributes& aOriginAttributes) { + mAsciiHost.Assign(aHostName); + aOriginAttributes.CreateSuffix(mOriginAttributesSuffix); + } + + nsClientAuthRemember(const nsCString& aEntryKey, const nsCString& aDBKey) { + if (!aDBKey.Equals(nsClientAuthRemember::SentinelValue)) { + mDBKey = aDBKey; + } + + size_t field_index = 0; + for (const auto& field : aEntryKey.Split(',')) { + switch (field_index) { + case 0: + mAsciiHost.Assign(field); + break; + case 1: + break; + case 2: + mOriginAttributesSuffix.Assign(field); + break; + default: + break; + } + field_index++; + } + } + + nsCString mAsciiHost; + nsCString mOriginAttributesSuffix; + nsCString mDBKey; + static const nsCString SentinelValue; + + protected: + ~nsClientAuthRemember() = default; +}; + +class nsClientAuthRememberService final : public nsIClientAuthRememberService { + public: + NS_DECL_THREADSAFE_ISUPPORTS + NS_DECL_NSICLIENTAUTHREMEMBERSERVICE + + nsClientAuthRememberService() + : mMigrated(false, "nsClientAuthRememberService::mMigrated") {} + + nsresult Init(); + + static bool IsPrivateBrowsingKey(const nsCString& entryKey); + + protected: + ~nsClientAuthRememberService() = default; + + static nsIDataStorage::DataType GetDataStorageType( + const OriginAttributes& aOriginAttributes); + + nsCOMPtr<nsIDataStorage> mClientAuthRememberList; + + nsresult AddEntryToList(const nsACString& aHost, + const OriginAttributes& aOriginAttributes, + const nsACString& aDBKey); + + mozilla::DataMutex<bool> mMigrated; + void Migrate(); +}; + +#endif |