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
|
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifdef UNSAFE_BUFFERS_BUILD
// TODO(crbug.com/351564777): Remove this and convert code to safer constructs.
#pragma allow_unsafe_buffers
#endif
#include "third_party/blink/renderer/modules/fuzzing/internals_fuzzing.h"
#include "third_party/blink/public/platform/platform.h"
#include "third_party/blink/renderer/bindings/core/v8/script_promise_resolver.h"
#include "third_party/blink/renderer/bindings/core/v8/v8_union_arraybuffer_arraybufferview.h"
#include "third_party/blink/renderer/core/execution_context/execution_context.h"
#include "third_party/blink/renderer/core/frame/local_dom_window.h"
#include "third_party/blink/renderer/platform/testing/renderer_fuzzing_support.h"
#include "third_party/blink/renderer/platform/wtf/casting.h"
namespace blink {
static void ResolvePromise(ScriptPromiseResolver<IDLUndefined>* resolver) {
resolver->Resolve();
}
// static
ScriptPromise<IDLUndefined> InternalsFuzzing::runFuzzer(
ScriptState* script_state,
Internals&,
const String& fuzzer_id,
V8BufferSource* fuzzer_data) {
auto* context = ExecutionContext::From(script_state);
const uint8_t* bytes = nullptr;
size_t num_bytes = 0;
switch (fuzzer_data->GetContentType()) {
case V8BufferSource::ContentType::kArrayBuffer: {
DOMArrayBuffer* array = fuzzer_data->GetAsArrayBuffer();
bytes = static_cast<uint8_t*>(array->Data());
num_bytes = array->ByteLength();
break;
}
case V8BufferSource::ContentType::kArrayBufferView: {
const auto& view = fuzzer_data->GetAsArrayBufferView();
bytes = static_cast<uint8_t*>(view->BaseAddress());
num_bytes = view->byteLength();
break;
}
}
std::vector<uint8_t> data(bytes, bytes + num_bytes);
auto* resolver =
MakeGarbageCollected<ScriptPromiseResolver<IDLUndefined>>(script_state);
auto promise = resolver->Promise();
AssociatedInterfaceProvider* associated_provider = nullptr;
if (auto* window = DynamicTo<LocalDOMWindow>(context)) {
if (auto* frame = window->GetFrame()) {
associated_provider = frame->GetRemoteNavigationAssociatedInterfaces();
}
}
RendererFuzzingSupport::Run(
&context->GetBrowserInterfaceBroker(),
Platform::Current()->GetBrowserInterfaceBroker(), associated_provider,
fuzzer_id.Utf8(), std::move(data),
WTF::BindOnce(&ResolvePromise, WrapPersistent(resolver)));
return promise;
}
} // namespace blink
|