mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-01-10 09:13:33 +01:00
2f1e782f62
Frame identifiers have changed from int64_t to string type. This is due to https://crbug.com/1502660 which removes access to frame routing IDs in the renderer process. New cross-process frame identifiers are 160-bit values (32-bit child process ID + 128-bit local frame token) and most easily represented as strings. All other frame-related expectations and behaviors remain the same.
80 lines
2.5 KiB
C++
80 lines
2.5 KiB
C++
// Copyright (c) 2019 The Chromium Embedded Framework Authors. All rights
|
|
// reserved. Use of this source code is governed by a BSD-style license that can
|
|
// be found in the LICENSE file.
|
|
|
|
#include "libcef/common/frame_util.h"
|
|
|
|
#include "libcef/browser/thread_util.h"
|
|
|
|
#include "base/strings/string_number_conversions.h"
|
|
#include "base/strings/stringprintf.h"
|
|
#include "content/public/browser/navigation_handle.h"
|
|
#include "content/public/browser/render_frame_host.h"
|
|
|
|
namespace frame_util {
|
|
|
|
content::GlobalRenderFrameHostId GetGlobalId(
|
|
content::NavigationHandle* navigation_handle) {
|
|
CEF_REQUIRE_UIT();
|
|
return navigation_handle->HasCommitted()
|
|
? navigation_handle->GetRenderFrameHost()->GetGlobalId()
|
|
: navigation_handle->GetPreviousRenderFrameHostId();
|
|
}
|
|
|
|
std::optional<content::GlobalRenderFrameHostToken> ParseFrameIdentifier(
|
|
const std::string& identifier) {
|
|
if (identifier.size() < 3) {
|
|
return std::nullopt;
|
|
}
|
|
|
|
const size_t pos = identifier.find('-');
|
|
if (pos == std::string::npos || pos == 0 || pos == identifier.size() - 1) {
|
|
return std::nullopt;
|
|
}
|
|
|
|
std::string_view process_id_str(identifier.c_str(), pos);
|
|
int process_id;
|
|
if (!base::HexStringToInt(process_id_str, &process_id) ||
|
|
!IsValidChildId(process_id)) {
|
|
return std::nullopt;
|
|
}
|
|
|
|
std::string_view frame_token_str(identifier.c_str() + pos + 1,
|
|
identifier.size() - pos - 1);
|
|
auto token = base::Token::FromString(frame_token_str);
|
|
if (token) {
|
|
auto unguessable_token =
|
|
base::UnguessableToken::Deserialize(token->high(), token->low());
|
|
if (unguessable_token) {
|
|
return content::GlobalRenderFrameHostToken(
|
|
process_id, blink::LocalFrameToken(unguessable_token.value()));
|
|
}
|
|
}
|
|
|
|
return std::nullopt;
|
|
}
|
|
|
|
std::string MakeFrameIdentifier(
|
|
const content::GlobalRenderFrameHostToken& global_token) {
|
|
if (!IsValidGlobalToken(global_token)) {
|
|
return std::string();
|
|
}
|
|
|
|
// All upper-case hex values.
|
|
return base::StringPrintf("%X-%s", global_token.child_id,
|
|
global_token.frame_token.ToString().c_str());
|
|
}
|
|
|
|
std::string GetFrameDebugString(
|
|
const content::GlobalRenderFrameHostId& global_id) {
|
|
return base::StringPrintf("[%d,%d]", global_id.child_id,
|
|
global_id.frame_routing_id);
|
|
}
|
|
|
|
std::string GetFrameDebugString(
|
|
const content::GlobalRenderFrameHostToken& global_token) {
|
|
return MakeFrameIdentifier(global_token);
|
|
}
|
|
|
|
} // namespace frame_util
|