| // 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. | 
 |  | 
 | #include "third_party/blink/renderer/modules/fuzzing/internals_fuzzing.h" | 
 |  | 
 | #include "base/compiler_specific.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, UNSAFE_TODO(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), | 
 |       BindOnce(&ResolvePromise, WrapPersistent(resolver))); | 
 |  | 
 |   return promise; | 
 | } | 
 |  | 
 | }  // namespace blink |