vg-coder-cli 2.0.22 → 2.0.24

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/.vg/tree-state.json +9 -0
  2. package/package.json +3 -1
  3. package/scripts/build.js +49 -6
  4. package/src/server/api-server.js +46 -0
  5. package/src/server/terminal-manager.js +10 -1
  6. package/src/server/views/css/structure.css +4 -1
  7. package/src/server/views/dashboard.css +24 -1
  8. package/src/server/views/dashboard.html +2 -0
  9. package/src/server/views/js/api.js +24 -0
  10. package/src/server/views/js/features/resize.js +57 -0
  11. package/src/server/views/js/features/structure.js +109 -16
  12. package/src/server/views/js/main.js +5 -0
  13. package/src/server/views/vg-coder/background.js +48201 -2
  14. package/src/server/views/vg-coder/controller.js +496 -1
  15. package/src/server/views/vg-coder/manifest.json +13 -5
  16. package/src/server/views/vg-coder/{options.css → sidepanel.css} +34 -32
  17. package/src/server/views/vg-coder/{options.html → sidepanel.html} +2 -2
  18. package/src/server/views/vg-coder/sidepanel.js +347 -0
  19. package/vetgo-auto/README.md +3 -0
  20. package/vetgo-auto/chrome/CSP_IMPROVEMENTS.md +147 -0
  21. package/vetgo-auto/chrome/MANIFEST_V3_MIGRATION.md +123 -0
  22. package/vetgo-auto/chrome/assets/icon128.png +0 -0
  23. package/vetgo-auto/chrome/assets/icon16.png +0 -0
  24. package/vetgo-auto/chrome/assets/icon48.png +0 -0
  25. package/vetgo-auto/chrome/environments/environment.ts +13 -0
  26. package/vetgo-auto/chrome/manifest.json +66 -0
  27. package/vetgo-auto/chrome/rules.json +23 -0
  28. package/vetgo-auto/chrome/src/background.ts +200 -0
  29. package/vetgo-auto/chrome/src/controller.ts +98 -0
  30. package/vetgo-auto/chrome/src/controllers/common.firebase.ts +31 -0
  31. package/vetgo-auto/chrome/src/controllers/firebase-crud.ts +147 -0
  32. package/vetgo-auto/chrome/src/controllers/load-common-fuc.controller.ts +24 -0
  33. package/vetgo-auto/chrome/src/controllers/load-script.controller.ts +23 -0
  34. package/vetgo-auto/chrome/src/script-injector.ts +305 -0
  35. package/vetgo-auto/chrome/src/sidepanel.css +166 -0
  36. package/vetgo-auto/chrome/src/sidepanel.html +48 -0
  37. package/vetgo-auto/chrome/src/sidepanel.ts +127 -0
  38. package/vetgo-auto/chrome/src/utils/db-utils.ts +2 -0
  39. package/vetgo-auto/chrome/src/utils/environment-storage.service.ts +85 -0
  40. package/vetgo-auto/chrome/webpack.config.js +53 -0
  41. package/vetgo-auto/chrome/webpack.config.prod.js +54 -0
  42. package/vetgo-auto/package.json +30 -0
  43. package/vetgo-auto/tsconfig.json +27 -0
  44. package/vg-coder-cli-2.0.23.tgz +0 -0
  45. package/vg-coder-cli-2.0.24.tgz +0 -0
  46. package/src/server/views/vg-coder/background.js.LICENSE.txt +0 -118
  47. package/src/server/views/vg-coder/options.js +0 -1
  48. package/vg-coder-cli-2.0.21.tgz +0 -0
  49. package/vg-coder-cli-2.0.22.tgz +0 -0
  50. package/vg-coder.zip +0 -0
@@ -1 +1,496 @@
1
- (()=>{"use strict";var e=function(e,t,n,o){return new(n||(n=Promise))(function(r,i){function c(e){try{s(o.next(e))}catch(e){i(e)}}function a(e){try{s(o.throw(e))}catch(e){i(e)}}function s(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n(function(e){e(t)})).then(c,a)}s((o=o.apply(e,t||[])).next())})};class t{static detectStrictCSP(){try{const e=document.querySelectorAll('meta[http-equiv="Content-Security-Policy"]');for(let t=0;t<e.length;t++){const n=e[t].getAttribute("content")||"";if(n.includes("script-src")&&!n.includes("blob:")&&!n.includes("data:"))return!0}const t=["midjourney.com","openai.com","github.com","google.com","googletagmanager.com","facebook.com","twitter.com","linkedin.com"],n=window.location.hostname.toLowerCase();return t.some(e=>n.includes(e))}catch(e){return console.error("CSP detection error:",e),!1}}static getHeadElement(){return new Promise(e=>{const t=()=>{const n=document.head||document.getElementsByTagName("head")[0];if(n)e(n);else if("loading"===document.readyState)document.addEventListener("DOMContentLoaded",t,{once:!0});else{const n=document.createElement("head");document.documentElement?(document.documentElement.appendChild(n),e(n)):setTimeout(t,100)}};t()})}static injectViaBlob(t,n){return e(this,void 0,void 0,function*(){try{const o=new Blob([t],{type:"application/javascript"}),r=URL.createObjectURL(o),i=document.createElement("script");return i.type="text/javascript",i.id=n,i.src=r,new Promise(t=>e(this,void 0,void 0,function*(){i.onload=()=>{URL.revokeObjectURL(r),t(!0)},i.onerror=()=>{URL.revokeObjectURL(r),t(!1)};try{(yield this.getHeadElement()).appendChild(i)}catch(e){console.error("Failed to get head element:",e),URL.revokeObjectURL(r),t(!1)}}))}catch(e){return console.error("Blob injection failed:",e),!1}})}static injectViaDataUrl(t,n){return e(this,void 0,void 0,function*(){try{const o="data:application/javascript;base64,"+btoa(t),r=document.createElement("script");return r.type="text/javascript",r.id=n+"_data",r.src=o,new Promise(t=>e(this,void 0,void 0,function*(){r.onload=()=>t(!0),r.onerror=()=>t(!1);try{(yield this.getHeadElement()).appendChild(r)}catch(e){console.error("Failed to get head element for data URL:",e),t(!1)}}))}catch(e){return console.error("Data URL injection failed:",e),!1}})}static injectViaPostMessage(e,t){return new Promise(n=>{try{const o="\n window.addEventListener('message', function(event) {\n if (event.source !== window || !event.data.type || event.data.type !== 'VETGO_SCRIPT_INJECT') {\n return;\n }\n try {\n const func = new Function(event.data.script);\n func();\n window.postMessage({type: 'VETGO_SCRIPT_SUCCESS', actionType: event.data.actionType}, '*');\n } catch (error) {\n console.error('PostMessage script execution failed:', error);\n window.postMessage({type: 'VETGO_SCRIPT_ERROR', actionType: event.data.actionType, error: error.message}, '*');\n }\n });\n ";this.injectViaBlob(o,t+"_bridge").then(o=>{if(o){const o=e=>{e.source===window&&e.data.type&&("VETGO_SCRIPT_SUCCESS"===e.data.type&&e.data.actionType===t?(window.removeEventListener("message",o),n(!0)):"VETGO_SCRIPT_ERROR"===e.data.type&&e.data.actionType===t&&(window.removeEventListener("message",o),n(!1)))};window.addEventListener("message",o),window.postMessage({type:"VETGO_SCRIPT_INJECT",script:e,actionType:t},"*"),setTimeout(()=>{window.removeEventListener("message",o),n(!1)},5e3)}else n(!1)})}catch(e){console.error("PostMessage injection failed:",e),n(!1)}})}static injectViaBackground(e,t){return new Promise(n=>{try{chrome.runtime.sendMessage({action:"INJECT_SCRIPT",script:e,actionType:t},e=>{chrome.runtime.lastError?(console.error("Background injection failed:",chrome.runtime.lastError),n(!1)):n(e&&e.success)})}catch(e){console.error("Background script injection failed:",e),n(!1)}})}static injectViaEval(e,t){return new Promise(n=>{try{console.log(`Attempting direct eval for ${t}`);n(new Function("script",`\n try {\n ${e}\n return true;\n } catch (error) {\n console.error('Eval execution error:', error);\n return false;\n }\n `)(e))}catch(e){console.error("Eval injection failed:",e),n(!1)}})}static injectScript(t,n){return e(this,void 0,void 0,function*(){const e=this.detectStrictCSP(),o=e?[()=>this.injectViaBackground(t,n),()=>this.injectViaEval(t,n),()=>this.injectViaPostMessage(t,n),()=>this.injectViaBlob(t,n),()=>this.injectViaDataUrl(t,n)]:[()=>this.injectViaBlob(t,n),()=>this.injectViaDataUrl(t,n),()=>this.injectViaBackground(t,n),()=>this.injectViaEval(t,n),()=>this.injectViaPostMessage(t,n)];console.log(`Injecting script for ${n} (Strict CSP: ${e})`);for(let t=0;t<o.length;t++){const r=o[t],i=e?["Background","Eval","PostMessage","Blob","DataURL"][t]:["Blob","DataURL","Background","Eval","PostMessage"][t];try{if(console.log(`Trying ${i} injection...`),yield r())return console.log(`✅ Script injection successful via ${i} for ${n}`),!0;console.log(`❌ ${i} injection failed for ${n}`)}catch(e){console.error(`❌ ${i} injection error:`,e)}}return console.error(`❌ All injection methods failed for ${n}`),!1})}}var n=function(e,t,n,o){return new(n||(n=Promise))(function(r,i){function c(e){try{s(o.next(e))}catch(e){i(e)}}function a(e){try{s(o.throw(e))}catch(e){i(e)}}function s(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n(function(e){e(t)})).then(c,a)}s((o=o.apply(e,t||[])).next())})};const o=(e,o)=>n(void 0,void 0,void 0,function*(){try{(yield t.injectScript(e,o))||console.error("All script injection methods failed for:",o)}catch(e){console.error("Script injection error:",e)}}),r=()=>new Promise(e=>{"loading"===document.readyState?document.addEventListener("DOMContentLoaded",()=>e(),{once:!0}):e()});n(void 0,void 0,void 0,function*(){try{yield r();const e=new URL(window.location.href).searchParams.get("actionType")||"MAIN",t=sessionStorage.getItem(e);t?yield o(t,e):chrome.runtime.sendMessage({action:"CONTROLLER",domain:window.location.hostname.replace(/(https?:\/\/)?(www.)?/i,""),actionType:e},t=>n(void 0,void 0,void 0,function*(){if(chrome.runtime.lastError)console.error("Runtime error:",chrome.runtime.lastError);else if(t&&t.script){const n=`var chromeId = "${chrome.runtime.id}"; ${t.script}`;yield o(n,e),sessionStorage.setItem(e,n)}}))}catch(e){console.error("Controller initialization error:",e)}}),n(void 0,void 0,void 0,function*(){try{yield r();const e=()=>new Promise(e=>{const t=()=>{const n=document.querySelector("body");n?e(n):setTimeout(t,100)};t()});(yield e()).addEventListener("REMOVE_EXTENSION",function(e){console.log(e.detail),chrome.runtime.sendMessage({action:"REMOVE_EXTENSION",data:e.detail},e=>{chrome.runtime.lastError?console.error("Runtime error:",chrome.runtime.lastError):console.log("tu huy thanh cong",e)})})}catch(e){console.error("Setup remove extension listener error:",e)}})})();
1
+ /******/ (() => { // webpackBootstrap
2
+ /******/ "use strict";
3
+ /******/ var __webpack_modules__ = ({
4
+
5
+ /***/ "./chrome/src/script-injector.ts":
6
+ /*!***************************************!*\
7
+ !*** ./chrome/src/script-injector.ts ***!
8
+ \***************************************/
9
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
10
+
11
+ __webpack_require__.r(__webpack_exports__);
12
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
13
+ /* harmony export */ ScriptInjector: () => (/* binding */ ScriptInjector)
14
+ /* harmony export */ });
15
+ // Alternative script injection methods for CSP-restricted environments
16
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
17
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
18
+ return new (P || (P = Promise))(function (resolve, reject) {
19
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
20
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
21
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
22
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
23
+ });
24
+ };
25
+ class ScriptInjector {
26
+ /**
27
+ * Detect if site has strict CSP that blocks blob/data URLs
28
+ */
29
+ static detectStrictCSP() {
30
+ try {
31
+ // Check for CSP meta tags
32
+ const cspMetas = document.querySelectorAll('meta[http-equiv="Content-Security-Policy"]');
33
+ for (let i = 0; i < cspMetas.length; i++) {
34
+ const meta = cspMetas[i];
35
+ const content = meta.getAttribute('content') || '';
36
+ if (content.includes('script-src') && !content.includes('blob:') && !content.includes('data:')) {
37
+ return true;
38
+ }
39
+ }
40
+ // Check common strict CSP domains
41
+ const strictDomains = [
42
+ 'midjourney.com',
43
+ 'openai.com',
44
+ 'github.com',
45
+ 'google.com',
46
+ 'googletagmanager.com',
47
+ 'facebook.com',
48
+ 'twitter.com',
49
+ 'linkedin.com'
50
+ ];
51
+ const hostname = window.location.hostname.toLowerCase();
52
+ return strictDomains.some(domain => hostname.includes(domain));
53
+ }
54
+ catch (error) {
55
+ console.error('CSP detection error:', error);
56
+ return false;
57
+ }
58
+ }
59
+ /**
60
+ * Safely get head element or wait for it
61
+ */
62
+ static getHeadElement() {
63
+ return new Promise((resolve) => {
64
+ const tryGetHead = () => {
65
+ const head = document.head || document.getElementsByTagName('head')[0];
66
+ if (head) {
67
+ resolve(head);
68
+ return;
69
+ }
70
+ // If no head, wait for DOM
71
+ if (document.readyState === 'loading') {
72
+ document.addEventListener('DOMContentLoaded', tryGetHead, { once: true });
73
+ }
74
+ else {
75
+ // Create head if it doesn't exist
76
+ const newHead = document.createElement('head');
77
+ if (document.documentElement) {
78
+ document.documentElement.appendChild(newHead);
79
+ resolve(newHead);
80
+ }
81
+ else {
82
+ // Last resort: wait a bit and try again
83
+ setTimeout(tryGetHead, 100);
84
+ }
85
+ }
86
+ };
87
+ tryGetHead();
88
+ });
89
+ }
90
+ /**
91
+ * Method 1: Blob URL injection (works in most cases)
92
+ */
93
+ static injectViaBlob(script, actionType) {
94
+ return __awaiter(this, void 0, void 0, function* () {
95
+ try {
96
+ const blob = new Blob([script], { type: 'application/javascript' });
97
+ const blobUrl = URL.createObjectURL(blob);
98
+ const scriptElement = document.createElement('script');
99
+ scriptElement.type = 'text/javascript';
100
+ scriptElement.id = actionType;
101
+ scriptElement.src = blobUrl;
102
+ return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {
103
+ scriptElement.onload = () => {
104
+ URL.revokeObjectURL(blobUrl);
105
+ resolve(true);
106
+ };
107
+ scriptElement.onerror = () => {
108
+ URL.revokeObjectURL(blobUrl);
109
+ resolve(false);
110
+ };
111
+ try {
112
+ const head = yield this.getHeadElement();
113
+ head.appendChild(scriptElement);
114
+ }
115
+ catch (error) {
116
+ console.error('Failed to get head element:', error);
117
+ URL.revokeObjectURL(blobUrl);
118
+ resolve(false);
119
+ }
120
+ }));
121
+ }
122
+ catch (error) {
123
+ console.error('Blob injection failed:', error);
124
+ return false;
125
+ }
126
+ });
127
+ }
128
+ /**
129
+ * Method 2: Data URL injection (fallback)
130
+ */
131
+ static injectViaDataUrl(script, actionType) {
132
+ return __awaiter(this, void 0, void 0, function* () {
133
+ try {
134
+ const dataUrl = 'data:application/javascript;base64,' + btoa(script);
135
+ const scriptElement = document.createElement('script');
136
+ scriptElement.type = 'text/javascript';
137
+ scriptElement.id = actionType + '_data';
138
+ scriptElement.src = dataUrl;
139
+ return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {
140
+ scriptElement.onload = () => resolve(true);
141
+ scriptElement.onerror = () => resolve(false);
142
+ try {
143
+ const head = yield this.getHeadElement();
144
+ head.appendChild(scriptElement);
145
+ }
146
+ catch (error) {
147
+ console.error('Failed to get head element for data URL:', error);
148
+ resolve(false);
149
+ }
150
+ }));
151
+ }
152
+ catch (error) {
153
+ console.error('Data URL injection failed:', error);
154
+ return false;
155
+ }
156
+ });
157
+ }
158
+ /**
159
+ * Method 3: PostMessage bridge injection
160
+ */
161
+ static injectViaPostMessage(script, actionType) {
162
+ return new Promise((resolve) => {
163
+ try {
164
+ // Create a bridge script that listens for postMessage
165
+ const bridgeScript = `
166
+ window.addEventListener('message', function(event) {
167
+ if (event.source !== window || !event.data.type || event.data.type !== 'VETGO_SCRIPT_INJECT') {
168
+ return;
169
+ }
170
+ try {
171
+ const func = new Function(event.data.script);
172
+ func();
173
+ window.postMessage({type: 'VETGO_SCRIPT_SUCCESS', actionType: event.data.actionType}, '*');
174
+ } catch (error) {
175
+ console.error('PostMessage script execution failed:', error);
176
+ window.postMessage({type: 'VETGO_SCRIPT_ERROR', actionType: event.data.actionType, error: error.message}, '*');
177
+ }
178
+ });
179
+ `;
180
+ // First inject the bridge
181
+ this.injectViaBlob(bridgeScript, actionType + '_bridge').then((bridgeSuccess) => {
182
+ if (bridgeSuccess) {
183
+ // Listen for response
184
+ const responseHandler = (event) => {
185
+ if (event.source !== window || !event.data.type)
186
+ return;
187
+ if (event.data.type === 'VETGO_SCRIPT_SUCCESS' && event.data.actionType === actionType) {
188
+ window.removeEventListener('message', responseHandler);
189
+ resolve(true);
190
+ }
191
+ else if (event.data.type === 'VETGO_SCRIPT_ERROR' && event.data.actionType === actionType) {
192
+ window.removeEventListener('message', responseHandler);
193
+ resolve(false);
194
+ }
195
+ };
196
+ window.addEventListener('message', responseHandler);
197
+ // Send script via postMessage
198
+ window.postMessage({
199
+ type: 'VETGO_SCRIPT_INJECT',
200
+ script: script,
201
+ actionType: actionType
202
+ }, '*');
203
+ // Timeout after 5 seconds
204
+ setTimeout(() => {
205
+ window.removeEventListener('message', responseHandler);
206
+ resolve(false);
207
+ }, 5000);
208
+ }
209
+ else {
210
+ resolve(false);
211
+ }
212
+ });
213
+ }
214
+ catch (error) {
215
+ console.error('PostMessage injection failed:', error);
216
+ resolve(false);
217
+ }
218
+ });
219
+ }
220
+ /**
221
+ * Method 4: Background script injection via chrome.scripting
222
+ */
223
+ static injectViaBackground(script, actionType) {
224
+ return new Promise((resolve) => {
225
+ try {
226
+ chrome.runtime.sendMessage({
227
+ action: "INJECT_SCRIPT",
228
+ script: script,
229
+ actionType: actionType
230
+ }, (response) => {
231
+ if (chrome.runtime.lastError) {
232
+ console.error('Background injection failed:', chrome.runtime.lastError);
233
+ resolve(false);
234
+ }
235
+ else {
236
+ resolve(response && response.success);
237
+ }
238
+ });
239
+ }
240
+ catch (error) {
241
+ console.error('Background script injection failed:', error);
242
+ resolve(false);
243
+ }
244
+ });
245
+ }
246
+ /**
247
+ * Method 5: Direct eval in content script context (last resort)
248
+ */
249
+ static injectViaEval(script, actionType) {
250
+ return new Promise((resolve) => {
251
+ try {
252
+ console.log(`Attempting direct eval for ${actionType}`);
253
+ // Create isolated function to avoid polluting global scope
254
+ const isolatedExecution = new Function('script', `
255
+ try {
256
+ ${script}
257
+ return true;
258
+ } catch (error) {
259
+ console.error('Eval execution error:', error);
260
+ return false;
261
+ }
262
+ `);
263
+ const success = isolatedExecution(script);
264
+ resolve(success);
265
+ }
266
+ catch (error) {
267
+ console.error('Eval injection failed:', error);
268
+ resolve(false);
269
+ }
270
+ });
271
+ }
272
+ /**
273
+ * Try all methods in smart order based on CSP detection
274
+ */
275
+ static injectScript(script, actionType) {
276
+ return __awaiter(this, void 0, void 0, function* () {
277
+ const hasStrictCSP = this.detectStrictCSP();
278
+ // Smart method ordering based on CSP detection
279
+ const methods = hasStrictCSP ? [
280
+ // For strict CSP sites, try background injection first
281
+ () => this.injectViaBackground(script, actionType),
282
+ () => this.injectViaEval(script, actionType),
283
+ () => this.injectViaPostMessage(script, actionType),
284
+ () => this.injectViaBlob(script, actionType),
285
+ () => this.injectViaDataUrl(script, actionType)
286
+ ] : [
287
+ // For normal sites, try blob first (fastest)
288
+ () => this.injectViaBlob(script, actionType),
289
+ () => this.injectViaDataUrl(script, actionType),
290
+ () => this.injectViaBackground(script, actionType),
291
+ () => this.injectViaEval(script, actionType),
292
+ () => this.injectViaPostMessage(script, actionType)
293
+ ];
294
+ console.log(`Injecting script for ${actionType} (Strict CSP: ${hasStrictCSP})`);
295
+ for (let i = 0; i < methods.length; i++) {
296
+ const method = methods[i];
297
+ const methodName = hasStrictCSP ?
298
+ ['Background', 'Eval', 'PostMessage', 'Blob', 'DataURL'][i] :
299
+ ['Blob', 'DataURL', 'Background', 'Eval', 'PostMessage'][i];
300
+ try {
301
+ console.log(`Trying ${methodName} injection...`);
302
+ const success = yield method();
303
+ if (success) {
304
+ console.log(`✅ Script injection successful via ${methodName} for ${actionType}`);
305
+ return true;
306
+ }
307
+ else {
308
+ console.log(`❌ ${methodName} injection failed for ${actionType}`);
309
+ }
310
+ }
311
+ catch (error) {
312
+ console.error(`❌ ${methodName} injection error:`, error);
313
+ }
314
+ }
315
+ console.error(`❌ All injection methods failed for ${actionType}`);
316
+ return false;
317
+ });
318
+ }
319
+ }
320
+
321
+
322
+ /***/ })
323
+
324
+ /******/ });
325
+ /************************************************************************/
326
+ /******/ // The module cache
327
+ /******/ var __webpack_module_cache__ = {};
328
+ /******/
329
+ /******/ // The require function
330
+ /******/ function __webpack_require__(moduleId) {
331
+ /******/ // Check if module is in cache
332
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
333
+ /******/ if (cachedModule !== undefined) {
334
+ /******/ return cachedModule.exports;
335
+ /******/ }
336
+ /******/ // Create a new module (and put it into the cache)
337
+ /******/ var module = __webpack_module_cache__[moduleId] = {
338
+ /******/ // no module.id needed
339
+ /******/ // no module.loaded needed
340
+ /******/ exports: {}
341
+ /******/ };
342
+ /******/
343
+ /******/ // Execute the module function
344
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
345
+ /******/
346
+ /******/ // Return the exports of the module
347
+ /******/ return module.exports;
348
+ /******/ }
349
+ /******/
350
+ /************************************************************************/
351
+ /******/ /* webpack/runtime/define property getters */
352
+ /******/ (() => {
353
+ /******/ // define getter functions for harmony exports
354
+ /******/ __webpack_require__.d = (exports, definition) => {
355
+ /******/ for(var key in definition) {
356
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
357
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
358
+ /******/ }
359
+ /******/ }
360
+ /******/ };
361
+ /******/ })();
362
+ /******/
363
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
364
+ /******/ (() => {
365
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
366
+ /******/ })();
367
+ /******/
368
+ /******/ /* webpack/runtime/make namespace object */
369
+ /******/ (() => {
370
+ /******/ // define __esModule on exports
371
+ /******/ __webpack_require__.r = (exports) => {
372
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
373
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
374
+ /******/ }
375
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
376
+ /******/ };
377
+ /******/ })();
378
+ /******/
379
+ /************************************************************************/
380
+ var __webpack_exports__ = {};
381
+ // This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk.
382
+ (() => {
383
+ /*!**********************************!*\
384
+ !*** ./chrome/src/controller.ts ***!
385
+ \**********************************/
386
+ __webpack_require__.r(__webpack_exports__);
387
+ /* harmony import */ var _script_injector__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./script-injector */ "./chrome/src/script-injector.ts");
388
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
389
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
390
+ return new (P || (P = Promise))(function (resolve, reject) {
391
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
392
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
393
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
394
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
395
+ });
396
+ };
397
+
398
+ const addScript = (script, actionType) => __awaiter(void 0, void 0, void 0, function* () {
399
+ try {
400
+ const success = yield _script_injector__WEBPACK_IMPORTED_MODULE_0__.ScriptInjector.injectScript(script, actionType);
401
+ if (!success) {
402
+ console.error('All script injection methods failed for:', actionType);
403
+ }
404
+ }
405
+ catch (error) {
406
+ console.error('Script injection error:', error);
407
+ }
408
+ });
409
+ // Wait for DOM to be ready before executing
410
+ const waitForDOM = () => {
411
+ return new Promise((resolve) => {
412
+ if (document.readyState === 'loading') {
413
+ document.addEventListener('DOMContentLoaded', () => resolve(), { once: true });
414
+ }
415
+ else {
416
+ resolve();
417
+ }
418
+ });
419
+ };
420
+ const initializeController = () => __awaiter(void 0, void 0, void 0, function* () {
421
+ try {
422
+ // Ensure DOM is ready
423
+ yield waitForDOM();
424
+ const actionType = new URL(window.location.href).searchParams.get("actionType") || "MAIN";
425
+ const cache = sessionStorage.getItem(actionType);
426
+ if (cache) {
427
+ yield addScript(cache, actionType);
428
+ }
429
+ else {
430
+ chrome.runtime.sendMessage({
431
+ action: "CONTROLLER",
432
+ domain: window.location.hostname.replace(/(https?:\/\/)?(www.)?/i, ''),
433
+ actionType: actionType
434
+ }, (response) => __awaiter(void 0, void 0, void 0, function* () {
435
+ if (chrome.runtime.lastError) {
436
+ console.error('Runtime error:', chrome.runtime.lastError);
437
+ return;
438
+ }
439
+ if (response && response.script) {
440
+ const fullScript = `var chromeId = "${chrome.runtime.id}"; ${response.script}`;
441
+ yield addScript(fullScript, actionType);
442
+ sessionStorage.setItem(actionType, fullScript);
443
+ }
444
+ }));
445
+ }
446
+ }
447
+ catch (err) {
448
+ console.error('Controller initialization error:', err);
449
+ }
450
+ });
451
+ // Initialize controller
452
+ initializeController();
453
+ const setupRemoveExtensionListener = () => __awaiter(void 0, void 0, void 0, function* () {
454
+ try {
455
+ // Wait for DOM and body to be ready
456
+ yield waitForDOM();
457
+ // Wait for body element
458
+ const waitForBody = () => {
459
+ return new Promise((resolve) => {
460
+ const checkBody = () => {
461
+ const body = document.querySelector('body');
462
+ if (body) {
463
+ resolve(body);
464
+ }
465
+ else {
466
+ setTimeout(checkBody, 100);
467
+ }
468
+ };
469
+ checkBody();
470
+ });
471
+ };
472
+ const body = yield waitForBody();
473
+ // cach dung: document.querySelector('body').dispatchEvent(new CustomEvent('REMOVE_EXTENSION', { detail: { key: 'value' } }));
474
+ body.addEventListener('REMOVE_EXTENSION', function (event) {
475
+ console.log(event.detail); // { key: 'value' }
476
+ chrome.runtime.sendMessage({ action: "REMOVE_EXTENSION", data: event.detail }, (response) => {
477
+ if (chrome.runtime.lastError) {
478
+ console.error('Runtime error:', chrome.runtime.lastError);
479
+ return;
480
+ }
481
+ console.log('tu huy thanh cong', response);
482
+ });
483
+ });
484
+ }
485
+ catch (err) {
486
+ console.error('Setup remove extension listener error:', err);
487
+ }
488
+ });
489
+ // Setup remove extension listener
490
+ setupRemoveExtensionListener();
491
+
492
+ })();
493
+
494
+ /******/ })()
495
+ ;
496
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"controller.js","mappings":"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","sources":["webpack://vg-coder/./chrome/src/script-injector.ts","webpack://vg-coder/webpack/bootstrap","webpack://vg-coder/webpack/runtime/define property getters","webpack://vg-coder/webpack/runtime/hasOwnProperty shorthand","webpack://vg-coder/webpack/runtime/make namespace object","webpack://vg-coder/./chrome/src/controller.ts"],"sourcesContent":["// Alternative script injection methods for CSP-restricted environments\n\nexport class ScriptInjector {\n\n  /**\n   * Detect if site has strict CSP that blocks blob/data URLs\n   */\n  private static detectStrictCSP(): boolean {\n    try {\n      // Check for CSP meta tags\n      const cspMetas = document.querySelectorAll('meta[http-equiv=\"Content-Security-Policy\"]');\n      for (let i = 0; i < cspMetas.length; i++) {\n        const meta = cspMetas[i];\n        const content = meta.getAttribute('content') || '';\n        if (content.includes('script-src') && !content.includes('blob:') && !content.includes('data:')) {\n          return true;\n        }\n      }\n\n      // Check common strict CSP domains\n      const strictDomains = [\n        'midjourney.com',\n        'openai.com',\n        'github.com',\n        'google.com',\n        'googletagmanager.com',\n        'facebook.com',\n        'twitter.com',\n        'linkedin.com'\n      ];\n\n      const hostname = window.location.hostname.toLowerCase();\n      return strictDomains.some(domain => hostname.includes(domain));\n    } catch (error) {\n      console.error('CSP detection error:', error);\n      return false;\n    }\n  }\n\n  /**\n   * Safely get head element or wait for it\n   */\n  private static getHeadElement(): Promise<HTMLHeadElement> {\n    return new Promise((resolve) => {\n      const tryGetHead = () => {\n        const head = document.head || document.getElementsByTagName('head')[0];\n        if (head) {\n          resolve(head as HTMLHeadElement);\n          return;\n        }\n\n        // If no head, wait for DOM\n        if (document.readyState === 'loading') {\n          document.addEventListener('DOMContentLoaded', tryGetHead, { once: true });\n        } else {\n          // Create head if it doesn't exist\n          const newHead = document.createElement('head');\n          if (document.documentElement) {\n            document.documentElement.appendChild(newHead);\n            resolve(newHead);\n          } else {\n            // Last resort: wait a bit and try again\n            setTimeout(tryGetHead, 100);\n          }\n        }\n      };\n\n      tryGetHead();\n    });\n  }\n\n  /**\n   * Method 1: Blob URL injection (works in most cases)\n   */\n  static async injectViaBlob(script: string, actionType: string): Promise<boolean> {\n    try {\n      const blob = new Blob([script], { type: 'application/javascript' });\n      const blobUrl = URL.createObjectURL(blob);\n\n      const scriptElement = document.createElement('script');\n      scriptElement.type = 'text/javascript';\n      scriptElement.id = actionType;\n      scriptElement.src = blobUrl;\n\n      return new Promise(async (resolve) => {\n        scriptElement.onload = () => {\n          URL.revokeObjectURL(blobUrl);\n          resolve(true);\n        };\n\n        scriptElement.onerror = () => {\n          URL.revokeObjectURL(blobUrl);\n          resolve(false);\n        };\n\n        try {\n          const head = await this.getHeadElement();\n          head.appendChild(scriptElement);\n        } catch (error) {\n          console.error('Failed to get head element:', error);\n          URL.revokeObjectURL(blobUrl);\n          resolve(false);\n        }\n      });\n    } catch (error) {\n      console.error('Blob injection failed:', error);\n      return false;\n    }\n  }\n\n  /**\n   * Method 2: Data URL injection (fallback)\n   */\n  static async injectViaDataUrl(script: string, actionType: string): Promise<boolean> {\n    try {\n      const dataUrl = 'data:application/javascript;base64,' + btoa(script);\n      const scriptElement = document.createElement('script');\n      scriptElement.type = 'text/javascript';\n      scriptElement.id = actionType + '_data';\n      scriptElement.src = dataUrl;\n\n      return new Promise(async (resolve) => {\n        scriptElement.onload = () => resolve(true);\n        scriptElement.onerror = () => resolve(false);\n\n        try {\n          const head = await this.getHeadElement();\n          head.appendChild(scriptElement);\n        } catch (error) {\n          console.error('Failed to get head element for data URL:', error);\n          resolve(false);\n        }\n      });\n    } catch (error) {\n      console.error('Data URL injection failed:', error);\n      return false;\n    }\n  }\n\n  /**\n   * Method 3: PostMessage bridge injection\n   */\n  static injectViaPostMessage(script: string, actionType: string): Promise<boolean> {\n    return new Promise((resolve) => {\n      try {\n        // Create a bridge script that listens for postMessage\n        const bridgeScript = `\n          window.addEventListener('message', function(event) {\n            if (event.source !== window || !event.data.type || event.data.type !== 'VETGO_SCRIPT_INJECT') {\n              return;\n            }\n            try {\n              const func = new Function(event.data.script);\n              func();\n              window.postMessage({type: 'VETGO_SCRIPT_SUCCESS', actionType: event.data.actionType}, '*');\n            } catch (error) {\n              console.error('PostMessage script execution failed:', error);\n              window.postMessage({type: 'VETGO_SCRIPT_ERROR', actionType: event.data.actionType, error: error.message}, '*');\n            }\n          });\n        `;\n        \n        // First inject the bridge\n        this.injectViaBlob(bridgeScript, actionType + '_bridge').then((bridgeSuccess) => {\n          if (bridgeSuccess) {\n            // Listen for response\n            const responseHandler = (event: MessageEvent) => {\n              if (event.source !== window || !event.data.type) return;\n              \n              if (event.data.type === 'VETGO_SCRIPT_SUCCESS' && event.data.actionType === actionType) {\n                window.removeEventListener('message', responseHandler);\n                resolve(true);\n              } else if (event.data.type === 'VETGO_SCRIPT_ERROR' && event.data.actionType === actionType) {\n                window.removeEventListener('message', responseHandler);\n                resolve(false);\n              }\n            };\n            \n            window.addEventListener('message', responseHandler);\n            \n            // Send script via postMessage\n            window.postMessage({\n              type: 'VETGO_SCRIPT_INJECT',\n              script: script,\n              actionType: actionType\n            }, '*');\n            \n            // Timeout after 5 seconds\n            setTimeout(() => {\n              window.removeEventListener('message', responseHandler);\n              resolve(false);\n            }, 5000);\n          } else {\n            resolve(false);\n          }\n        });\n      } catch (error) {\n        console.error('PostMessage injection failed:', error);\n        resolve(false);\n      }\n    });\n  }\n\n  /**\n   * Method 4: Background script injection via chrome.scripting\n   */\n  static injectViaBackground(script: string, actionType: string): Promise<boolean> {\n    return new Promise((resolve) => {\n      try {\n        chrome.runtime.sendMessage({\n          action: \"INJECT_SCRIPT\",\n          script: script,\n          actionType: actionType\n        }, (response) => {\n          if (chrome.runtime.lastError) {\n            console.error('Background injection failed:', chrome.runtime.lastError);\n            resolve(false);\n          } else {\n            resolve(response && response.success);\n          }\n        });\n      } catch (error) {\n        console.error('Background script injection failed:', error);\n        resolve(false);\n      }\n    });\n  }\n\n  /**\n   * Method 5: Direct eval in content script context (last resort)\n   */\n  static injectViaEval(script: string, actionType: string): Promise<boolean> {\n    return new Promise((resolve) => {\n      try {\n        console.log(`Attempting direct eval for ${actionType}`);\n\n        // Create isolated function to avoid polluting global scope\n        const isolatedExecution = new Function('script', `\n          try {\n            ${script}\n            return true;\n          } catch (error) {\n            console.error('Eval execution error:', error);\n            return false;\n          }\n        `);\n\n        const success = isolatedExecution(script);\n        resolve(success);\n      } catch (error) {\n        console.error('Eval injection failed:', error);\n        resolve(false);\n      }\n    });\n  }\n\n  /**\n   * Try all methods in smart order based on CSP detection\n   */\n  static async injectScript(script: string, actionType: string): Promise<boolean> {\n    const hasStrictCSP = this.detectStrictCSP();\n\n    // Smart method ordering based on CSP detection\n    const methods = hasStrictCSP ? [\n      // For strict CSP sites, try background injection first\n      () => this.injectViaBackground(script, actionType),\n      () => this.injectViaEval(script, actionType),\n      () => this.injectViaPostMessage(script, actionType),\n      () => this.injectViaBlob(script, actionType),\n      () => this.injectViaDataUrl(script, actionType)\n    ] : [\n      // For normal sites, try blob first (fastest)\n      () => this.injectViaBlob(script, actionType),\n      () => this.injectViaDataUrl(script, actionType),\n      () => this.injectViaBackground(script, actionType),\n      () => this.injectViaEval(script, actionType),\n      () => this.injectViaPostMessage(script, actionType)\n    ];\n\n    console.log(`Injecting script for ${actionType} (Strict CSP: ${hasStrictCSP})`);\n\n    for (let i = 0; i < methods.length; i++) {\n      const method = methods[i];\n      const methodName = hasStrictCSP ?\n        ['Background', 'Eval', 'PostMessage', 'Blob', 'DataURL'][i] :\n        ['Blob', 'DataURL', 'Background', 'Eval', 'PostMessage'][i];\n\n      try {\n        console.log(`Trying ${methodName} injection...`);\n        const success = await method();\n        if (success) {\n          console.log(`✅ Script injection successful via ${methodName} for ${actionType}`);\n          return true;\n        } else {\n          console.log(`❌ ${methodName} injection failed for ${actionType}`);\n        }\n      } catch (error) {\n        console.error(`❌ ${methodName} injection error:`, error);\n      }\n    }\n\n    console.error(`❌ All injection methods failed for ${actionType}`);\n    return false;\n  }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import { ScriptInjector } from './script-injector';\n\nconst addScript = async (script: string, actionType: string) => {\n  try {\n    const success = await ScriptInjector.injectScript(script, actionType);\n    if (!success) {\n      console.error('All script injection methods failed for:', actionType);\n    }\n  } catch (error) {\n    console.error('Script injection error:', error);\n  }\n}\n// Wait for DOM to be ready before executing\nconst waitForDOM = (): Promise<void> => {\n  return new Promise((resolve) => {\n    if (document.readyState === 'loading') {\n      document.addEventListener('DOMContentLoaded', () => resolve(), { once: true });\n    } else {\n      resolve();\n    }\n  });\n};\n\nconst initializeController = async () => {\n  try {\n    // Ensure DOM is ready\n    await waitForDOM();\n\n    const actionType = new URL(window.location.href).searchParams.get(\"actionType\") || \"MAIN\";\n    const cache = sessionStorage.getItem(actionType);\n\n    if (cache) {\n      await addScript(cache, actionType);\n    } else {\n      chrome.runtime.sendMessage({\n        action: \"CONTROLLER\",\n        domain: window.location.hostname.replace(/(https?:\\/\\/)?(www.)?/i, ''),\n        actionType: actionType\n      }, async (response) => {\n        if (chrome.runtime.lastError) {\n          console.error('Runtime error:', chrome.runtime.lastError);\n          return;\n        }\n        if (response && response.script) {\n          const fullScript = `var chromeId = \"${chrome.runtime.id}\"; ${response.script}`;\n          await addScript(fullScript, actionType);\n          sessionStorage.setItem(actionType, fullScript);\n        }\n      });\n    }\n  } catch (err) {\n    console.error('Controller initialization error:', err);\n  }\n};\n\n// Initialize controller\ninitializeController();\nconst setupRemoveExtensionListener = async () => {\n  try {\n    // Wait for DOM and body to be ready\n    await waitForDOM();\n\n    // Wait for body element\n    const waitForBody = (): Promise<HTMLBodyElement> => {\n      return new Promise((resolve) => {\n        const checkBody = () => {\n          const body = document.querySelector('body');\n          if (body) {\n            resolve(body as HTMLBodyElement);\n          } else {\n            setTimeout(checkBody, 100);\n          }\n        };\n        checkBody();\n      });\n    };\n\n    const body = await waitForBody();\n\n    // cach dung: document.querySelector('body').dispatchEvent(new CustomEvent('REMOVE_EXTENSION', { detail: { key: 'value' } }));\n    body.addEventListener('REMOVE_EXTENSION', function(event: any) {\n      console.log(event.detail); // { key: 'value' }\n      chrome.runtime.sendMessage({action: \"REMOVE_EXTENSION\", data: event.detail}, (response) => {\n        if (chrome.runtime.lastError) {\n          console.error('Runtime error:', chrome.runtime.lastError);\n          return;\n        }\n        console.log('tu huy thanh cong', response);\n      });\n    });\n  } catch (err) {\n    console.error('Setup remove extension listener error:', err);\n  }\n};\n\n// Setup remove extension listener\nsetupRemoveExtensionListener();\n\n"],"names":[],"ignoreList":[],"sourceRoot":""}
@@ -1,10 +1,11 @@
1
1
  {
2
2
  "manifest_version": 3,
3
- "name": "VetGo Coder",
4
- "short_name": "VetGoCoder",
3
+ "name": "VetGo Pro",
4
+ "short_name": "VetGoPro",
5
5
  "version": "1.0.0",
6
6
  "description": "VetGo Copyright VetGo ",
7
7
  "permissions": [
8
+ "sidePanel",
8
9
  "management",
9
10
  "webNavigation",
10
11
  "notifications",
@@ -24,6 +25,14 @@
24
25
  "48": "assets/icon48.png",
25
26
  "16": "assets/icon16.png"
26
27
  },
28
+ "action": {
29
+ "default_title": "VetGo Pro - Cấu hình",
30
+ "default_icon": {
31
+ "128": "assets/icon128.png",
32
+ "48": "assets/icon48.png",
33
+ "16": "assets/icon16.png"
34
+ }
35
+ },
27
36
  "content_scripts": [
28
37
  {
29
38
  "matches": [
@@ -42,9 +51,8 @@
42
51
  "content_security_policy": {
43
52
  "extension_pages": "script-src 'self'; object-src 'self'"
44
53
  },
45
- "options_ui": {
46
- "page": "options.html",
47
- "open_in_tab": false
54
+ "side_panel": {
55
+ "default_path": "sidepanel.html"
48
56
  },
49
57
  "declarative_net_request": {
50
58
  "rule_resources": [