@nsshunt/stsappframework 3.0.93 → 3.0.95

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 (106) hide show
  1. package/dist/authutilsnode.js +6 -7
  2. package/dist/authutilsnode.js.map +1 -1
  3. package/dist/influxdb/influxDBManager.js +16 -17
  4. package/dist/influxdb/influxDBManager.js.map +1 -1
  5. package/dist/influxdb/influxDBManagerAgent.js +9 -13
  6. package/dist/influxdb/influxDBManagerAgent.js.map +1 -1
  7. package/dist/influxdb/influxDBManagerBase.js +2 -6
  8. package/dist/influxdb/influxDBManagerBase.js.map +1 -1
  9. package/dist/influxdb/influxDBManagerService.js +10 -14
  10. package/dist/influxdb/influxDBManagerService.js.map +1 -1
  11. package/dist/instrumentationsubscriber.js +11 -15
  12. package/dist/instrumentationsubscriber.js.map +1 -1
  13. package/dist/kafka/IMKafkaManager.js +2 -6
  14. package/dist/kafka/IMKafkaManager.js.map +1 -1
  15. package/dist/kafkatesting/produce.js +1 -5
  16. package/dist/kafkatesting/produce.js.map +1 -1
  17. package/dist/masterprocessbase.js +19 -20
  18. package/dist/masterprocessbase.js.map +1 -1
  19. package/dist/processbase.js +7 -8
  20. package/dist/processbase.js.map +1 -1
  21. package/dist/server.js +1 -1
  22. package/dist/server.js.map +1 -1
  23. package/dist/singleprocessbase.js +3 -4
  24. package/dist/singleprocessbase.js.map +1 -1
  25. package/dist/tcpclient/app2.js +2 -2
  26. package/dist/tcpserver/appmaster.js +39 -16
  27. package/dist/tcpserver/appmaster.js.map +1 -1
  28. package/dist/testing/appWorkerWSS.js +6 -7
  29. package/dist/testing/appWorkerWSS.js.map +1 -1
  30. package/dist/testing/singleservertest.test.js +8 -9
  31. package/dist/testing/singleservertest.test.js.map +1 -1
  32. package/dist/workerprocessbase.js +3 -4
  33. package/dist/workerprocessbase.js.map +1 -1
  34. package/package.json +1 -1
  35. package/src/authutilsnode.ts +8 -10
  36. package/src/influxdb/influxDBManager.ts +16 -18
  37. package/src/influxdb/influxDBManagerAgent.ts +9 -11
  38. package/src/influxdb/influxDBManagerBase.ts +2 -4
  39. package/src/influxdb/influxDBManagerService.ts +10 -12
  40. package/src/instrumentationsubscriber.ts +11 -14
  41. package/src/kafka/IMKafkaManager.ts +2 -4
  42. package/src/kafkatesting/produce.ts +1 -3
  43. package/src/masterprocessbase.ts +32 -24
  44. package/src/processbase.ts +7 -9
  45. package/src/server.ts +1 -1
  46. package/src/singleprocessbase.ts +3 -5
  47. package/src/tcpclient/app2.ts +2 -2
  48. package/src/tcpserver/appmaster.ts +39 -17
  49. package/src/testing/appWorkerWSS.ts +6 -8
  50. package/src/testing/singleservertest.test.ts +8 -10
  51. package/src/workerprocessbase.ts +3 -5
  52. package/src_new/authDefs.ts +37 -0
  53. package/src_new/authutilsnode.ts +375 -0
  54. package/src_new/commonTypes.ts +239 -0
  55. package/src_new/index.ts +22 -0
  56. package/src_new/influxdb/influxDBManager.ts +972 -0
  57. package/src_new/influxdb/influxDBManagerAgent.ts +316 -0
  58. package/src_new/influxdb/influxDBManagerBase.ts +111 -0
  59. package/src_new/influxdb/influxDBManagerService.ts +375 -0
  60. package/src_new/instrumentationsubscriber.ts +286 -0
  61. package/src_new/kafka/IMKafkaManager.ts +154 -0
  62. package/src_new/kafka/kafkaconsumer.ts +82 -0
  63. package/src_new/kafka/kafkamanager.ts +186 -0
  64. package/src_new/kafka/kafkaproducer.ts +58 -0
  65. package/src_new/kafkatesting/config.ts +10 -0
  66. package/src_new/kafkatesting/consume.ts +116 -0
  67. package/src_new/kafkatesting/produce.ts +155 -0
  68. package/src_new/masterprocessbase.ts +590 -0
  69. package/src_new/middleware/serverNetworkMiddleware.ts +240 -0
  70. package/src_new/network.ts +36 -0
  71. package/src_new/processbase.ts +413 -0
  72. package/src_new/processoptions.ts +164 -0
  73. package/src_new/publishertransports/publishTransportDirect.ts +45 -0
  74. package/src_new/publishertransports/publishTransportUtils.ts +53 -0
  75. package/src_new/server.ts +141 -0
  76. package/src_new/serverprocessbase.ts +393 -0
  77. package/src_new/singleprocessbase.ts +123 -0
  78. package/src_new/socketIoServerHelper.ts +177 -0
  79. package/src_new/stscontrollerbase.ts +15 -0
  80. package/src_new/stslatencycontroller.ts +27 -0
  81. package/src_new/stslatencyroute.ts +16 -0
  82. package/src_new/stsrouterbase.ts +22 -0
  83. package/src_new/tcpclient/app.ts +19 -0
  84. package/src_new/tcpclient/app2.ts +56 -0
  85. package/src_new/tcpserver/app.ts +11 -0
  86. package/src_new/tcpserver/appConfig.ts +65 -0
  87. package/src_new/tcpserver/appmaster.ts +522 -0
  88. package/src_new/validation/errors.ts +6 -0
  89. package/src_new/webworkertesting/app.ts +49 -0
  90. package/src_new/webworkertesting/worker.ts +24 -0
  91. package/src_new/workerprocessbase.test.ts +47 -0
  92. package/src_new/workerprocessbase.ts +187 -0
  93. package/types/authutilsnode.d.ts.map +1 -1
  94. package/types/influxdb/influxDBManager.d.ts.map +1 -1
  95. package/types/influxdb/influxDBManagerAgent.d.ts.map +1 -1
  96. package/types/influxdb/influxDBManagerBase.d.ts.map +1 -1
  97. package/types/influxdb/influxDBManagerService.d.ts.map +1 -1
  98. package/types/instrumentationsubscriber.d.ts.map +1 -1
  99. package/types/kafka/IMKafkaManager.d.ts.map +1 -1
  100. package/types/masterprocessbase.d.ts.map +1 -1
  101. package/types/processbase.d.ts +2 -2
  102. package/types/processbase.d.ts.map +1 -1
  103. package/types/singleprocessbase.d.ts.map +1 -1
  104. package/types/tcpserver/appmaster.d.ts.map +1 -1
  105. package/types/testing/appWorkerWSS.d.ts.map +1 -1
  106. package/types/workerprocessbase.d.ts.map +1 -1
@@ -0,0 +1,155 @@
1
+ /*
2
+
3
+ kafka example server #01 - Docker Compose File
4
+ ----------------------------------------------
5
+ Note: In this example, the log retention is set to 24 hours (rather than default to 1 week)
6
+ https://www.conduktor.io/kafka/kafka-topic-configuration-log-retention/
7
+
8
+ version: '2'
9
+ services:
10
+ zookeeper:
11
+ image: wurstmeister/zookeeper
12
+ ports:
13
+ - "2181:2181"
14
+ restart: unless-stopped
15
+
16
+ kafka:
17
+ image: wurstmeister/kafka
18
+ ports:
19
+ - "9092:9092"
20
+ environment:
21
+ DOCKER_API_VERSION: 1.22
22
+ KAFKA_ADVERTISED_HOST_NAME: 192.168.14.92
23
+ KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
24
+ KAFKA_CREATE_TOPICS: "topic-name2:3:1"
25
+ KAFKA_LOG_RETENTION_MS: 86400000
26
+ KAFKA_LOG_RETENTION_BYTES: -1
27
+ volumes:
28
+ - /var/run/docker.sock:/var/run/docker.sock
29
+ restart: unless-stopped
30
+
31
+
32
+ kafka example server #02 - Docker Compose File
33
+ ----------------------------------------------
34
+ version: "3.9" # optional since v1.27.0
35
+
36
+ networks:
37
+ app-tier:
38
+ driver: bridge
39
+
40
+ services:
41
+ kafka:
42
+ image: 'bitnami/kafka:latest'
43
+ ports:
44
+ - '9092:9092'
45
+ networks:
46
+ - app-tier
47
+ environment:
48
+ - ALLOW_PLAINTEXT_LISTENER=yes
49
+ - KAFKA_CFG_AUTO_CREATE_TOPICS_ENABLE=true
50
+ - KAFKA_CFG_ADVERTISED_LISTENERS=PLAINTEXT://192.168.14.92:9092
51
+
52
+ */
53
+ import { TOPIC, CLIENT_ID, BROKERS, PARTITIONS, TIMEOUT } from './config'
54
+
55
+ import { KafkaManager } from './../kafka/kafkamanager'
56
+
57
+ import 'colors'
58
+
59
+ import chalk from 'chalk';
60
+
61
+ async function Sleep(milliseconds = 1000) {
62
+ return new Promise(resolve => setTimeout(resolve, milliseconds))
63
+ }
64
+
65
+ const km = new KafkaManager({
66
+ clientId: CLIENT_ID + process.env.CLIENT_ID,
67
+ brokers: BROKERS,
68
+ adminTimeout: TIMEOUT,
69
+ connectionTimeout: TIMEOUT,
70
+ requestTimeout: TIMEOUT,
71
+ logLevel: 'NOTHING',
72
+ useSSL: false
73
+ });
74
+
75
+ const runme = async () => {
76
+ await km.CreateTopic(TOPIC, PARTITIONS);
77
+ await km.CreateTopic('zzz', 1);
78
+ await km.CreateTopic('yyy', 1);
79
+
80
+ const producer = km.CreateProducer();
81
+
82
+ await producer.Connect();
83
+
84
+ const count = 100000;
85
+ const sleepTime = 1000;
86
+
87
+ process.on("SIGINT", async () => {
88
+ console.log('=========SIGTERM START =======================')
89
+ await producer.Disconnect();
90
+ console.log('=========SIGTERM END =======================')
91
+ process.exit();
92
+ });
93
+
94
+ for (let i=0; i < count; i++) {
95
+ if (i % 100 === 0) console.log(i);
96
+ const retVal = await producer.SendMessages(TOPIC, [
97
+ { key: 'key1', value: chalk.green(`hello world - ${i}`) },
98
+ { key: 'key2', value: 'hey hey! -2' },
99
+ { key: 'key3', value: 'hey hey! -3' },
100
+ { key: 'key4', value: 'hey hey! -4' },
101
+ { key: 'key5', value: 'hey hey! -5' }
102
+ ]
103
+ );
104
+
105
+ await producer.SendMessages('zzz', [
106
+ { key: 'key-zzz', value: `hello world - ${i}`.yellow }
107
+ ]
108
+ );
109
+
110
+ await producer.SendMessages('yyy', [
111
+ { key: 'key-yyy', value: `hello world - ${i}`.cyan }
112
+ ]
113
+ );
114
+
115
+ if (i % 100 === 0) {
116
+ console.log(retVal);
117
+ console.log(` ------------=================> ${i}`);
118
+ }
119
+ if (sleepTime >= 0) {
120
+ await Sleep(sleepTime);
121
+ }
122
+ }
123
+
124
+ await producer.Disconnect();
125
+ }
126
+
127
+ /*
128
+ const errorTypes = ['unhandledRejection', 'uncaughtException']
129
+ const signalTraps = ['SIGTERM', 'SIGINT', 'SIGUSR2']
130
+
131
+ errorTypes.forEach(type => {
132
+ process.on(type, async () => {
133
+ try {
134
+ console.log(`process.on ${type}`)
135
+ await producer.disconnect()
136
+ process.exit(0)
137
+ } catch (_) {
138
+ process.exit(1)
139
+ }
140
+ })
141
+ })
142
+
143
+ signalTraps.forEach(type => {
144
+ process.once(type, async () => {
145
+ try {
146
+ await producer.disconnect()
147
+ } finally {
148
+ process.kill(process.pid, type)
149
+ }
150
+ })
151
+ })
152
+ */
153
+
154
+ runme().catch(e => console.error(`[example/producer] ${e.message}`, e))
155
+