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 86 87 88 89 90 91 92 93 94 95
|
// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/certificate_provider/sign_requests.h"
namespace chromeos {
namespace certificate_provider {
SignRequests::Request::Request(
const scoped_refptr<net::X509Certificate>& certificate,
const std::optional<AccountId>& authenticating_user_account_id,
net::SSLPrivateKey::SignCallback callback)
: certificate(certificate),
authenticating_user_account_id(authenticating_user_account_id),
callback(std::move(callback)) {}
SignRequests::Request::Request(Request&& other) = default;
SignRequests::Request::~Request() = default;
SignRequests::Request& SignRequests::Request::operator=(Request&&) = default;
SignRequests::RequestsState::RequestsState() = default;
SignRequests::RequestsState::RequestsState(RequestsState&& other) = default;
SignRequests::RequestsState::~RequestsState() = default;
SignRequests::SignRequests() = default;
SignRequests::~SignRequests() = default;
int SignRequests::AddRequest(
const std::string& extension_id,
const scoped_refptr<net::X509Certificate>& certificate,
const std::optional<AccountId>& authenticating_user_account_id,
net::SSLPrivateKey::SignCallback callback) {
RequestsState& state = extension_to_requests_[extension_id];
const int request_id = state.next_free_id++;
state.pending_requests.emplace(
request_id, Request(certificate, authenticating_user_account_id,
std::move(callback)));
return request_id;
}
std::vector<SignRequests::ExtensionNameRequestIdPair>
SignRequests::FindRequestsForAuthenticatingUser(
const AccountId& authenticating_user_account_id) const {
std::vector<ExtensionNameRequestIdPair> found_requests;
for (const auto& extension_entry : extension_to_requests_) {
const std::string& extension_id = extension_entry.first;
const RequestsState& extension_requests = extension_entry.second;
for (const auto& entry : extension_requests.pending_requests) {
const int request_id = entry.first;
const Request& request = entry.second;
if (request.authenticating_user_account_id ==
authenticating_user_account_id) {
found_requests.emplace_back(extension_id, request_id);
}
}
}
return found_requests;
}
bool SignRequests::RemoveRequest(
const std::string& extension_id,
int request_id,
scoped_refptr<net::X509Certificate>* certificate,
net::SSLPrivateKey::SignCallback* callback) {
RequestsState& state = extension_to_requests_[extension_id];
std::map<int, Request>& pending = state.pending_requests;
const auto it = pending.find(request_id);
if (it == pending.end())
return false;
Request& request = it->second;
*certificate = request.certificate;
*callback = std::move(request.callback);
pending.erase(it);
return true;
}
std::vector<net::SSLPrivateKey::SignCallback> SignRequests::RemoveAllRequests(
const std::string& extension_id) {
std::vector<net::SSLPrivateKey::SignCallback> callbacks;
for (auto& entry : extension_to_requests_[extension_id].pending_requests) {
callbacks.push_back(std::move(entry.second.callback));
}
extension_to_requests_.erase(extension_id);
return callbacks;
}
} // namespace certificate_provider
} // namespace chromeos
|