CCF
Loading...
Searching...
No Matches
context.h
Go to the documentation of this file.
1// Copyright (c) Microsoft Corporation. All rights reserved.
2// Licensed under the Apache 2.0 License.
3#pragma once
4
9#include "ccf/js/tx_access.h"
10#include "ccf/pal/locking.h"
11
12#include <chrono>
13#include <quickjs/quickjs-exports.h>
14#include <quickjs/quickjs.h>
15#include <span>
16
17// Forward declarations
18namespace ccf
19{
20 class AbstractGovernanceEffects;
21 class AbstractHostProcesses;
22 struct NetworkState;
23 class RpcContext;
24 class BaseEndpointRegistry;
25
26 namespace historical
27 {
28 class AbstractStateCache;
29 struct State;
30
31 using StatePtr = std::shared_ptr<State>;
32 }
33}
34
35namespace ccf::js::core
36{
38 {
39 std::chrono::high_resolution_clock::time_point start_time;
40 std::chrono::milliseconds max_execution_time;
42 bool request_timed_out = false;
43 };
44
45 class Context
46 {
47 private:
48 JSContext* ctx;
49 Runtime rt;
50
52 js::modules::ModuleLoaderPtr module_loader;
53
54 // The interpreter can cache loaded modules so they do not need to be loaded
55 // from the KV for every execution, which is particularly useful when
56 // re-using interpreters. A module can only be loaded once per interpreter,
57 // and the entire interpreter should be thrown away if _any_ of its modules
58 // needs to be refreshed.
59 std::map<std::string, js::core::JSWrappedValue, std::less<>>
60 loaded_modules_cache;
61
62 public:
64
68
69 Context(TxAccess acc);
70
71 virtual ~Context();
72
73 // Delete copy and assignment operators, since this assumes sole ownership
74 // of underlying rt and ctx
75 Context(const Context&) = delete;
76 Context& operator=(const Context&) = delete;
77
79 {
80 return rt;
81 }
82
83 operator JSContext*() const
84 {
85 return ctx;
86 }
87
89 {
90 module_loader = ml;
91 }
92
93 virtual std::optional<JSWrappedValue> get_module(
94 std::string_view module_name);
95
96 // Construct RAII wrapper around raw QuickJS value
97 JSWrappedValue wrap(JSValue&& val) const;
98 JSWrappedValue wrap(const JSValue& val) const;
99
100 // If the first argument is a string-array, populates the second, and
101 // returns undefined. Otherwise returns a JS error value.
102 JSValue extract_string_array(
103 JSValueConst& argv, std::vector<std::string>& out);
104
105 std::pair<std::string, std::optional<std::string>> error_message();
106
107 // Getters
109 JSValue object, char const* property_name) const;
111 JSWrappedValue get_global_property(const char* s) const;
113 const char* s, JSWrappedValue default_value) const;
115 const JSWrappedValue& obj,
116 size_t* pbyte_offset,
117 size_t* pbyte_length,
118 size_t* pbytes_per_element) const;
120 const std::string& code,
121 const std::string& func,
122 const std::string& path);
124 const JSWrappedValue& module,
125 const std::string& func,
126 const std::string& path);
127
128 // Constant values
129 JSWrappedValue null() const;
131
132 // Construct new values
133 JSWrappedValue new_obj() const;
134 JSWrappedValue new_obj_class(JSClassID class_id) const;
137 const uint8_t* buf, size_t buf_len) const;
138 JSWrappedValue new_array_buffer_copy(const char* buf, size_t buf_len) const;
139 JSWrappedValue new_array_buffer_copy(std::span<const uint8_t> data) const;
140 JSWrappedValue new_string(const std::string_view& str) const;
141 JSWrappedValue new_string_len(const char* buf, size_t buf_len) const;
142 JSWrappedValue new_string_len(const std::span<const uint8_t> buf) const;
143 JSWrappedValue new_type_error(const char* fmt, ...) const;
144 JSWrappedValue new_internal_error(const char* fmt, ...) const;
145 JSWrappedValue new_tag_value(int tag, int32_t val = 0) const;
147 JSCFunction* func, const char* name, int length) const;
149 JSCFunction* func, const char* name, size_t arg_count = 0) const;
150
151 JSWrappedValue duplicate_value(JSValueConst original) const;
152
154 const char* input,
155 size_t input_len,
156 const char* filename,
157 int eval_flags) const;
159 const uint8_t* buf, size_t buf_len, int flags) const;
160
162 const JSWrappedValue& f,
163 const std::vector<JSWrappedValue>& argv,
164 const std::optional<ccf::JSRuntimeOptions>& options,
165 RuntimeLimitsPolicy policy);
166
167 // Call a JS function _without_ any stack, heap or execution time limits.
168 // Only to be used, as the name indicates, for calls inside an already
169 // invoked JS function, where the caller has already set up the necessary
170 // limits.
172 const JSWrappedValue& f, const std::vector<JSWrappedValue>& argv);
173
174 // JSON I/O
176 JSWrappedValue parse_json(const nlohmann::json& j) const;
178 const char* buf, size_t buf_len, const char* filename) const;
179
180 // Convert objects to string
181 std::optional<std::string> to_str(const JSWrappedValue& x) const;
182 std::optional<std::string> to_str(const JSValue& x) const;
183 std::optional<std::string> to_str(const JSValue& x, size_t& len) const;
184 std::optional<std::string> to_str(const JSAtom& atom) const;
185
186 void add_extension(const js::extensions::ExtensionPtr& extension);
187 bool remove_extension(const js::extensions::ExtensionPtr& extension);
188
189 template <typename TExtension>
190 TExtension* get_extension()
191 {
192 for (auto& extension : extensions)
193 {
194 if (TExtension* t = dynamic_cast<TExtension*>(extension.get());
195 t != nullptr)
196 {
197 return t;
198 }
199 }
200
201 return nullptr;
202 }
203 };
204}
Definition context.h:46
JSWrappedValue null() const
Definition context.cpp:307
JSWrappedValue new_c_function(JSCFunction *func, const char *name, int length) const
Definition context.cpp:397
JSWrappedValue get_exported_function(const std::string &code, const std::string &func, const std::string &path)
Definition context.cpp:245
bool remove_extension(const js::extensions::ExtensionPtr &extension)
Definition context.cpp:570
ccf::pal::Mutex lock
Definition context.h:63
JSWrappedValue get_global_obj() const
Definition context.cpp:210
void add_extension(const js::extensions::ExtensionPtr &extension)
Definition context.cpp:564
virtual std::optional< JSWrappedValue > get_module(std::string_view module_name)
Definition context.cpp:76
Context & operator=(const Context &)=delete
JSWrappedValue new_obj() const
Definition context.cpp:317
JSWrappedValue new_array_buffer_copy(const uint8_t *buf, size_t buf_len) const
Definition context.cpp:332
JSWrappedValue inner_call(const JSWrappedValue &f, const std::vector< JSWrappedValue > &argv)
Definition context.cpp:472
JSWrappedValue get_typed_array_buffer(const JSWrappedValue &obj, size_t *pbyte_offset, size_t *pbyte_length, size_t *pbytes_per_element) const
Definition context.cpp:235
bool log_execution_metrics
Definition context.h:67
JSWrappedValue undefined() const
Definition context.cpp:312
JSWrappedValue read_object(const uint8_t *buf, size_t buf_len, int flags) const
Definition context.cpp:424
const TxAccess access
Definition context.h:65
virtual ~Context()
Definition context.cpp:70
JSWrappedValue eval(const char *input, size_t input_len, const char *filename, int eval_flags) const
Definition context.cpp:415
JSWrappedValue new_internal_error(const char *fmt,...) const
Definition context.cpp:379
JSWrappedValue new_getter_c_function(JSCFunction *func, const char *name, size_t arg_count=0) const
Definition context.cpp:403
InterruptData interrupt_data
Definition context.h:66
JSValue extract_string_array(JSValueConst &argv, std::vector< std::string > &out)
Definition context.cpp:134
JSWrappedValue parse_json(const nlohmann::json &j) const
Definition context.cpp:499
JSWrappedValue new_type_error(const char *fmt,...) const
Definition context.cpp:370
JSWrappedValue new_tag_value(int tag, int32_t val=0) const
Definition context.cpp:388
std::optional< std::string > to_str(const JSWrappedValue &x) const
Definition context.cpp:511
JSWrappedValue new_string_len(const char *buf, size_t buf_len) const
Definition context.cpp:358
std::pair< std::string, std::optional< std::string > > error_message()
Definition context.cpp:177
JSWrappedValue get_property(JSValue object, char const *property_name) const
Definition context.cpp:204
JSWrappedValue new_string(const std::string_view &str) const
Definition context.cpp:353
Context(const Context &)=delete
JSWrappedValue new_obj_class(JSClassID class_id) const
Definition context.cpp:322
JSWrappedValue json_stringify(const JSWrappedValue &obj) const
Definition context.cpp:490
JSWrappedValue duplicate_value(JSValueConst original) const
Definition context.cpp:410
Runtime & runtime()
Definition context.h:78
JSWrappedValue call_with_rt_options(const JSWrappedValue &f, const std::vector< JSWrappedValue > &argv, const std::optional< ccf::JSRuntimeOptions > &options, RuntimeLimitsPolicy policy)
Definition context.cpp:452
TExtension * get_extension()
Definition context.h:190
JSWrappedValue get_or_create_global_property(const char *s, JSWrappedValue default_value) const
Definition context.cpp:221
JSWrappedValue wrap(JSValue &&val) const
Definition context.cpp:122
JSWrappedValue new_array() const
Definition context.cpp:327
void set_module_loader(const modules::ModuleLoaderPtr &ml)
Definition context.h:88
JSWrappedValue get_global_property(const char *s) const
Definition context.cpp:215
Definition runtime.h:19
std::shared_ptr< State > StatePtr
Definition historical_queries_interface.h:41
Definition constants.h:8
RuntimeLimitsPolicy
Definition runtime.h:13
std::vector< ExtensionPtr > Extensions
Definition extension_interface.h:24
std::shared_ptr< ExtensionInterface > ExtensionPtr
Definition extension_interface.h:23
std::shared_ptr< ModuleLoaderInterface > ModuleLoaderPtr
Definition module_loader_interface.h:29
TxAccess
Definition tx_access.h:10
std::mutex Mutex
Definition locking.h:12
Definition app_interface.h:14
State
Definition http_parser.h:122
Definition context.h:38
ccf::js::TxAccess access
Definition context.h:41
std::chrono::high_resolution_clock::time_point start_time
Definition context.h:39
bool request_timed_out
Definition context.h:42
std::chrono::milliseconds max_execution_time
Definition context.h:40
Definition wrapped_value.h:13