summaryrefslogtreecommitdiffstats
path: root/dom/ipc/JSValidatorParent.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/ipc/JSValidatorParent.cpp
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/ipc/JSValidatorParent.cpp')
-rw-r--r--dom/ipc/JSValidatorParent.cpp99
1 files changed, 99 insertions, 0 deletions
diff --git a/dom/ipc/JSValidatorParent.cpp b/dom/ipc/JSValidatorParent.cpp
new file mode 100644
index 0000000000..45b6d9de4c
--- /dev/null
+++ b/dom/ipc/JSValidatorParent.cpp
@@ -0,0 +1,99 @@
+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim: set ts=8 sts=2 et sw=2 tw=80: */
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+#include "mozilla/net/OpaqueResponseUtils.h"
+#include "mozilla/dom/JSValidatorParent.h"
+#include "mozilla/dom/JSValidatorUtils.h"
+#include "mozilla/dom/JSOracleParent.h"
+#include "mozilla/RefPtr.h"
+#include "nsCOMPtr.h"
+#include "HttpBaseChannel.h"
+
+namespace mozilla::dom {
+/* static */
+already_AddRefed<JSValidatorParent> JSValidatorParent::Create() {
+ RefPtr<JSValidatorParent> validator = new JSValidatorParent();
+ JSOracleParent::WithJSOracle([validator](JSOracleParent* aParent) {
+ MOZ_ASSERT_IF(aParent, aParent->CanSend());
+ if (aParent) {
+ MOZ_ALWAYS_TRUE(aParent->SendPJSValidatorConstructor(validator));
+ }
+ });
+ return validator.forget();
+}
+
+void JSValidatorParent::IsOpaqueResponseAllowed(
+ const std::function<void(Maybe<Shmem>, ValidatorResult)>& aCallback) {
+ JSOracleParent::WithJSOracle([=, self = RefPtr{this}](const auto* aParent) {
+ if (aParent) {
+ MOZ_DIAGNOSTIC_ASSERT(self->CanSend());
+ self->SendIsOpaqueResponseAllowed()->Then(
+ GetMainThreadSerialEventTarget(), __func__,
+ [aCallback](
+ const IsOpaqueResponseAllowedPromise::ResolveOrRejectValue&
+ aResult) {
+ if (aResult.IsResolve()) {
+ auto [data, result] = aResult.ResolveValue();
+ aCallback(std::move(data), result);
+ } else {
+ // For cases like the Utility Process crashes, the promise will be
+ // rejected due to sending failures, and we'll block the request
+ // since we can't validate it.
+ aCallback(Nothing(), ValidatorResult::Failure);
+ }
+ });
+ } else {
+ aCallback(Nothing(), ValidatorResult::Failure);
+ }
+ });
+}
+
+void JSValidatorParent::OnDataAvailable(const nsACString& aData) {
+ JSOracleParent::WithJSOracle(
+ [self = RefPtr{this}, data = nsCString{aData}](const auto* aParent) {
+ if (!aParent) {
+ return;
+ }
+
+ if (self->CanSend()) {
+ Shmem sharedData;
+ nsresult rv =
+ JSValidatorUtils::CopyCStringToShmem(self, data, sharedData);
+ if (NS_FAILED(rv)) {
+ return;
+ }
+ Unused << self->SendOnDataAvailable(std::move(sharedData));
+ }
+ });
+}
+
+void JSValidatorParent::OnStopRequest(nsresult aResult, nsIRequest& aRequest) {
+ JSOracleParent::WithJSOracle(
+ [self = RefPtr{this}, aResult,
+ request = nsCOMPtr{&aRequest}](const auto* aParent) {
+ if (!aParent) {
+ return;
+ }
+ if (self->CanSend() && request) {
+ nsCOMPtr<net::HttpBaseChannel> httpBaseChannel =
+ do_QueryInterface(request);
+ MOZ_ASSERT(httpBaseChannel);
+
+ nsAutoCString contentCharset;
+ Unused << httpBaseChannel->GetContentCharset(contentCharset);
+
+ nsAutoString hintCharset;
+ Unused << httpBaseChannel->GetClassicScriptHintCharset(hintCharset);
+
+ nsAutoString documentCharset;
+ Unused << httpBaseChannel->GetDocumentCharacterSet(documentCharset);
+
+ Unused << self->SendOnStopRequest(aResult, contentCharset,
+ hintCharset, documentCharset);
+ }
+ });
+}
+} // namespace mozilla::dom