geonix 1.22.3 → 1.22.5

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.
package/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- export function encode(data: any): Uint8Array;
1
+ export function encode(data: any): Uint8Array<ArrayBuffer>;
2
2
  export function decode(data: any): unknown;
3
3
  export const codec: import("nats").Codec<unknown>;
4
4
  export const connection: Connection;
@@ -195,15 +195,24 @@ type ParsedMultiPart = {
195
195
  body: Readable;
196
196
  };
197
197
  type ServiceOptions = {
198
- middleware: {
199
- json: boolean;
200
- raw: boolean;
201
- cookies: boolean;
202
- };
198
+ middleware?: {
199
+ /**
200
+ * Enable JSON middleware
201
+ */
202
+ json?: boolean | undefined;
203
+ /**
204
+ * Enable RAW middleware
205
+ */
206
+ raw?: boolean | undefined;
207
+ /**
208
+ * Enable cookies middleware
209
+ */
210
+ cookies?: boolean | undefined;
211
+ } | undefined;
203
212
  /**
204
213
  * Enable full beacon
205
214
  */
206
- fullBeacon: boolean;
215
+ fullBeacon?: boolean | undefined;
207
216
  };
208
217
  /**
209
218
  * Parse nats:// URL
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "geonix",
3
- "version": "1.22.3",
3
+ "version": "1.22.5",
4
4
  "type": "module",
5
5
  "description": "",
6
6
  "bin": {
package/src/Types.js CHANGED
@@ -16,9 +16,9 @@
16
16
 
17
17
  /**
18
18
  * @typedef {Object} ServiceOptions
19
- * @property {Object} middleware
20
- * @property {boolean} middleware.json Enable JSON middleware
21
- * @property {boolean} middleware.raw Enable RAW middleware
22
- * @property {boolean} middleware.cookies Enable cookies middleware
23
- * @property {boolean} fullBeacon Enable full beacon
19
+ * @property {Object} [middleware]
20
+ * @property {boolean} [middleware.json] Enable JSON middleware
21
+ * @property {boolean} [middleware.raw] Enable RAW middleware
22
+ * @property {boolean} [middleware.cookies] Enable cookies middleware
23
+ * @property {boolean} [fullBeacon] Enable full beacon
24
24
  */
package/src/WebServer.js CHANGED
@@ -50,6 +50,8 @@ class WebServer {
50
50
  #ready = false;
51
51
  #started = false;
52
52
 
53
+ #routers = [];
54
+
53
55
  async start() {
54
56
  if (this.#started) { return; }
55
57
 
@@ -88,17 +90,41 @@ class WebServer {
88
90
  res.send({ status: "healthy", services: Service.serviceClasses });
89
91
  });
90
92
 
91
- // wait for 2 seconds and then set fall-through handler
92
- // this should provide more than enough time to start all the services
93
- setTimeout(() => {
94
- // default answer
95
- this.#app.all("*", (req, res) => {
96
- res.status(404).send({
97
- error: 404,
98
- source: "ws"
93
+ // middleware to handle dynamic routers
94
+ this.#app.use(async (req, res, next) => {
95
+ const routers = [...this.#routers];
96
+ let currentResolve;
97
+ let handled = false;
98
+
99
+ res.on("finish", () => {
100
+ handled = true;
101
+ currentResolve();
102
+ });
103
+
104
+ let router = routers.shift();
105
+ while (router) {
106
+ router = await new Promise((resolve) => {
107
+ currentResolve = resolve;
108
+ router(req, res, () => {
109
+ // go to next router
110
+ resolve(routers.shift());
111
+ });
99
112
  });
113
+ }
114
+
115
+ if (!handled) {
116
+ // go to next router
117
+ next();
118
+ }
119
+ });
120
+
121
+ // fallthrough handler
122
+ this.#app.all("*", (req, res) => {
123
+ res.status(404).send({
124
+ error: 404,
125
+ source: "ws"
100
126
  });
101
- }, 2000);
127
+ });
102
128
 
103
129
  // config
104
130
  this.#app.disable("x-powered-by");
@@ -115,7 +141,7 @@ class WebServer {
115
141
 
116
142
  router() {
117
143
  const router = Router();
118
- this.#app.use(router);
144
+ this.#routers.push(router);
119
145
  return router;
120
146
  }
121
147
 
@@ -0,0 +1,24 @@
1
+ import { Gateway, Service, streamToBuffer } from "../exports.js";
2
+ import { parseMultipart, sleep } from "../src/Util.js";
3
+
4
+ class TestService extends Service {
5
+
6
+ "GET /test/"(req, res) {
7
+ res.send("Hello World");
8
+ }
9
+
10
+ }
11
+
12
+ class Application extends Service {
13
+
14
+ "GET /"(req, res) {
15
+ res.send("app");
16
+ }
17
+
18
+ }
19
+
20
+ Application.start();
21
+
22
+ await sleep(3000);
23
+
24
+ TestService.start();