n8n-nodes-soar 0.1.16 → 0.1.19

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 (57) hide show
  1. package/dist/common/asset.js +141 -0
  2. package/dist/common/collector.js +32 -0
  3. package/dist/common/connectionType.js +15 -0
  4. package/dist/common/executor/docker.executor.js +97 -0
  5. package/dist/common/executor/executor.js +48 -0
  6. package/dist/common/executor/k8s.executor.js +190 -0
  7. package/dist/common/runner/container.runner.js +174 -0
  8. package/dist/common/runner/priority.js +44 -0
  9. package/dist/common/runner/priority.runner.js +38 -0
  10. package/dist/common/runner/runner.js +57 -0
  11. package/dist/credentials/Docker/Docker.credentials.js +149 -0
  12. package/dist/credentials/Docker/docker.svg +7 -0
  13. package/dist/credentials/{FofaCredentials.credentials.js → FofaApi/FofaApi.credentials.js} +5 -5
  14. package/dist/credentials/Kubernetes/Kubernetes.credentials.js +82 -0
  15. package/dist/credentials/Kubernetes/k8s.svg +1 -0
  16. package/dist/nodes/Asset/SplitAsset/SplitAsset.node.js +110 -0
  17. package/dist/nodes/Asset/SplitAsset/split.svg +13 -0
  18. package/dist/nodes/Collector/Collector.node.js +123 -0
  19. package/dist/nodes/Executor/DockerExecutor/DockerExecutor.node.js +59 -0
  20. package/dist/nodes/Executor/DockerExecutor/docker.svg +7 -0
  21. package/dist/nodes/Executor/KubernetesExecutor/KubernetesExecutor.node.js +59 -0
  22. package/dist/nodes/Executor/KubernetesExecutor/k8s.svg +1 -0
  23. package/dist/nodes/Fofa/Fofa.node.js +20 -7
  24. package/dist/nodes/Katana/Katana.node.js +1 -1
  25. package/dist/nodes/Nuclei/Nuclei.node.js +1 -1
  26. package/dist/nodes/Runner/Dns/Dns.node.js +199 -0
  27. package/dist/nodes/Runner/Dns/script.js +81 -0
  28. package/dist/nodes/Runner/Httpx/Httpx.node.js +830 -0
  29. package/dist/nodes/Runner/Httpx/httpx.svg +3 -0
  30. package/dist/nodes/Runner/Katana/Katana.node.js +521 -0
  31. package/dist/nodes/Runner/Katana/a.json +30 -0
  32. package/dist/nodes/Runner/Katana/katana.svg +3 -0
  33. package/dist/nodes/Runner/Masscan/Masscan.node.js +151 -0
  34. package/dist/nodes/Runner/Masscan/masscan.svg +70 -0
  35. package/dist/nodes/{Naabu → Runner/Naabu}/Naabu.node.js +86 -48
  36. package/dist/nodes/Runner/Naabu/naabu.svg +3 -0
  37. package/dist/nodes/Runner/Nuclei/Nuclei.node.js +1057 -0
  38. package/dist/nodes/Runner/Nuclei/a.json +48 -0
  39. package/dist/nodes/Runner/Nuclei/nuclei.svg +3 -0
  40. package/dist/nodes/Runner/Priority/Priority.node.js +110 -0
  41. package/dist/nodes/Runner/PriorityAdd/PriorityAdd.node.js +97 -0
  42. package/dist/nodes/Runner/Router/SwitchRouter/SwitchRouter.node.js +101 -0
  43. package/dist/nodes/{Subfinder → Runner/Subfinder}/Subfinder.node.js +74 -43
  44. package/dist/nodes/Runner/Subfinder/subfinder.svg +3 -0
  45. package/dist/nodes/Runner/Unauthor/Unauthor.node.js +169 -0
  46. package/package.json +63 -59
  47. package/dist/nodes/Cdncheck/Cdncheck.node.json +0 -9
  48. package/dist/nodes/Fofa/Fofa.node.json +0 -9
  49. package/dist/nodes/Httpx/Httpx.node.json +0 -9
  50. package/dist/nodes/Naabu/Naabu.node.json +0 -9
  51. package/dist/nodes/Subfinder/Subfinder.node.json +0 -9
  52. package/dist/utils/executor.js +0 -233
  53. package/dist/utils/interface.js +0 -4
  54. package/dist/utils/runner/docker.runner.js +0 -72
  55. package/dist/utils/runner/k8s.runner.js +0 -167
  56. package/dist/utils/runner/runner.js +0 -11
  57. /package/dist/credentials/{fofa.svg → FofaApi/fofa.svg} +0 -0
@@ -0,0 +1,3 @@
1
+ <svg width="596" height="596" xmlns="http://www.w3.org/2000/svg" version="1.1">
2
+ <image x="0" y="196" width="596" height="204" href="" />
3
+ </svg>
@@ -0,0 +1,521 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "Katana", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return Katana;
9
+ }
10
+ });
11
+ const _classtransformer = require("class-transformer");
12
+ const _asset = require("../../../common/asset");
13
+ const _connectionType = require("../../../common/connectionType");
14
+ const _containerrunner = require("../../../common/runner/container.runner");
15
+ const _priority = require("../../../common/runner/priority");
16
+ function _define_property(obj, key, value) {
17
+ if (key in obj) {
18
+ Object.defineProperty(obj, key, {
19
+ value: value,
20
+ enumerable: true,
21
+ configurable: true,
22
+ writable: true
23
+ });
24
+ } else {
25
+ obj[key] = value;
26
+ }
27
+ return obj;
28
+ }
29
+ class KatanaRunner extends _containerrunner.ContainerRunner {
30
+ cmd(assets) {
31
+ const path = this.func.getNodeParameter("path", this.itemIndex);
32
+ return [
33
+ "katana",
34
+ "-disable-update-check",
35
+ "-jsonl",
36
+ "-silent",
37
+ "-list",
38
+ assets.map((a)=>`${a.getHostAndPort()}${path}`).join(","),
39
+ ...this.collectGeneratedOptions([
40
+ "options.configuration",
41
+ "options.headless",
42
+ "options.scope",
43
+ "options.filter",
44
+ "options.rateLimit",
45
+ "options.output"
46
+ ])
47
+ ];
48
+ }
49
+ process(rawAssets, stdout) {
50
+ const resultMap = new Map();
51
+ for (const line of stdout.trim().split("\n")){
52
+ const json = JSON.parse(line);
53
+ const endpoint = json.request.endpoint;
54
+ const url = new URL(endpoint);
55
+ if (!url.port) {
56
+ if (url.protocol === "https") {
57
+ url.port = "443";
58
+ } else if (url.protocol === "http") {
59
+ url.port = "80";
60
+ }
61
+ }
62
+ resultMap.set(`${url.hostname}:${url.port}`, (resultMap.get(`${url.hostname}:${url.port}`) || []).concat(json));
63
+ }
64
+ const resultAssets = [
65
+ ...rawAssets.map((a)=>{
66
+ const result = resultMap.get(a.getHostAndPort());
67
+ if (result) {
68
+ resultMap.delete(a.getHostAndPort());
69
+ a.response = result;
70
+ a.success = true;
71
+ }
72
+ return a;
73
+ })
74
+ ];
75
+ resultMap.forEach((result, [host, port])=>{
76
+ resultAssets.push(...result.map((r)=>(0, _classtransformer.plainToInstance)(_asset.Asset, {
77
+ basic: {
78
+ host,
79
+ port
80
+ },
81
+ response: r,
82
+ success: true
83
+ })));
84
+ });
85
+ return resultAssets;
86
+ }
87
+ }
88
+ class Katana {
89
+ async supplyData(itemIndex) {
90
+ return {
91
+ response: [
92
+ new KatanaRunner("katana", _priority.APP_RUNNER_PRIORITY, this, itemIndex)
93
+ ]
94
+ };
95
+ }
96
+ constructor(){
97
+ _define_property(this, "description", {
98
+ displayName: "Runner: Katana",
99
+ name: "katana",
100
+ icon: "svg:katana.svg",
101
+ group: [
102
+ "transform"
103
+ ],
104
+ codex: {
105
+ alias: [
106
+ "Katana"
107
+ ],
108
+ categories: [
109
+ "SOAR"
110
+ ],
111
+ subcategories: {
112
+ SOAR: [
113
+ "runner"
114
+ ]
115
+ },
116
+ resources: {
117
+ primaryDocumentation: [
118
+ {
119
+ url: "https://github.com/projectdiscovery/katana/"
120
+ }
121
+ ]
122
+ }
123
+ },
124
+ version: 1,
125
+ description: "Interact with Katana",
126
+ defaults: {
127
+ name: "Katana"
128
+ },
129
+ // eslint-disable-next-line n8n-nodes-base/node-class-description-inputs-wrong-regular-node
130
+ inputs: [],
131
+ // eslint-disable-next-line n8n-nodes-base/node-class-description-outputs-wrong
132
+ outputs: [
133
+ _connectionType.NodeConnectionType.Runner
134
+ ],
135
+ properties: [
136
+ {
137
+ displayName: "Only Success",
138
+ name: "onlySuccess",
139
+ type: "boolean",
140
+ default: true
141
+ },
142
+ {
143
+ displayName: "Path",
144
+ name: "path",
145
+ type: "string",
146
+ default: "/"
147
+ },
148
+ {
149
+ displayName: "Options",
150
+ name: "options",
151
+ type: "fixedCollection",
152
+ default: {},
153
+ typeOptions: {
154
+ multipleValues: true
155
+ },
156
+ options: [
157
+ {
158
+ displayName: "Configuration",
159
+ name: "configuration",
160
+ values: [
161
+ {
162
+ displayName: "Options",
163
+ name: "key",
164
+ type: "options",
165
+ default: "-automatic-form-fill",
166
+ options: [
167
+ {
168
+ name: "Automatic Form Fill",
169
+ value: "-automatic-form-fill",
170
+ description: "Enable automatic form filling (experimental)"
171
+ },
172
+ {
173
+ name: "Config",
174
+ value: "-config",
175
+ description: "Path to the katana configuration file (string)"
176
+ },
177
+ {
178
+ name: "Crawl Duration",
179
+ value: "-crawl-duration",
180
+ description: "Maximum duration to crawl the target for (s, m, h, d) (default s) (value)"
181
+ },
182
+ {
183
+ name: "Depth",
184
+ value: "-depth",
185
+ description: "Maximum depth to crawl (default 3) (int)"
186
+ },
187
+ {
188
+ name: "Field Config",
189
+ value: "-field-config",
190
+ description: "Path to custom field configuration file (string)"
191
+ },
192
+ {
193
+ name: "Form Config",
194
+ value: "-form-config",
195
+ description: "Path to custom form configuration file (string)"
196
+ },
197
+ {
198
+ name: "Form Extraction",
199
+ value: "-form-extraction",
200
+ description: "Extract form, input, textarea & select elements in jsonl output"
201
+ },
202
+ {
203
+ name: "Headers",
204
+ value: "-headers",
205
+ description: "Custom header/cookie to include in all http request in header:value format (file) (string[])"
206
+ },
207
+ {
208
+ name: "Ignore Query Params",
209
+ value: "-ignore-query-params",
210
+ description: "Ignore crawling same path with different query-param values"
211
+ },
212
+ {
213
+ name: "Js Crawl",
214
+ value: "-js-crawl",
215
+ description: "Enable endpoint parsing / crawling in javascript file"
216
+ },
217
+ {
218
+ name: "Jsluice",
219
+ value: "-jsluice",
220
+ description: "Enable jsluice parsing in javascript file (memory intensive)"
221
+ },
222
+ {
223
+ name: "Known Files",
224
+ value: "-known-files",
225
+ description: "Enable crawling of known files (all,robotstxt,sitemapxml) (string)"
226
+ },
227
+ {
228
+ name: "Max Response Size",
229
+ value: "-max-response-size",
230
+ description: "Maximum response size to read (default 9223372036854775807) (int)"
231
+ },
232
+ {
233
+ name: "Proxy",
234
+ value: "-proxy",
235
+ description: "Http/socks5 proxy to use (string)"
236
+ },
237
+ {
238
+ name: "Resolvers",
239
+ value: "-resolvers",
240
+ description: "List of custom resolver (file or comma-separated) (string[])"
241
+ },
242
+ {
243
+ name: "Retry",
244
+ value: "-retry",
245
+ description: "Number of times to retry the request (default 1) (int)"
246
+ },
247
+ {
248
+ name: "Strategy",
249
+ value: "-strategy",
250
+ description: 'Visit strategy (depth-first, breadth-first) (default "depth-first") (string)'
251
+ },
252
+ {
253
+ name: "Timeout",
254
+ value: "-timeout",
255
+ description: "Time to wait for request in seconds (default 10) (int)"
256
+ },
257
+ {
258
+ name: "Tls Impersonate",
259
+ value: "-tls-impersonate",
260
+ description: "Enable experimental client hello (ja3) tls randomization"
261
+ }
262
+ ]
263
+ },
264
+ {
265
+ displayName: "Value",
266
+ name: "value",
267
+ type: "string",
268
+ default: ""
269
+ }
270
+ ]
271
+ },
272
+ {
273
+ displayName: "Headless",
274
+ name: "headless",
275
+ values: [
276
+ {
277
+ displayName: "Options",
278
+ name: "key",
279
+ type: "options",
280
+ default: "-chrome-data-dir",
281
+ options: [
282
+ {
283
+ name: "Chrome Data Dir",
284
+ value: "-chrome-data-dir",
285
+ description: "Path to store chrome browser data (string)"
286
+ },
287
+ {
288
+ name: "Chrome Ws URL",
289
+ value: "-chrome-ws-url",
290
+ description: "Use chrome browser instance launched elsewhere with the debugger listening at this URL (string)"
291
+ },
292
+ {
293
+ name: "Headless",
294
+ value: "-headless",
295
+ description: "Enable headless hybrid crawling (experimental)"
296
+ },
297
+ {
298
+ name: "Headless Options",
299
+ value: "-headless-options",
300
+ description: "Start headless chrome with additional options (string[])"
301
+ },
302
+ {
303
+ name: "No Incognito",
304
+ value: "-no-incognito",
305
+ description: "Start headless chrome without incognito mode"
306
+ },
307
+ {
308
+ name: "No Sandbox",
309
+ value: "-no-sandbox",
310
+ description: "Start headless chrome in --no-sandbox mode"
311
+ },
312
+ {
313
+ name: "Show Browser",
314
+ value: "-show-browser",
315
+ description: "Show the browser on the screen with headless mode"
316
+ },
317
+ {
318
+ name: "System Chrome",
319
+ value: "-system-chrome",
320
+ description: "Use local installed chrome browser instead of katana installed"
321
+ },
322
+ {
323
+ name: "System Chrome Path",
324
+ value: "-system-chrome-path",
325
+ description: "Use specified chrome browser for headless crawling (string)"
326
+ },
327
+ {
328
+ name: "Xhr Extraction",
329
+ value: "-xhr-extraction",
330
+ description: "Extract xhr request URL,method in jsonl output"
331
+ }
332
+ ]
333
+ },
334
+ {
335
+ displayName: "Value",
336
+ name: "value",
337
+ type: "string",
338
+ default: ""
339
+ }
340
+ ]
341
+ },
342
+ {
343
+ displayName: "Scope",
344
+ name: "scope",
345
+ values: [
346
+ {
347
+ displayName: "Options",
348
+ name: "key",
349
+ type: "options",
350
+ default: "-crawl-out-scope",
351
+ options: [
352
+ {
353
+ name: "Crawl Out Scope",
354
+ value: "-crawl-out-scope",
355
+ description: "Out of scope URL regex to be excluded by crawler (string[])"
356
+ },
357
+ {
358
+ name: "Crawl Scope",
359
+ value: "-crawl-scope",
360
+ description: "In scope URL regex to be followed by crawler (string[])"
361
+ },
362
+ {
363
+ name: "Display Out Scope",
364
+ value: "-display-out-scope",
365
+ description: "Display external endpoint from scoped crawling"
366
+ },
367
+ {
368
+ name: "Field Scope",
369
+ value: "-field-scope",
370
+ description: 'Pre-defined scope field (dn,rdn,fqdn) (default "rdn") (string)'
371
+ },
372
+ {
373
+ name: "No Scope",
374
+ value: "-no-scope",
375
+ description: "Disables host based default scope"
376
+ }
377
+ ]
378
+ },
379
+ {
380
+ displayName: "Value",
381
+ name: "value",
382
+ type: "string",
383
+ default: ""
384
+ }
385
+ ]
386
+ },
387
+ {
388
+ displayName: "Filter",
389
+ name: "filter",
390
+ values: [
391
+ {
392
+ displayName: "Options",
393
+ name: "key",
394
+ type: "options",
395
+ default: "-extension-filter",
396
+ options: [
397
+ {
398
+ name: "Extension Filter",
399
+ value: "-extension-filter",
400
+ description: "Filter output for given extension (eg, -ef png,css) (string[])"
401
+ },
402
+ {
403
+ name: "Extension Match",
404
+ value: "-extension-match",
405
+ description: "Match output for given extension (eg, -em php,html,js) (string[])"
406
+ },
407
+ {
408
+ name: "Field",
409
+ value: "-field",
410
+ description: "Field to display in output (URL,path,fqdn,rdn,rurl,qurl,qpath,file,ufile,key,value,kv,dir,udir) (string)"
411
+ },
412
+ {
413
+ name: "Filter Condition",
414
+ value: "-filter-condition",
415
+ description: "Filter response with dsl based condition (string)"
416
+ },
417
+ {
418
+ name: "Filter Regex",
419
+ value: "-filter-regex",
420
+ description: "Regex or list of regex to filter on output URL (cli, file) (string[])"
421
+ },
422
+ {
423
+ name: "Match Condition",
424
+ value: "-match-condition",
425
+ description: "Match response with dsl based condition (string)"
426
+ },
427
+ {
428
+ name: "Match Regex",
429
+ value: "-match-regex",
430
+ description: "Regex or list of regex to match on output URL (cli, file) (string[])"
431
+ },
432
+ {
433
+ name: "Store Field",
434
+ value: "-store-field",
435
+ description: "Field to store in per-host output (URL,path,fqdn,rdn,rurl,qurl,qpath,file,ufile,key,value,kv,dir,udir) (string)"
436
+ }
437
+ ]
438
+ },
439
+ {
440
+ displayName: "Value",
441
+ name: "value",
442
+ type: "string",
443
+ default: ""
444
+ }
445
+ ]
446
+ },
447
+ {
448
+ displayName: "Rate Limit",
449
+ name: "rateLimit",
450
+ values: [
451
+ {
452
+ displayName: "Options",
453
+ name: "key",
454
+ type: "options",
455
+ default: "-concurrency",
456
+ options: [
457
+ {
458
+ name: "Concurrency",
459
+ value: "-concurrency",
460
+ description: "Number of concurrent fetchers to use (default 10) (int)"
461
+ },
462
+ {
463
+ name: "Delay",
464
+ value: "-delay",
465
+ description: "Request delay between each request in seconds (int)"
466
+ },
467
+ {
468
+ name: "Parallelism",
469
+ value: "-parallelism",
470
+ description: "Number of concurrent inputs to process (default 10) (int)"
471
+ },
472
+ {
473
+ name: "Rate Limit",
474
+ value: "-rate-limit",
475
+ description: "Maximum requests to send per second (default 150) (int)"
476
+ },
477
+ {
478
+ name: "Rate Limit Minute",
479
+ value: "-rate-limit-minute",
480
+ description: "Maximum number of requests to send per minute (int)"
481
+ }
482
+ ]
483
+ },
484
+ {
485
+ displayName: "Value",
486
+ name: "value",
487
+ type: "string",
488
+ default: ""
489
+ }
490
+ ]
491
+ },
492
+ {
493
+ displayName: "Output",
494
+ name: "output",
495
+ values: [
496
+ {
497
+ displayName: "Options",
498
+ name: "key",
499
+ type: "options",
500
+ default: "-omit-raw",
501
+ options: [
502
+ {
503
+ name: "Omit Raw",
504
+ value: "-omit-raw",
505
+ description: "Omit raw requests/responses from jsonl output"
506
+ },
507
+ {
508
+ name: "Omit Body",
509
+ value: "-omit-body",
510
+ description: "Omit response body from jsonl output"
511
+ }
512
+ ]
513
+ }
514
+ ]
515
+ }
516
+ ]
517
+ }
518
+ ]
519
+ });
520
+ }
521
+ }