1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_K_ANONYMITY_SERVICE_K_ANONYMITY_SERVICE_STORAGE_H_
#define CHROME_BROWSER_K_ANONYMITY_SERVICE_K_ANONYMITY_SERVICE_STORAGE_H_
#include <optional>
#include <string>
#include "base/containers/flat_map.h"
#include "base/files/file_path.h"
#include "base/functional/callback.h"
#include "base/time/time.h"
#include "url/origin.h"
struct OHTTPKeyAndExpiration {
// The OHTTP key in this struct is formatted as described in
// https://www.ietf.org/archive/id/draft-ietf-ohai-ohttp-02.html#name-key-configuration-encoding
std::string key; // OHTTP key
base::Time expiration;
};
struct KeyAndNonUniqueUserId {
std::string key_commitment; // trust token key commitment (specific to
// `non_unique_user_id`)
int non_unique_user_id; // Non-unique ID assigned to this user for k-anon
// reporting
};
struct KeyAndNonUniqueUserIdWithExpiration {
KeyAndNonUniqueUserId key_and_id;
base::Time expiration;
};
class KAnonymityServiceStorage {
public:
enum InitStatus {
kInitOk,
kInitError,
// kInitNotReady is only be used internally, not as a response to
// WaitUntilReady.
kInitNotReady,
};
virtual ~KAnonymityServiceStorage();
virtual void WaitUntilReady(
base::OnceCallback<void(InitStatus)> on_ready) = 0;
virtual std::optional<OHTTPKeyAndExpiration> GetOHTTPKeyFor(
const url::Origin& origin) const = 0;
virtual void UpdateOHTTPKeyFor(const url::Origin& origin,
const OHTTPKeyAndExpiration& key) = 0;
virtual std::optional<KeyAndNonUniqueUserIdWithExpiration>
GetKeyAndNonUniqueUserId() const = 0;
virtual void UpdateKeyAndNonUniqueUserId(
const KeyAndNonUniqueUserIdWithExpiration& key) = 0;
};
class KAnonymityServiceMemoryStorage : public KAnonymityServiceStorage {
public:
KAnonymityServiceMemoryStorage();
~KAnonymityServiceMemoryStorage() override;
void WaitUntilReady(base::OnceCallback<void(InitStatus)> on_ready) override;
std::optional<OHTTPKeyAndExpiration> GetOHTTPKeyFor(
const url::Origin& origin) const override;
void UpdateOHTTPKeyFor(const url::Origin& origin,
const OHTTPKeyAndExpiration& key) override;
std::optional<KeyAndNonUniqueUserIdWithExpiration> GetKeyAndNonUniqueUserId()
const override;
void UpdateKeyAndNonUniqueUserId(
const KeyAndNonUniqueUserIdWithExpiration& key) override;
private:
std::optional<KeyAndNonUniqueUserIdWithExpiration>
key_and_non_unique_user_id_with_expiration_;
base::flat_map<url::Origin, OHTTPKeyAndExpiration> ohttp_key_map_;
};
std::unique_ptr<KAnonymityServiceStorage> CreateKAnonymitySqlStorageForPath(
base::FilePath db_storage_path);
#endif // CHROME_BROWSER_K_ANONYMITY_SERVICE_K_ANONYMITY_SERVICE_STORAGE_H_
|