@jshookmcp/jshook 0.2.5 → 0.2.6

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 (210) hide show
  1. package/README.md +5 -5
  2. package/README.zh.md +5 -5
  3. package/dist/packages/extension-sdk/src/workflow.d.ts +17 -2
  4. package/dist/packages/extension-sdk/src/workflow.js +36 -0
  5. package/dist/src/modules/browser/BrowserPool.d.ts +49 -0
  6. package/dist/src/modules/browser/BrowserPool.js +288 -0
  7. package/dist/src/modules/deobfuscator/AdvancedDeobfuscator.d.ts +5 -0
  8. package/dist/src/modules/deobfuscator/AdvancedDeobfuscator.js +43 -2
  9. package/dist/src/modules/deobfuscator/Deobfuscator.js +5 -0
  10. package/dist/src/modules/external/ExternalToolRunner.js +1 -1
  11. package/dist/src/server/MCPServer.context.d.ts +1 -0
  12. package/dist/src/server/domains/browser/handlers/stealth-injection.d.ts +1 -0
  13. package/dist/src/server/domains/browser/handlers/stealth-injection.js +3 -0
  14. package/dist/src/server/domains/shared-state-board/definitions.d.ts +2 -0
  15. package/dist/src/server/domains/shared-state-board/definitions.js +78 -0
  16. package/dist/src/server/domains/shared-state-board/handlers.impl.d.ts +58 -0
  17. package/dist/src/server/domains/shared-state-board/handlers.impl.js +419 -0
  18. package/dist/src/server/domains/shared-state-board/index.d.ts +2 -0
  19. package/dist/src/server/domains/shared-state-board/index.js +2 -0
  20. package/dist/src/server/domains/shared-state-board/manifest.d.ts +57 -0
  21. package/dist/src/server/domains/shared-state-board/manifest.js +74 -0
  22. package/dist/src/server/http/SseStream.d.ts +21 -0
  23. package/dist/src/server/http/SseStream.js +129 -0
  24. package/dist/src/server/teams/TeamManager.d.ts +43 -0
  25. package/dist/src/server/teams/TeamManager.js +238 -0
  26. package/dist/src/server/teams/index.d.ts +1 -0
  27. package/dist/src/server/teams/index.js +1 -0
  28. package/dist/src/server/workflows/WorkflowContract.d.ts +20 -4
  29. package/dist/src/server/workflows/WorkflowContract.js +40 -0
  30. package/dist/src/server/workflows/WorkflowEngine.js +190 -13
  31. package/dist/src/types/deobfuscator.d.ts +1 -0
  32. package/dist/src/utils/cache/CachedDecorator.d.ts +8 -0
  33. package/dist/src/utils/cache/CachedDecorator.js +55 -0
  34. package/dist/src/utils/cache/PersistentCache.d.ts +33 -0
  35. package/dist/src/utils/cache/PersistentCache.js +246 -0
  36. package/dist/src/utils/cache/index.d.ts +2 -0
  37. package/dist/src/utils/cache/index.js +2 -0
  38. package/package.json +11 -12
  39. package/scripts/postinstall.cjs +54 -27
  40. package/workflows/anti-bot-diagnoser/.jshook-install.json +14 -0
  41. package/workflows/anti-bot-diagnoser/LICENSE +21 -0
  42. package/workflows/anti-bot-diagnoser/README.md +105 -0
  43. package/workflows/anti-bot-diagnoser/docs/agent-recipes.md +44 -0
  44. package/workflows/anti-bot-diagnoser/meta.yaml +6 -0
  45. package/workflows/anti-bot-diagnoser/package.json +22 -0
  46. package/workflows/anti-bot-diagnoser/tsconfig.json +15 -0
  47. package/workflows/anti-bot-diagnoser/workflow.ts +224 -0
  48. package/workflows/api-openapi-probe/.jshook-install.json +14 -0
  49. package/workflows/api-openapi-probe/meta.yaml +6 -0
  50. package/workflows/api-openapi-probe/package.json +22 -0
  51. package/workflows/api-openapi-probe/pnpm-lock.yaml +819 -0
  52. package/workflows/api-openapi-probe/tsconfig.json +15 -0
  53. package/workflows/api-openapi-probe/workflow.ts +40 -0
  54. package/workflows/api-probe-batch/.jshook-install.json +14 -0
  55. package/workflows/api-probe-batch/LICENSE +21 -0
  56. package/workflows/api-probe-batch/README.md +45 -0
  57. package/workflows/api-probe-batch/meta.yaml +4 -0
  58. package/workflows/api-probe-batch/package.json +23 -0
  59. package/workflows/api-probe-batch/tsconfig.json +16 -0
  60. package/workflows/api-probe-batch/workflow.ts +111 -0
  61. package/workflows/auth-bootstrap/.jshook-install.json +14 -0
  62. package/workflows/auth-bootstrap/LICENSE +21 -0
  63. package/workflows/auth-bootstrap/README.md +74 -0
  64. package/workflows/auth-bootstrap/meta.yaml +4 -0
  65. package/workflows/auth-bootstrap/package.json +23 -0
  66. package/workflows/auth-bootstrap/tsconfig.json +16 -0
  67. package/workflows/auth-bootstrap/workflow.ts +141 -0
  68. package/workflows/auth-extract/.jshook-install.json +14 -0
  69. package/workflows/auth-extract/meta.yaml +6 -0
  70. package/workflows/auth-extract/package.json +22 -0
  71. package/workflows/auth-extract/pnpm-lock.yaml +819 -0
  72. package/workflows/auth-extract/tsconfig.json +15 -0
  73. package/workflows/auth-extract/workflow.ts +36 -0
  74. package/workflows/auth-surface-mapper/.jshook-install.json +14 -0
  75. package/workflows/auth-surface-mapper/meta.yaml +6 -0
  76. package/workflows/auth-surface-mapper/package.json +22 -0
  77. package/workflows/auth-surface-mapper/pnpm-lock.yaml +819 -0
  78. package/workflows/auth-surface-mapper/tsconfig.json +15 -0
  79. package/workflows/auth-surface-mapper/workflow.ts +104 -0
  80. package/workflows/batch-register/.jshook-install.json +14 -0
  81. package/workflows/batch-register/LICENSE +21 -0
  82. package/workflows/batch-register/README.md +39 -0
  83. package/workflows/batch-register/meta.yaml +4 -0
  84. package/workflows/batch-register/package.json +23 -0
  85. package/workflows/batch-register/tsconfig.json +16 -0
  86. package/workflows/batch-register/workflow.ts +67 -0
  87. package/workflows/bundle-recovery/.jshook-install.json +14 -0
  88. package/workflows/bundle-recovery/LICENSE +21 -0
  89. package/workflows/bundle-recovery/README.md +105 -0
  90. package/workflows/bundle-recovery/docs/agent-recipes.md +44 -0
  91. package/workflows/bundle-recovery/meta.yaml +6 -0
  92. package/workflows/bundle-recovery/package.json +22 -0
  93. package/workflows/bundle-recovery/tsconfig.json +15 -0
  94. package/workflows/bundle-recovery/workflow.ts +179 -0
  95. package/workflows/challenge-detector/.jshook-install.json +14 -0
  96. package/workflows/challenge-detector/meta.yaml +14 -0
  97. package/workflows/challenge-detector/package.json +22 -0
  98. package/workflows/challenge-detector/pnpm-lock.yaml +819 -0
  99. package/workflows/challenge-detector/tsconfig.json +15 -0
  100. package/workflows/challenge-detector/workflow.ts +298 -0
  101. package/workflows/deobfuscation-pipeline/.jshook-install.json +14 -0
  102. package/workflows/deobfuscation-pipeline/meta.yaml +6 -0
  103. package/workflows/deobfuscation-pipeline/package.json +22 -0
  104. package/workflows/deobfuscation-pipeline/pnpm-lock.yaml +819 -0
  105. package/workflows/deobfuscation-pipeline/tsconfig.json +15 -0
  106. package/workflows/deobfuscation-pipeline/workflow.ts +119 -0
  107. package/workflows/electron-bridge-mapper/.jshook-install.json +14 -0
  108. package/workflows/electron-bridge-mapper/meta.yaml +6 -0
  109. package/workflows/electron-bridge-mapper/package.json +22 -0
  110. package/workflows/electron-bridge-mapper/pnpm-lock.yaml +819 -0
  111. package/workflows/electron-bridge-mapper/tsconfig.json +15 -0
  112. package/workflows/electron-bridge-mapper/workflow.ts +125 -0
  113. package/workflows/evidence-pack/.jshook-install.json +14 -0
  114. package/workflows/evidence-pack/LICENSE +21 -0
  115. package/workflows/evidence-pack/README.md +105 -0
  116. package/workflows/evidence-pack/docs/agent-recipes.md +44 -0
  117. package/workflows/evidence-pack/meta.yaml +6 -0
  118. package/workflows/evidence-pack/package.json +22 -0
  119. package/workflows/evidence-pack/tsconfig.json +15 -0
  120. package/workflows/evidence-pack/workflow.ts +154 -0
  121. package/workflows/js-bundle-search/.jshook-install.json +14 -0
  122. package/workflows/js-bundle-search/LICENSE +21 -0
  123. package/workflows/js-bundle-search/README.md +46 -0
  124. package/workflows/js-bundle-search/meta.yaml +4 -0
  125. package/workflows/js-bundle-search/package.json +23 -0
  126. package/workflows/js-bundle-search/tsconfig.json +16 -0
  127. package/workflows/js-bundle-search/workflow.ts +118 -0
  128. package/workflows/protocol-registry/.jshook-install.json +14 -0
  129. package/workflows/protocol-registry/meta.yaml +6 -0
  130. package/workflows/protocol-registry/package.json +22 -0
  131. package/workflows/protocol-registry/pnpm-lock.yaml +819 -0
  132. package/workflows/protocol-registry/tsconfig.json +15 -0
  133. package/workflows/protocol-registry/workflow.ts +107 -0
  134. package/workflows/qwen-mail-open-latest/meta.yaml +7 -0
  135. package/workflows/qwen-mail-open-latest/package.json +22 -0
  136. package/workflows/qwen-mail-open-latest/pnpm-lock.yaml +819 -0
  137. package/workflows/qwen-mail-open-latest/tsconfig.json +15 -0
  138. package/workflows/qwen-mail-open-latest/workflow.ts +77 -0
  139. package/workflows/register-account-flow/.jshook-install.json +14 -0
  140. package/workflows/register-account-flow/LICENSE +21 -0
  141. package/workflows/register-account-flow/README.md +64 -0
  142. package/workflows/register-account-flow/meta.yaml +4 -0
  143. package/workflows/register-account-flow/package.json +23 -0
  144. package/workflows/register-account-flow/tsconfig.json +16 -0
  145. package/workflows/register-account-flow/workflow.ts +127 -0
  146. package/workflows/replay-lab/.jshook-install.json +14 -0
  147. package/workflows/replay-lab/meta.yaml +6 -0
  148. package/workflows/replay-lab/package.json +22 -0
  149. package/workflows/replay-lab/pnpm-lock.yaml +819 -0
  150. package/workflows/replay-lab/tsconfig.json +15 -0
  151. package/workflows/replay-lab/workflow.ts +106 -0
  152. package/workflows/script-evidence-scan/.jshook-install.json +14 -0
  153. package/workflows/script-evidence-scan/LICENSE +21 -0
  154. package/workflows/script-evidence-scan/README.md +61 -0
  155. package/workflows/script-evidence-scan/meta.yaml +4 -0
  156. package/workflows/script-evidence-scan/package.json +23 -0
  157. package/workflows/script-evidence-scan/tsconfig.json +16 -0
  158. package/workflows/script-evidence-scan/workflow.ts +89 -0
  159. package/workflows/signature-hunter/.jshook-install.json +14 -0
  160. package/workflows/signature-hunter/LICENSE +21 -0
  161. package/workflows/signature-hunter/README.md +105 -0
  162. package/workflows/signature-hunter/docs/agent-recipes.md +44 -0
  163. package/workflows/signature-hunter/meta.yaml +6 -0
  164. package/workflows/signature-hunter/package.json +22 -0
  165. package/workflows/signature-hunter/tsconfig.json +15 -0
  166. package/workflows/signature-hunter/workflow.ts +170 -0
  167. package/workflows/signing-lineage/.jshook-install.json +14 -0
  168. package/workflows/signing-lineage/meta.yaml +6 -0
  169. package/workflows/signing-lineage/package.json +22 -0
  170. package/workflows/signing-lineage/pnpm-lock.yaml +819 -0
  171. package/workflows/signing-lineage/tsconfig.json +15 -0
  172. package/workflows/signing-lineage/workflow.ts +120 -0
  173. package/workflows/temp-mail-extract-link/.jshook-install.json +14 -0
  174. package/workflows/temp-mail-extract-link/LICENSE +21 -0
  175. package/workflows/temp-mail-extract-link/README.md +71 -0
  176. package/workflows/temp-mail-extract-link/meta.yaml +4 -0
  177. package/workflows/temp-mail-extract-link/package.json +23 -0
  178. package/workflows/temp-mail-extract-link/tsconfig.json +16 -0
  179. package/workflows/temp-mail-extract-link/workflow.ts +221 -0
  180. package/workflows/temp-mail-open-latest/.jshook-install.json +14 -0
  181. package/workflows/temp-mail-open-latest/LICENSE +21 -0
  182. package/workflows/temp-mail-open-latest/README.md +61 -0
  183. package/workflows/temp-mail-open-latest/meta.yaml +4 -0
  184. package/workflows/temp-mail-open-latest/package.json +23 -0
  185. package/workflows/temp-mail-open-latest/tsconfig.json +16 -0
  186. package/workflows/temp-mail-open-latest/workflow.ts +136 -0
  187. package/workflows/template/.jshook-install.json +14 -0
  188. package/workflows/template/LICENSE +21 -0
  189. package/workflows/template/README.md +45 -0
  190. package/workflows/template/docs/SKILL.md +111 -0
  191. package/workflows/template/meta.yaml +6 -0
  192. package/workflows/template/package.json +22 -0
  193. package/workflows/template/pnpm-lock.yaml +819 -0
  194. package/workflows/template/tsconfig.json +15 -0
  195. package/workflows/template/workflow.ts +73 -0
  196. package/workflows/web-api-capture-session/.jshook-install.json +14 -0
  197. package/workflows/web-api-capture-session/LICENSE +21 -0
  198. package/workflows/web-api-capture-session/README.md +64 -0
  199. package/workflows/web-api-capture-session/meta.yaml +4 -0
  200. package/workflows/web-api-capture-session/package.json +23 -0
  201. package/workflows/web-api-capture-session/tsconfig.json +16 -0
  202. package/workflows/web-api-capture-session/workflow.ts +124 -0
  203. package/workflows/ws-protocol-lifter/.jshook-install.json +14 -0
  204. package/workflows/ws-protocol-lifter/LICENSE +21 -0
  205. package/workflows/ws-protocol-lifter/README.md +105 -0
  206. package/workflows/ws-protocol-lifter/docs/agent-recipes.md +44 -0
  207. package/workflows/ws-protocol-lifter/meta.yaml +6 -0
  208. package/workflows/ws-protocol-lifter/package.json +22 -0
  209. package/workflows/ws-protocol-lifter/tsconfig.json +15 -0
  210. package/workflows/ws-protocol-lifter/workflow.ts +163 -0
@@ -0,0 +1,179 @@
1
+ import {
2
+ createWorkflow,
3
+ type WorkflowExecutionContext,
4
+ SequenceNodeBuilder,
5
+ } from '@jshookmcp/extension-sdk/workflow';
6
+
7
+ const workflowId = 'workflow.bundle-recovery.v1';
8
+
9
+ /**
10
+ * Bundle Recovery — Reverse Mission Workflow
11
+ *
12
+ * End-to-end bundle analysis workflow:
13
+ * 1. Collects all scripts from the target page
14
+ * 2. Detects source maps and attempts recovery
15
+ * 3. Identifies webpack/rollup/parcel bundles
16
+ * 4. Enumerates modules and entry points
17
+ * 5. Runs webcrack for code unpacking/deobfuscation
18
+ * 6. Extracts function dependency trees for key modules
19
+ * 7. Exports structured module map and evidence
20
+ */
21
+ export default createWorkflow(workflowId, 'Bundle Recovery')
22
+ .description(
23
+ 'Collects scripts, recovers source maps, identifies bundlers (webpack/rollup/parcel), enumerates modules, runs webcrack deobfuscation, and extracts function trees.',
24
+ )
25
+ .tags([
26
+ 'reverse',
27
+ 'bundle',
28
+ 'webpack',
29
+ 'sourcemap',
30
+ 'deobfuscation',
31
+ 'webcrack',
32
+ 'module',
33
+ 'mission',
34
+ ])
35
+ .timeoutMs(15 * 60_000)
36
+ .defaultMaxConcurrency(3)
37
+ .buildGraph((ctx: WorkflowExecutionContext) => {
38
+ const prefix = 'workflows.bundleRecovery';
39
+
40
+ // ── Config ──────────────────────────────────────────────────────
41
+ const url = String(ctx.getConfig(`${prefix}.url`, 'https://example.com'));
42
+ const waitUntil = String(ctx.getConfig(`${prefix}.waitUntil`, 'networkidle0'));
43
+ const collectInline = Boolean(ctx.getConfig(`${prefix}.collectInline`, true));
44
+ const maxScripts = Number(ctx.getConfig(`${prefix}.maxScripts`, 50));
45
+ const runWebcrack = Boolean(ctx.getConfig(`${prefix}.runWebcrack`, true));
46
+ const extractFunctionTree = Boolean(ctx.getConfig(`${prefix}.extractFunctionTree`, true));
47
+ const maxConcurrency = Number(ctx.getConfig(`${prefix}.parallel.maxConcurrency`, 3));
48
+ const moduleSearchDepth = Number(ctx.getConfig(`${prefix}.moduleSearchDepth`, 4));
49
+
50
+ const root = new SequenceNodeBuilder('bundle-recovery-root');
51
+
52
+ root
53
+ // ── Phase 1: Navigate & Enable ────────────────────────────────
54
+ .tool('enable-network', 'network_enable', {
55
+ input: { enableExceptions: true },
56
+ })
57
+ .tool('navigate', 'page_navigate', {
58
+ input: { url, waitUntil },
59
+ })
60
+
61
+ // ── Phase 2: Collect Scripts ──────────────────────────────────
62
+ .tool('collect-scripts', 'collect_code', {
63
+ input: {
64
+ includeInline: collectInline,
65
+ limit: maxScripts,
66
+ },
67
+ })
68
+
69
+ // ── Phase 3: Parallel Analysis ────────────────────────────────
70
+ .parallel('analyse-bundles', (p) => {
71
+ p.maxConcurrency(maxConcurrency)
72
+ .failFast(false)
73
+ // Detect & fetch source maps
74
+ .tool('detect-sourcemaps', 'source_map_detect', {
75
+ input: {},
76
+ })
77
+ .tool('fetch-sourcemaps', 'source_map_fetch', {
78
+ input: {},
79
+ })
80
+ // Identify bundler type
81
+ .tool('detect-bundler', 'js_bundle_detect', {
82
+ input: {},
83
+ })
84
+ // Search for webpack/rollup runtime signatures
85
+ .tool('search-webpack', 'js_bundle_search', {
86
+ input: {
87
+ bundlerType: 'webpack',
88
+ },
89
+ })
90
+ // Detect obfuscation
91
+ .tool('detect-obfuscation', 'detect_obfuscation', {
92
+ input: {},
93
+ });
94
+ })
95
+
96
+ // ── Phase 4: Source Map Recovery ──────────────────────────────
97
+ .tool('recover-sourcemaps', 'source_map_recover', {
98
+ input: {},
99
+ })
100
+
101
+ // ── Phase 5: Module Enumeration ───────────────────────────────
102
+ .tool('enumerate-modules', 'js_bundle_enumerate_modules', {
103
+ input: {
104
+ depth: moduleSearchDepth,
105
+ },
106
+ });
107
+
108
+ // ── Phase 6: Webcrack (Optional) ────────────────────────────────
109
+ if (runWebcrack) {
110
+ root.tool('run-webcrack', 'webcrack_unpack', {
111
+ input: {},
112
+ });
113
+ }
114
+
115
+ // ── Phase 7: Function Tree (Optional) ───────────────────────────
116
+ if (extractFunctionTree) {
117
+ root.tool('extract-function-tree', 'extract_function_tree', {
118
+ input: {
119
+ targetParam: '__webpack_require__',
120
+ depth: 3,
121
+ },
122
+ });
123
+ }
124
+
125
+ root
126
+ // ── Phase 8: Evidence Recording ───────────────────────────────
127
+ .tool('create-evidence-session', 'instrumentation_session_create', {
128
+ input: {
129
+ name: `bundle-recovery-${new Date().toISOString().slice(0, 10)}`,
130
+ metadata: { url, workflowId },
131
+ },
132
+ })
133
+ .tool('record-artifact', 'instrumentation_artifact_record', {
134
+ input: {
135
+ type: 'bundle_analysis',
136
+ label: `Bundle analysis for ${url}`,
137
+ metadata: { url, maxScripts, runWebcrack, extractFunctionTree },
138
+ },
139
+ })
140
+
141
+ // ── Phase 9: Session Insight ──────────────────────────────────
142
+ .tool('emit-insight', 'append_session_insight', {
143
+ input: {
144
+ insight: JSON.stringify({
145
+ status: 'bundle_recovery_complete',
146
+ workflowId,
147
+ url,
148
+ maxScripts,
149
+ runWebcrack,
150
+ extractFunctionTree,
151
+ }),
152
+ },
153
+ });
154
+
155
+ return root;
156
+ })
157
+ .onStart((ctx) => {
158
+ ctx.emitMetric('workflow_runs_total', 1, 'counter', {
159
+ workflowId,
160
+ mission: 'bundle_recovery',
161
+ stage: 'start',
162
+ });
163
+ })
164
+ .onFinish((ctx) => {
165
+ ctx.emitMetric('workflow_runs_total', 1, 'counter', {
166
+ workflowId,
167
+ mission: 'bundle_recovery',
168
+ stage: 'finish',
169
+ });
170
+ })
171
+ .onError((ctx, error) => {
172
+ ctx.emitMetric('workflow_errors_total', 1, 'counter', {
173
+ workflowId,
174
+ mission: 'bundle_recovery',
175
+ stage: 'error',
176
+ error: error.name,
177
+ });
178
+ })
179
+ .build();
@@ -0,0 +1,14 @@
1
+ {
2
+ "version": 1,
3
+ "kind": "workflow",
4
+ "slug": "challenge-detector",
5
+ "id": "workflow.challenge-detector.v1",
6
+ "source": {
7
+ "type": "git",
8
+ "repo": "https://github.com/vmoranv/jshook_workflow_challenge_detector",
9
+ "ref": "main",
10
+ "commit": "f050d18394c908485771e79a3778e9711724f073",
11
+ "subpath": ".",
12
+ "entry": "workflow.ts"
13
+ }
14
+ }
@@ -0,0 +1,14 @@
1
+ name: challenge-detector
2
+ description: JSHook workflow for challenge-detector (v2 - CTF platform support)
3
+ author: vmoranv
4
+ tags:
5
+ - workflow
6
+ - challenge-detector
7
+ - ctf
8
+ - juiceshop
9
+ - dvwa
10
+ - hackthebox
11
+ - tryhackme
12
+ - overthewire
13
+ - picoctf
14
+ - rootme
@@ -0,0 +1,22 @@
1
+ {
2
+ "name": "jshook-workflow-challenge-detector",
3
+ "private": true,
4
+ "version": "0.1.0",
5
+ "description": "jshookmcp workflow: challenge-detector",
6
+ "type": "module",
7
+ "packageManager": "pnpm@10.28.2",
8
+ "scripts": {
9
+ "build": "tsc -p tsconfig.json",
10
+ "check": "tsc -p tsconfig.json --noEmit"
11
+ },
12
+ "dependencies": {
13
+ "@jshookmcp/extension-sdk": "^0.3.0"
14
+ },
15
+ "devDependencies": {
16
+ "@types/node": "^25.3.0",
17
+ "typescript": "^5.9.3"
18
+ },
19
+ "engines": {
20
+ "node": ">=20.0.0"
21
+ }
22
+ }