处理 gm add element csp问题
This commit is contained in:
@ -1,4 +1,6 @@
|
|||||||
|
import Logger from "@App/app/logger/logger";
|
||||||
import { Message, MessageConnect, MessageSend, MessageSender } from "./server";
|
import { Message, MessageConnect, MessageSend, MessageSender } from "./server";
|
||||||
|
import LoggerCore from "@App/app/logger/core";
|
||||||
|
|
||||||
export class ExtensionMessageSend implements MessageSend {
|
export class ExtensionMessageSend implements MessageSend {
|
||||||
constructor() {}
|
constructor() {}
|
||||||
@ -44,6 +46,10 @@ export class ServiceWorkerMessage extends ExtensionMessageSend implements Messag
|
|||||||
}
|
}
|
||||||
|
|
||||||
export class ExtensionMessage extends ExtensionMessageSend implements Message {
|
export class ExtensionMessage extends ExtensionMessageSend implements Message {
|
||||||
|
constructor(private onUserScript = false) {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
onConnect(callback: (data: any, con: MessageConnect) => void) {
|
onConnect(callback: (data: any, con: MessageConnect) => void) {
|
||||||
chrome.runtime.onConnect.addListener((port) => {
|
chrome.runtime.onConnect.addListener((port) => {
|
||||||
const handler = (msg: any) => {
|
const handler = (msg: any) => {
|
||||||
@ -52,6 +58,16 @@ export class ExtensionMessage extends ExtensionMessageSend implements Message {
|
|||||||
};
|
};
|
||||||
port.onMessage.addListener(handler);
|
port.onMessage.addListener(handler);
|
||||||
});
|
});
|
||||||
|
if (this.onUserScript) {
|
||||||
|
// 监听用户脚本的连接
|
||||||
|
chrome.runtime.onUserScriptConnect.addListener((port) => {
|
||||||
|
const handler = (msg: any) => {
|
||||||
|
port.onMessage.removeListener(handler);
|
||||||
|
callback(msg, new ExtensionMessageConnect(port));
|
||||||
|
};
|
||||||
|
port.onMessage.addListener(handler);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 注意chrome.runtime.onMessage.addListener的回调函数需要返回true才能处理异步请求
|
// 注意chrome.runtime.onMessage.addListener的回调函数需要返回true才能处理异步请求
|
||||||
@ -62,6 +78,15 @@ export class ExtensionMessage extends ExtensionMessageSend implements Message {
|
|||||||
}
|
}
|
||||||
return callback(msg, sendResponse, sender);
|
return callback(msg, sendResponse, sender);
|
||||||
});
|
});
|
||||||
|
if (this.onUserScript) {
|
||||||
|
// 监听用户脚本的消息
|
||||||
|
chrome.runtime.onUserScriptMessage.addListener((msg, sender, sendResponse) => {
|
||||||
|
if (msg.action === "messageQueue") {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return callback(msg, sendResponse, sender);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,9 +60,7 @@ export default class ContentRuntime {
|
|||||||
parentNode = (this.msg as CustomEventMessage).getAndDelRelatedTarget(parentNodeId);
|
parentNode = (this.msg as CustomEventMessage).getAndDelRelatedTarget(parentNodeId);
|
||||||
}
|
}
|
||||||
const el = <Element>document.createElement(tagName);
|
const el = <Element>document.createElement(tagName);
|
||||||
Object.keys(attr).forEach((key) => {
|
|
||||||
el.setAttribute(key, attr[key]);
|
|
||||||
});
|
|
||||||
let textContent = "";
|
let textContent = "";
|
||||||
if (attr) {
|
if (attr) {
|
||||||
if (attr.textContent) {
|
if (attr.textContent) {
|
||||||
@ -72,6 +70,9 @@ export default class ContentRuntime {
|
|||||||
} else {
|
} else {
|
||||||
attr = {};
|
attr = {};
|
||||||
}
|
}
|
||||||
|
Object.keys(attr).forEach((key) => {
|
||||||
|
el.setAttribute(key, attr[key]);
|
||||||
|
});
|
||||||
if (textContent) {
|
if (textContent) {
|
||||||
el.innerHTML = textContent;
|
el.innerHTML = textContent;
|
||||||
}
|
}
|
||||||
|
@ -247,6 +247,10 @@ export class RuntimeService {
|
|||||||
registerInjectScript() {
|
registerInjectScript() {
|
||||||
chrome.userScripts.getScripts({ ids: ["scriptcat-inject"] }).then((res) => {
|
chrome.userScripts.getScripts({ ids: ["scriptcat-inject"] }).then((res) => {
|
||||||
if (res.length == 0) {
|
if (res.length == 0) {
|
||||||
|
chrome.userScripts.configureWorld({
|
||||||
|
csp: "script-src 'self' 'unsafe-inline' 'unsafe-eval' *",
|
||||||
|
messaging: true,
|
||||||
|
});
|
||||||
fetch("inject.js")
|
fetch("inject.js")
|
||||||
.then((res) => res.text())
|
.then((res) => res.text())
|
||||||
.then(async (injectJs) => {
|
.then(async (injectJs) => {
|
||||||
@ -261,18 +265,17 @@ export class RuntimeService {
|
|||||||
world: "MAIN",
|
world: "MAIN",
|
||||||
runAt: "document_start",
|
runAt: "document_start",
|
||||||
},
|
},
|
||||||
]);
|
// 注册content
|
||||||
});
|
|
||||||
chrome.scripting.registerContentScripts([
|
|
||||||
{
|
{
|
||||||
id: "scriptcat-content",
|
id: "scriptcat-content",
|
||||||
js: ["src/content.js"],
|
js: [{ file: "src/content.js" }],
|
||||||
matches: ["<all_urls>"],
|
matches: ["<all_urls>"],
|
||||||
allFrames: true,
|
allFrames: true,
|
||||||
runAt: "document_start",
|
runAt: "document_start",
|
||||||
world: "ISOLATED",
|
world: "USER_SCRIPT",
|
||||||
},
|
},
|
||||||
]);
|
]);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -426,7 +429,6 @@ export class RuntimeService {
|
|||||||
if (script.metadata["run-at"]) {
|
if (script.metadata["run-at"]) {
|
||||||
registerScript.runAt = getRunAt(script.metadata["run-at"]);
|
registerScript.runAt = getRunAt(script.metadata["run-at"]);
|
||||||
}
|
}
|
||||||
console.log("registerScript", script.name, registerScript, scriptMatchInfo);
|
|
||||||
if (await Cache.getInstance().get("registryScript:" + script.uuid)) {
|
if (await Cache.getInstance().get("registryScript:" + script.uuid)) {
|
||||||
await chrome.userScripts.update([registerScript]);
|
await chrome.userScripts.update([registerScript]);
|
||||||
} else {
|
} else {
|
||||||
|
@ -56,7 +56,7 @@ async function main() {
|
|||||||
});
|
});
|
||||||
loggerCore.logger().debug("service worker start");
|
loggerCore.logger().debug("service worker start");
|
||||||
// 初始化管理器
|
// 初始化管理器
|
||||||
const message = new ExtensionMessage();
|
const message = new ExtensionMessage(true);
|
||||||
const server = new Server("serviceWorker", message);
|
const server = new Server("serviceWorker", message);
|
||||||
const manager = new ServiceWorkerManager(server, new MessageQueue(), new ServiceWorkerMessageSend());
|
const manager = new ServiceWorkerManager(server, new MessageQueue(), new ServiceWorkerMessageSend());
|
||||||
manager.initManager();
|
manager.initManager();
|
||||||
|
Reference in New Issue
Block a user