2019-10-18 19:57:09 +00:00
|
|
|
// 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.
|
|
|
|
|
2021-11-22 07:34:31 +00:00
|
|
|
#ifndef ELECTRON_SHELL_RENDERER_API_ELECTRON_API_CONTEXT_BRIDGE_H_
|
|
|
|
#define ELECTRON_SHELL_RENDERER_API_ELECTRON_API_CONTEXT_BRIDGE_H_
|
2019-10-18 19:57:09 +00:00
|
|
|
|
2020-03-04 07:18:22 +00:00
|
|
|
#include "shell/renderer/api/context_bridge/object_cache.h"
|
2019-10-31 07:56:00 +00:00
|
|
|
#include "v8/include/v8.h"
|
|
|
|
|
|
|
|
namespace gin_helper {
|
|
|
|
class Arguments;
|
|
|
|
}
|
2019-10-18 19:57:09 +00:00
|
|
|
|
2022-06-29 19:55:47 +00:00
|
|
|
namespace electron::api {
|
2019-10-18 19:57:09 +00:00
|
|
|
|
2020-05-15 18:57:40 +00:00
|
|
|
void ProxyFunctionWrapper(const v8::FunctionCallbackInfo<v8::Value>& info);
|
2019-10-18 19:57:09 +00:00
|
|
|
|
2021-01-26 22:23:35 +00:00
|
|
|
// Where the context bridge should create the exception it is about to throw
|
|
|
|
enum class BridgeErrorTarget {
|
|
|
|
// The source / calling context. This is default and correct 99% of the time,
|
|
|
|
// the caller / context asking for the conversion will receive the error and
|
|
|
|
// therefore the error should be made in that context
|
|
|
|
kSource,
|
|
|
|
// The destination / target context. This should only be used when the source
|
|
|
|
// won't catch the error that results from the value it is passing over the
|
|
|
|
// bridge. This can **only** occur when returning a value from a function as
|
|
|
|
// we convert the return value after the method has terminated and execution
|
|
|
|
// has been returned to the caller. In this scenario the error will the be
|
|
|
|
// catchable in the "destination" context and therefore we create the error
|
|
|
|
// there.
|
|
|
|
kDestination
|
|
|
|
};
|
|
|
|
|
|
|
|
v8::MaybeLocal<v8::Value> PassValueToOtherContext(
|
|
|
|
v8::Local<v8::Context> source_context,
|
|
|
|
v8::Local<v8::Context> destination_context,
|
|
|
|
v8::Local<v8::Value> value,
|
2023-10-18 14:21:42 +00:00
|
|
|
/**
|
|
|
|
* Used to automatically bind a function across
|
|
|
|
* worlds to its appropriate default "this" value.
|
|
|
|
*
|
|
|
|
* If this value is the root of a tree going over
|
|
|
|
* the bridge set this to the "context" of the value.
|
|
|
|
*/
|
|
|
|
v8::Local<v8::Value> parent_value,
|
2021-01-26 22:23:35 +00:00
|
|
|
context_bridge::ObjectCache* object_cache,
|
|
|
|
bool support_dynamic_properties,
|
|
|
|
int recursion_depth,
|
2023-04-10 21:58:27 +00:00
|
|
|
BridgeErrorTarget error_target);
|
2021-01-26 22:23:35 +00:00
|
|
|
|
2019-10-18 19:57:09 +00:00
|
|
|
v8::MaybeLocal<v8::Object> CreateProxyForAPI(
|
|
|
|
const v8::Local<v8::Object>& api_object,
|
|
|
|
const v8::Local<v8::Context>& source_context,
|
2020-10-27 15:18:36 +00:00
|
|
|
const v8::Local<v8::Context>& destination_context,
|
2020-03-04 07:18:22 +00:00
|
|
|
context_bridge::ObjectCache* object_cache,
|
2020-04-27 19:46:04 +00:00
|
|
|
bool support_dynamic_properties,
|
2023-04-10 21:58:27 +00:00
|
|
|
int recursion_depth,
|
|
|
|
BridgeErrorTarget error_target);
|
2019-10-18 19:57:09 +00:00
|
|
|
|
2022-06-29 19:55:47 +00:00
|
|
|
} // namespace electron::api
|
2019-10-18 19:57:09 +00:00
|
|
|
|
2021-11-22 07:34:31 +00:00
|
|
|
#endif // ELECTRON_SHELL_RENDERER_API_ELECTRON_API_CONTEXT_BRIDGE_H_
|