mirror of
https://github.com/electron/electron.git
synced 2026-02-19 03:14:51 -05:00
* chore: bump chromium in DEPS to 98.0.4726.0 * 3292117: Remove unneeded base/compiler_specific.h includes in //chrome. https://chromium-review.googlesource.com/c/chromium/src/+/3292117 * 3289198: Enables calculating line, word and sentence boundaries on the browser https://chromium-review.googlesource.com/c/chromium/src/+/3289198 * 3276176: Remove expired gdi-text-printing flag and associated code. https://chromium-review.googlesource.com/c/chromium/src/+/3276176 * 3240963: content: allow embedder to prevent locking scheme registry https://chromium-review.googlesource.com/c/chromium/src/+/3240963 * 3269899: Rename WebContentsImpl::GetFrameTree to GetPrimaryFrameTree https://chromium-review.googlesource.com/c/chromium/src/+/3269899 * chore: fixup patch indices * 3276279: Enable -Wshadow by default for the "chromium code" config. https://chromium-review.googlesource.com/c/chromium/src/+/3276279 * 3279737: appcache: Remove WebPreference/WebSetting https://chromium-review.googlesource.com/c/chromium/src/+/3279737 * 3275564: [api] Advance API deprecation for APIs last marked in v9.6 https://chromium-review.googlesource.com/c/v8/v8/+/3275564 * 3261873: Clean up WebScriptSource constructors https://chromium-review.googlesource.com/c/chromium/src/+/3261873 * 3279346: appcache: Remove ConsoleMessage appcache field https://chromium-review.googlesource.com/c/chromium/src/+/3279346 * 3264212: Move legacy file loading to legacy_test_runner https://chromium-review.googlesource.com/c/devtools/devtools-frontend/+/3264212 Both Persistence and UI have been removed from globals, but the issues they seemed to be patching are no longer reproducible from what I can tell, and so we can just delete these and re-evaluate if something surfaces. * 3290415: x11: remove the USE_X11 define. https://chromium-review.googlesource.com/c/chromium/src/+/3290415 * chore: bump Chromium to 98.0.4728.0 * 3179530: Defer system calls in PrintingContext for OOP printing https://chromium-review.googlesource.com/c/chromium/src/+/3179530 * 3299445: Consolidate is_win conditionals in chrome/test/BUILD.gn. https://chromium-review.googlesource.com/c/chromium/src/+/3299445 * chore: update patch indices * 3223975: Break PrintJobWorker OOP logic into separate class https://chromium-review.googlesource.com/c/chromium/src/+/3223975 * chore: bump chromium in DEPS to 98.0.4730.0 * 3279001: Remove support for font-family: -webkit-pictograph https://chromium-review.googlesource.com/c/chromium/src/+/3279001 * chore: fixup patch indices * chore: bump chromium in DEPS to 98.0.4732.0 * chore: update patches * chore: bump chromium in DEPS to 98.0.4734.0 * chore: bump chromium in DEPS to 98.0.4736.0 * chore: update patches * chore: update printing patch for miracle ptr * chore: add noexcept to fix clang error * chore: bump chromium in DEPS to 98.0.4738.0 * chore: update patches * chore: bump chromium in DEPS to 98.0.4740.0 * chore: bump chromium in DEPS to 98.0.4742.0 * chore: bump chromium in DEPS to 98.0.4744.0 * chore: bump chromium in DEPS to 98.0.4746.0 * chore: bump chromium in DEPS to 98.0.4748.0 * chore: bump chromium in DEPS to 98.0.4750.0 * chore: update patches * 3293841: Remove File Handling permissions code Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3293841 * chore: update patches 3311700: Move the PpapiPluginSandboxedProcessLauncherDelegate | https://chromium-review.googlesource.com/c/chromium/src/+/3311700 * 3289260: [CodeHealth]: Remove uses of Notification Service Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3289260 * 3301600: Disable scripted print in fenced frames Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3301600 * chore: add missing thread_restrictions headers * 3305132: Rewrite most `Foo* field_` pointer fields to `raw_ptr<Foo> field_`. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3305132 * fix: add ppapi_sandbox header for linux 3311700: Move the PpapiPluginSandboxedProcessLauncherDelegate | https://chromium-review.googlesource.com/c/chromium/src/+/3311700 * chore: manually bump chromium in DEPS to 98.0.4757.0 * chore: update patches * 3321044: Remove DictionaryValue::Clear() Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3321044 * chore: update printing.patch Refs: - 3304556: [code health] Remove notification observation from PrintJob. | https://chromium-review.googlesource.com/c/chromium/src/+/3304556 - 3305095: [code health] Remove NotificationService from PrintViewManagerBase. | https://chromium-review.googlesource.com/c/chromium/src/+/3305095 * build: add v8-embedder-state headers to GN patch * chore: bump chromium in DEPS to 99.0.4767.0 * chore: update patches * chore: rename CookiePartitionKeychain ...to CookiePartitionKeyCollection * chore: update video consumers * refactor: use newer base::Value API * 3232598: Convert net::DnsOverHttpsServerConfig into a class | https://chromium-review.googlesource.com/c/chromium/src/+/3232598 * 3327865: Remove the default WebContentsUserData ctor. | https://chromium-review.googlesource.com/c/chromium/src/+/3327865 * 3302814: DevTools: Add getPreference binding | https://chromium-review.googlesource.com/c/chromium/src/+/3302814 * 3301474: [tq][runtime] Use build flags for JS context promise hooks | https://chromium-review.googlesource.com/c/v8/v8/+/3301474 * oops 😵💫 * 3272411: Reland "base/allocator: Enable PartitionAlloc-Everywhere on macOS" | https://chromium-review.googlesource.com/c/chromium/src/+/3272411 build: turn PartitionAlloc back off on mac for now * fix: WCO method got renamed * 3344749: Revert "Stop using NSRunLoop in renderer process" https://chromium-review.googlesource.com/c/chromium/src/+/3344749 * 3288746: [serial] Fix BluetoothSerialDeviceEnumerator threading issues. https://chromium-review.googlesource.com/c/chromium/src/+/3288746 * Revert "3288746: [serial] Fix BluetoothSerialDeviceEnumerator threading issues." This reverts commit 5cc69f102e43ca72ac9ef45063711bcc7d849740. * chore: disable serial device enumerator sequence dcheck * fix: comment out line in DeviceService dtor * fixup! 3279001: Remove support for font-family: -webkit-pictograph * fixup! 3279346: appcache: Remove ConsoleMessage appcache field * chore: update patches after rebase Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com> Co-authored-by: VerteDinde <khammond@slack-corp.com> Co-authored-by: clavin <clavin@electronjs.org> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Jeremy Rose <jeremya@chromium.org>
168 lines
5.8 KiB
C++
168 lines
5.8 KiB
C++
// Copyright (c) 2019 Slack Technologies, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/browser/api/electron_api_service_worker_context.h"
|
|
|
|
#include <string>
|
|
#include <utility>
|
|
|
|
#include "chrome/browser/browser_process.h"
|
|
#include "content/public/browser/console_message.h"
|
|
#include "content/public/browser/storage_partition.h"
|
|
#include "gin/data_object_builder.h"
|
|
#include "gin/handle.h"
|
|
#include "gin/object_template_builder.h"
|
|
#include "shell/browser/electron_browser_context.h"
|
|
#include "shell/browser/javascript_environment.h"
|
|
#include "shell/common/gin_converters/gurl_converter.h"
|
|
#include "shell/common/gin_converters/value_converter.h"
|
|
#include "shell/common/gin_helper/dictionary.h"
|
|
#include "shell/common/gin_helper/function_template_extensions.h"
|
|
#include "shell/common/node_includes.h"
|
|
|
|
namespace electron {
|
|
|
|
namespace api {
|
|
|
|
namespace {
|
|
|
|
std::string MessageSourceToString(
|
|
const blink::mojom::ConsoleMessageSource source) {
|
|
if (source == blink::mojom::ConsoleMessageSource::kXml)
|
|
return "xml";
|
|
if (source == blink::mojom::ConsoleMessageSource::kJavaScript)
|
|
return "javascript";
|
|
if (source == blink::mojom::ConsoleMessageSource::kNetwork)
|
|
return "network";
|
|
if (source == blink::mojom::ConsoleMessageSource::kConsoleApi)
|
|
return "console-api";
|
|
if (source == blink::mojom::ConsoleMessageSource::kStorage)
|
|
return "storage";
|
|
if (source == blink::mojom::ConsoleMessageSource::kRendering)
|
|
return "rendering";
|
|
if (source == blink::mojom::ConsoleMessageSource::kSecurity)
|
|
return "security";
|
|
if (source == blink::mojom::ConsoleMessageSource::kDeprecation)
|
|
return "deprecation";
|
|
if (source == blink::mojom::ConsoleMessageSource::kWorker)
|
|
return "worker";
|
|
if (source == blink::mojom::ConsoleMessageSource::kViolation)
|
|
return "violation";
|
|
if (source == blink::mojom::ConsoleMessageSource::kIntervention)
|
|
return "intervention";
|
|
if (source == blink::mojom::ConsoleMessageSource::kRecommendation)
|
|
return "recommendation";
|
|
return "other";
|
|
}
|
|
|
|
v8::Local<v8::Value> ServiceWorkerRunningInfoToDict(
|
|
v8::Isolate* isolate,
|
|
const content::ServiceWorkerRunningInfo& info) {
|
|
return gin::DataObjectBuilder(isolate)
|
|
.Set("scriptUrl", info.script_url.spec())
|
|
.Set("scope", info.scope.spec())
|
|
.Set("renderProcessId", info.render_process_id)
|
|
.Build();
|
|
}
|
|
|
|
} // namespace
|
|
|
|
gin::WrapperInfo ServiceWorkerContext::kWrapperInfo = {gin::kEmbedderNativeGin};
|
|
|
|
ServiceWorkerContext::ServiceWorkerContext(
|
|
v8::Isolate* isolate,
|
|
ElectronBrowserContext* browser_context) {
|
|
service_worker_context_ =
|
|
browser_context->GetDefaultStoragePartition()->GetServiceWorkerContext();
|
|
service_worker_context_->AddObserver(this);
|
|
}
|
|
|
|
ServiceWorkerContext::~ServiceWorkerContext() {
|
|
service_worker_context_->RemoveObserver(this);
|
|
}
|
|
|
|
void ServiceWorkerContext::OnReportConsoleMessage(
|
|
int64_t version_id,
|
|
const GURL& scope,
|
|
const content::ConsoleMessage& message) {
|
|
v8::Isolate* isolate = JavascriptEnvironment::GetIsolate();
|
|
v8::HandleScope handle_scope(isolate);
|
|
Emit("console-message",
|
|
gin::DataObjectBuilder(isolate)
|
|
.Set("versionId", version_id)
|
|
.Set("source", MessageSourceToString(message.source))
|
|
.Set("level", static_cast<int32_t>(message.message_level))
|
|
.Set("message", message.message)
|
|
.Set("lineNumber", message.line_number)
|
|
.Set("sourceUrl", message.source_url.spec())
|
|
.Build());
|
|
}
|
|
|
|
void ServiceWorkerContext::OnRegistrationCompleted(const GURL& scope) {
|
|
v8::Isolate* isolate = JavascriptEnvironment::GetIsolate();
|
|
v8::HandleScope handle_scope(isolate);
|
|
Emit("registration-completed",
|
|
gin::DataObjectBuilder(isolate).Set("scope", scope).Build());
|
|
}
|
|
|
|
void ServiceWorkerContext::OnDestruct(content::ServiceWorkerContext* context) {
|
|
if (context == service_worker_context_) {
|
|
delete this;
|
|
}
|
|
}
|
|
|
|
v8::Local<v8::Value> ServiceWorkerContext::GetAllRunningWorkerInfo(
|
|
v8::Isolate* isolate) {
|
|
gin::DataObjectBuilder builder(isolate);
|
|
const base::flat_map<int64_t, content::ServiceWorkerRunningInfo>& info_map =
|
|
service_worker_context_->GetRunningServiceWorkerInfos();
|
|
for (auto iter = info_map.begin(); iter != info_map.end(); ++iter) {
|
|
builder.Set(
|
|
std::to_string(iter->first),
|
|
ServiceWorkerRunningInfoToDict(isolate, std::move(iter->second)));
|
|
}
|
|
return builder.Build();
|
|
}
|
|
|
|
v8::Local<v8::Value> ServiceWorkerContext::GetWorkerInfoFromID(
|
|
gin_helper::ErrorThrower thrower,
|
|
int64_t version_id) {
|
|
const base::flat_map<int64_t, content::ServiceWorkerRunningInfo>& info_map =
|
|
service_worker_context_->GetRunningServiceWorkerInfos();
|
|
auto iter = info_map.find(version_id);
|
|
if (iter == info_map.end()) {
|
|
thrower.ThrowError("Could not find service worker with that version_id");
|
|
return v8::Local<v8::Value>();
|
|
}
|
|
return ServiceWorkerRunningInfoToDict(thrower.isolate(),
|
|
std::move(iter->second));
|
|
}
|
|
|
|
// static
|
|
gin::Handle<ServiceWorkerContext> ServiceWorkerContext::Create(
|
|
v8::Isolate* isolate,
|
|
ElectronBrowserContext* browser_context) {
|
|
return gin::CreateHandle(isolate,
|
|
new ServiceWorkerContext(isolate, browser_context));
|
|
}
|
|
|
|
// static
|
|
gin::ObjectTemplateBuilder ServiceWorkerContext::GetObjectTemplateBuilder(
|
|
v8::Isolate* isolate) {
|
|
return gin_helper::EventEmitterMixin<
|
|
ServiceWorkerContext>::GetObjectTemplateBuilder(isolate)
|
|
.SetMethod("getAllRunning",
|
|
&ServiceWorkerContext::GetAllRunningWorkerInfo)
|
|
.SetMethod("getFromVersionID",
|
|
&ServiceWorkerContext::GetWorkerInfoFromID);
|
|
}
|
|
|
|
const char* ServiceWorkerContext::GetTypeName() {
|
|
return "ServiceWorkerContext";
|
|
}
|
|
|
|
} // namespace api
|
|
|
|
} // namespace electron
|