@panguard-ai/panguard-trap 0.1.0

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 (69) hide show
  1. package/dist/cli/index.d.ts +45 -0
  2. package/dist/cli/index.d.ts.map +1 -0
  3. package/dist/cli/index.js +298 -0
  4. package/dist/cli/index.js.map +1 -0
  5. package/dist/index.d.ts +23 -0
  6. package/dist/index.d.ts.map +1 -0
  7. package/dist/index.js +26 -0
  8. package/dist/index.js.map +1 -0
  9. package/dist/intel/index.d.ts +38 -0
  10. package/dist/intel/index.d.ts.map +1 -0
  11. package/dist/intel/index.js +157 -0
  12. package/dist/intel/index.js.map +1 -0
  13. package/dist/profiler/attacker-profiler.d.ts +68 -0
  14. package/dist/profiler/attacker-profiler.d.ts.map +1 -0
  15. package/dist/profiler/attacker-profiler.js +316 -0
  16. package/dist/profiler/attacker-profiler.js.map +1 -0
  17. package/dist/profiler/index.d.ts +8 -0
  18. package/dist/profiler/index.d.ts.map +1 -0
  19. package/dist/profiler/index.js +8 -0
  20. package/dist/profiler/index.js.map +1 -0
  21. package/dist/services/base-service.d.ts +61 -0
  22. package/dist/services/base-service.d.ts.map +1 -0
  23. package/dist/services/base-service.js +190 -0
  24. package/dist/services/base-service.js.map +1 -0
  25. package/dist/services/generic-trap.d.ts +22 -0
  26. package/dist/services/generic-trap.d.ts.map +1 -0
  27. package/dist/services/generic-trap.js +439 -0
  28. package/dist/services/generic-trap.js.map +1 -0
  29. package/dist/services/http-trap.d.ts +36 -0
  30. package/dist/services/http-trap.d.ts.map +1 -0
  31. package/dist/services/http-trap.js +218 -0
  32. package/dist/services/http-trap.js.map +1 -0
  33. package/dist/services/index.d.ts +26 -0
  34. package/dist/services/index.d.ts.map +1 -0
  35. package/dist/services/index.js +52 -0
  36. package/dist/services/index.js.map +1 -0
  37. package/dist/services/mysql-trap.d.ts +22 -0
  38. package/dist/services/mysql-trap.d.ts.map +1 -0
  39. package/dist/services/mysql-trap.js +374 -0
  40. package/dist/services/mysql-trap.js.map +1 -0
  41. package/dist/services/rdp-trap.d.ts +21 -0
  42. package/dist/services/rdp-trap.d.ts.map +1 -0
  43. package/dist/services/rdp-trap.js +299 -0
  44. package/dist/services/rdp-trap.js.map +1 -0
  45. package/dist/services/redis-trap.d.ts +21 -0
  46. package/dist/services/redis-trap.d.ts.map +1 -0
  47. package/dist/services/redis-trap.js +321 -0
  48. package/dist/services/redis-trap.js.map +1 -0
  49. package/dist/services/smb-trap.d.ts +21 -0
  50. package/dist/services/smb-trap.d.ts.map +1 -0
  51. package/dist/services/smb-trap.js +358 -0
  52. package/dist/services/smb-trap.js.map +1 -0
  53. package/dist/services/ssh-trap.d.ts +43 -0
  54. package/dist/services/ssh-trap.d.ts.map +1 -0
  55. package/dist/services/ssh-trap.js +397 -0
  56. package/dist/services/ssh-trap.js.map +1 -0
  57. package/dist/threat-cloud-uploader.d.ts +48 -0
  58. package/dist/threat-cloud-uploader.d.ts.map +1 -0
  59. package/dist/threat-cloud-uploader.js +125 -0
  60. package/dist/threat-cloud-uploader.js.map +1 -0
  61. package/dist/trap-engine.d.ts +80 -0
  62. package/dist/trap-engine.d.ts.map +1 -0
  63. package/dist/trap-engine.js +279 -0
  64. package/dist/trap-engine.js.map +1 -0
  65. package/dist/types.d.ts +229 -0
  66. package/dist/types.d.ts.map +1 -0
  67. package/dist/types.js +89 -0
  68. package/dist/types.js.map +1 -0
  69. package/package.json +37 -0
package/dist/types.js ADDED
@@ -0,0 +1,89 @@
1
+ /**
2
+ * PanguardTrap type definitions
3
+ * PanguardTrap 型別定義
4
+ * @module @panguard-ai/panguard-trap/types
5
+ */
6
+ /** Default service configurations / 預設服務配置 */
7
+ export const DEFAULT_SERVICE_CONFIGS = {
8
+ ssh: {
9
+ type: 'ssh',
10
+ port: 2222,
11
+ banner: 'SSH-2.0-OpenSSH_8.9p1 Ubuntu-3ubuntu0.6',
12
+ maxConnections: 50,
13
+ sessionTimeoutMs: 30_000,
14
+ responseDelayMs: 100,
15
+ },
16
+ http: {
17
+ type: 'http',
18
+ port: 8080,
19
+ banner: 'Apache/2.4.57 (Ubuntu)',
20
+ maxConnections: 100,
21
+ sessionTimeoutMs: 60_000,
22
+ responseDelayMs: 50,
23
+ },
24
+ ftp: {
25
+ type: 'ftp',
26
+ port: 2121,
27
+ banner: '220 ProFTPD 1.3.8 Server (Panguard) [::ffff:0.0.0.0]',
28
+ maxConnections: 30,
29
+ sessionTimeoutMs: 30_000,
30
+ responseDelayMs: 100,
31
+ },
32
+ smb: {
33
+ type: 'smb',
34
+ port: 4450,
35
+ maxConnections: 20,
36
+ sessionTimeoutMs: 30_000,
37
+ responseDelayMs: 150,
38
+ },
39
+ mysql: {
40
+ type: 'mysql',
41
+ port: 3307,
42
+ banner: '5.7.42-0ubuntu0.18.04.1',
43
+ maxConnections: 30,
44
+ sessionTimeoutMs: 30_000,
45
+ responseDelayMs: 80,
46
+ },
47
+ rdp: {
48
+ type: 'rdp',
49
+ port: 3390,
50
+ maxConnections: 10,
51
+ sessionTimeoutMs: 60_000,
52
+ responseDelayMs: 200,
53
+ },
54
+ telnet: {
55
+ type: 'telnet',
56
+ port: 2323,
57
+ banner: 'Ubuntu 22.04 LTS',
58
+ maxConnections: 30,
59
+ sessionTimeoutMs: 30_000,
60
+ responseDelayMs: 100,
61
+ },
62
+ redis: {
63
+ type: 'redis',
64
+ port: 6380,
65
+ maxConnections: 20,
66
+ sessionTimeoutMs: 30_000,
67
+ responseDelayMs: 30,
68
+ },
69
+ };
70
+ /** Default trap configuration / 預設蜜罐配置 */
71
+ export const DEFAULT_TRAP_CONFIG = {
72
+ services: [
73
+ { ...DEFAULT_SERVICE_CONFIGS.ssh, enabled: true },
74
+ { ...DEFAULT_SERVICE_CONFIGS.http, enabled: true },
75
+ { ...DEFAULT_SERVICE_CONFIGS.ftp, enabled: false },
76
+ { ...DEFAULT_SERVICE_CONFIGS.mysql, enabled: false },
77
+ { ...DEFAULT_SERVICE_CONFIGS.telnet, enabled: false },
78
+ { ...DEFAULT_SERVICE_CONFIGS.redis, enabled: false },
79
+ { ...DEFAULT_SERVICE_CONFIGS.smb, enabled: false },
80
+ { ...DEFAULT_SERVICE_CONFIGS.rdp, enabled: false },
81
+ ],
82
+ dataDir: '/var/lib/panguard/trap',
83
+ maxSessionsInMemory: 1000,
84
+ feedThreatCloud: true,
85
+ grantFakeAccess: true,
86
+ fakeAccessAfterAttempts: 3,
87
+ notifyOnHighValue: true,
88
+ };
89
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAuCH,8CAA8C;AAC9C,MAAM,CAAC,MAAM,uBAAuB,GAGhC;IACF,GAAG,EAAE;QACH,IAAI,EAAE,KAAK;QACX,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,yCAAyC;QACjD,cAAc,EAAE,EAAE;QAClB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,GAAG;KACrB;IACD,IAAI,EAAE;QACJ,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,wBAAwB;QAChC,cAAc,EAAE,GAAG;QACnB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,EAAE;KACpB;IACD,GAAG,EAAE;QACH,IAAI,EAAE,KAAK;QACX,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,sDAAsD;QAC9D,cAAc,EAAE,EAAE;QAClB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,GAAG;KACrB;IACD,GAAG,EAAE;QACH,IAAI,EAAE,KAAK;QACX,IAAI,EAAE,IAAI;QACV,cAAc,EAAE,EAAE;QAClB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,GAAG;KACrB;IACD,KAAK,EAAE;QACL,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,yBAAyB;QACjC,cAAc,EAAE,EAAE;QAClB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,EAAE;KACpB;IACD,GAAG,EAAE;QACH,IAAI,EAAE,KAAK;QACX,IAAI,EAAE,IAAI;QACV,cAAc,EAAE,EAAE;QAClB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,GAAG;KACrB;IACD,MAAM,EAAE;QACN,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,kBAAkB;QAC1B,cAAc,EAAE,EAAE;QAClB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,GAAG;KACrB;IACD,KAAK,EAAE;QACL,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,IAAI;QACV,cAAc,EAAE,EAAE;QAClB,gBAAgB,EAAE,MAAM;QACxB,eAAe,EAAE,EAAE;KACpB;CACF,CAAC;AAwLF,0CAA0C;AAC1C,MAAM,CAAC,MAAM,mBAAmB,GAAe;IAC7C,QAAQ,EAAE;QACR,EAAE,GAAG,uBAAuB,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE;QACjD,EAAE,GAAG,uBAAuB,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE;QAClD,EAAE,GAAG,uBAAuB,CAAC,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE;QAClD,EAAE,GAAG,uBAAuB,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE;QACpD,EAAE,GAAG,uBAAuB,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE;QACrD,EAAE,GAAG,uBAAuB,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE;QACpD,EAAE,GAAG,uBAAuB,CAAC,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE;QAClD,EAAE,GAAG,uBAAuB,CAAC,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE;KACnD;IACD,OAAO,EAAE,wBAAwB;IACjC,mBAAmB,EAAE,IAAI;IACzB,eAAe,EAAE,IAAI;IACrB,eAAe,EAAE,IAAI;IACrB,uBAAuB,EAAE,CAAC;IAC1B,iBAAiB,EAAE,IAAI;CACxB,CAAC"}
package/package.json ADDED
@@ -0,0 +1,37 @@
1
+ {
2
+ "name": "@panguard-ai/panguard-trap",
3
+ "version": "0.1.0",
4
+ "type": "module",
5
+ "description": "Smart honeypot for attacker profiling / 智慧蜜罐,誘捕並分析攻擊者",
6
+ "main": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "bin": {
9
+ "panguard-trap": "./dist/cli/index.js"
10
+ },
11
+ "publishConfig": {
12
+ "access": "public"
13
+ },
14
+ "files": [
15
+ "dist",
16
+ "package.json",
17
+ "README.md"
18
+ ],
19
+ "scripts": {
20
+ "build": "tsc --build",
21
+ "clean": "rm -rf dist tsconfig.tsbuildinfo",
22
+ "typecheck": "tsc --noEmit",
23
+ "test": "vitest run",
24
+ "dev": "tsc --build --watch",
25
+ "prepublishOnly": "pnpm run build"
26
+ },
27
+ "dependencies": {
28
+ "@panguard-ai/core": "workspace:*"
29
+ },
30
+ "optionalDependencies": {
31
+ "ssh2": "^1.16.0"
32
+ },
33
+ "devDependencies": {
34
+ "@types/node": "^22.14.0",
35
+ "typescript": "~5.7.3"
36
+ }
37
+ }