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/KeychainSecret.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/KeychainSecret.h')
-rw-r--r-- | security/manager/ssl/KeychainSecret.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/security/manager/ssl/KeychainSecret.h b/security/manager/ssl/KeychainSecret.h new file mode 100644 index 0000000000..7a0850a001 --- /dev/null +++ b/security/manager/ssl/KeychainSecret.h @@ -0,0 +1,49 @@ +/* -*- 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 KeychainSecret_h +#define KeychainSecret_h + +#include "CoreFoundation/CFBase.h" + +#include "OSKeyStore.h" +#include "nsString.h" + +template <typename T> +class ScopedCFType { + public: + explicit ScopedCFType(T value) : mValue(value) {} + + MOZ_IMPLICIT ScopedCFType(decltype(nullptr)) : mValue(nullptr) {} + + ~ScopedCFType() { + if (mValue) { + CFRelease((CFTypeRef)mValue); + } + } + + T get() { return mValue; } + + explicit operator bool() const { return mValue != nullptr; } + + private: + T mValue; +}; + +class KeychainSecret final : public AbstractOSKeyStore { + public: + KeychainSecret(); + + virtual nsresult RetrieveSecret(const nsACString& label, + /* out */ nsACString& secret) override; + virtual nsresult StoreSecret(const nsACString& secret, + const nsACString& label) override; + virtual nsresult DeleteSecret(const nsACString& label) override; + + virtual ~KeychainSecret(); +}; + +#endif // KeychainSecret_h |