Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[EB] Arriseos 41993/1 #150

Open
wants to merge 1 commit into
base: lgi-main-20220329
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
95 changes: 39 additions & 56 deletions WebKitBrowser/WebKitImplementation.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -825,8 +825,8 @@ static GSourceFuncs _handlerIntervention =
, _frameCount(0)
, _lastDumpTime(g_get_monotonic_time())
, _allowMixedContent(true)
, _userScripts()
, _userStyleSheets()
, _userScript()
, _userStyleSheet()
, _securityProfileName()
{
// Register an @Exit, in case we are killed, with an incorrect ref count !!
Expand Down Expand Up @@ -866,12 +866,12 @@ static GSourceFuncs _handlerIntervention =

public:
#ifdef WEBKIT_GLIB_API
uint32_t Headers(IStringIterator*& header) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t Headers(IStringIterator* const header) override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserScripts(IStringIterator*& uris) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserScripts(IStringIterator* const uris) override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserStyleSheets(IStringIterator*& uris) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserStyleSheets(IStringIterator* const uris) override { return Core::ERROR_UNAVAILABLE; }
uint32_t Headers(string& header) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t Headers(const string& header) override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserScripts(string& uri) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserScripts(const string& uri) override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserStyleSheets(string& uri) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserStyleSheets(const string& uri) override { return Core::ERROR_UNAVAILABLE; }
uint32_t HeaderList(string& headerlist) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t HeaderList(const string& headerlist) override { return Core::ERROR_UNAVAILABLE; }
uint32_t UserAgent(string& ua) const override { return Core::ERROR_UNAVAILABLE; }
Expand All @@ -885,67 +885,59 @@ static GSourceFuncs _handlerIntervention =
uint32_t MixedContentPolicy(MixedContentPolicyType& policy) const override { return Core::ERROR_UNAVAILABLE; }
uint32_t MixedContentPolicy(const MixedContentPolicyType policy) override { return Core::ERROR_UNAVAILABLE; }
#else
uint32_t Headers(IStringIterator*& header) const override
uint32_t Headers(string& header) const override
{
return Core::ERROR_NONE;
}

uint32_t Headers(IStringIterator* const header) override
uint32_t Headers(const string& header) override
{
return Core::ERROR_NONE;
}

uint32_t UserScripts(IStringIterator*& uris) const override
uint32_t UserScripts(string& uri) const override
{
_adminLock.Lock();
uris = Core::Service<RPC::StringIterator>::Create<RPC::IStringIterator>(_userScripts);
uri = _userScript;
_adminLock.Unlock();
return Core::ERROR_NONE;
}

uint32_t UserScripts(IStringIterator* const uris) override
uint32_t UserScripts(const string& uri) override
{
string entry;
std::vector<string> userScriptsContent;
std::list<string> userScriptsUris;
while (uris->Next(entry)) {
auto content = GetFileContent(entry);
if (!content.empty()) {
userScriptsUris.push_back(entry);
userScriptsContent.push_back(content);
}
TRACE_L1("Adding user's script (uri: %s, empty: %d)", entry.c_str(), content.empty());
}
using SetUserScriptsData = std::tuple<WebKitImplementation*, std::list<string>, std::vector<string>>;
auto* data = new SetUserScriptsData(this, userScriptsUris, userScriptsContent);
const auto content = GetFileContent(uri);
TRACE_L1("Setting user's script (uri: %s, empty: %d)", uri.c_str(), content.empty());

using SetUserScriptsData = std::tuple<WebKitImplementation*, string, string>;
auto* data = new SetUserScriptsData(this, uri, content);

g_main_context_invoke_full(
_context,
G_PRIORITY_DEFAULT,
[](gpointer customdata) -> gboolean {
auto& data = *static_cast<SetUserScriptsData*>(customdata);
WebKitImplementation* object = std::get<0>(data);
std::list<string> scriptsUris = std::get<1>(data);
std::vector<string> scriptsContent = std::get<2>(data);
const auto& scriptUri = std::get<1>(data);
const auto& scriptContent = std::get<2>(data);

object->_adminLock.Lock();
object->_userScripts = scriptsUris;
object->_userScript = scriptUri;
object->_adminLock.Unlock();

// Remove all user scripts
WKPageGroupRemoveAllUserScripts(object->_pageGroup);

for (string entry : scriptsContent) {
if (!scriptContent.empty()) {
WKPageGroupAddUserScript(
object->_pageGroup,
WKStringCreateWithUTF8CString(entry.c_str()),
WKStringCreateWithUTF8CString(scriptContent.c_str()),
nullptr,
nullptr,
nullptr,
kWKInjectInTopFrameOnly,
kWKInjectAtDocumentStart);
}


return G_SOURCE_REMOVE;
},
data,
Expand All @@ -956,49 +948,40 @@ static GSourceFuncs _handlerIntervention =
return Core::ERROR_NONE;
}

uint32_t UserStyleSheets(IStringIterator*& uris) const override
uint32_t UserStyleSheets(string& uri) const override
{
_adminLock.Lock();
uris = Core::Service<RPC::StringIterator>::Create<RPC::IStringIterator>(_userStyleSheets);
uri = _userStyleSheet;
_adminLock.Unlock();
return Core::ERROR_NONE;
}
uint32_t UserStyleSheets(IStringIterator* const uris) override
uint32_t UserStyleSheets(const string& uri) override
{
string entry;
std::vector<string> userStyleSheetsContent;
std::list<string> userStyleSheetsUris;
while (uris->Next(entry)) {
auto content = GetFileContent(entry);
if (!content.empty()) {
userStyleSheetsUris.push_back(entry);
userStyleSheetsContent.push_back(content);
}
TRACE_L1("Adding user's style sheet (uri: %s, empty: %d)", entry.c_str(), content.empty());
}
using SetUserStyleSheetsData = std::tuple<WebKitImplementation*, std::list<string>, std::vector<string>>;
auto* data = new SetUserStyleSheetsData(this, userStyleSheetsUris, userStyleSheetsContent);
const auto content = GetFileContent(uri);
TRACE_L1("Setting user's style sheet (uri: %s, empty: %d)", uri.c_str(), content.empty());

using SetUserStyleSheetsData = std::tuple<WebKitImplementation*, string, string>;
auto* data = new SetUserStyleSheetsData(this, uri, content);

g_main_context_invoke_full(
_context,
G_PRIORITY_DEFAULT,
[](gpointer customdata) -> gboolean {
auto& data = *static_cast<SetUserStyleSheetsData*>(customdata);
WebKitImplementation* object = std::get<0>(data);
std::list<string> styleSheetsUris = std::get<1>(data);
std::vector<string> styleSheetsContent = std::get<2>(data);
const auto& styleSheetUri = std::get<1>(data);
const auto& styleSheetContent = std::get<2>(data);

object->_adminLock.Lock();
object->_userStyleSheets = styleSheetsUris;
object->_userStyleSheet = styleSheetUri;
object->_adminLock.Unlock();

// Remove all style sheets
WKPageGroupRemoveAllUserStyleSheets(object->_pageGroup);

for (string entry : styleSheetsContent) {
if (!styleSheetContent.empty()) {
WKPageGroupAddUserStyleSheet(
object->_pageGroup,
WKStringCreateWithUTF8CString(entry.c_str()),
WKStringCreateWithUTF8CString(styleSheetContent.c_str()),
nullptr,
nullptr,
nullptr,
Expand Down Expand Up @@ -3163,8 +3146,8 @@ static GSourceFuncs _handlerIntervention =
unsigned _frameCount;
gint64 _lastDumpTime;
bool _allowMixedContent;
std::list<string> _userScripts;
std::list<string> _userStyleSheets;
string _userScript;
string _userStyleSheet;
string _securityProfileName;
};

Expand Down