geonix 1.22.4 → 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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "geonix",
3
- "version": "1.22.4",
3
+ "version": "1.22.5",
4
4
  "type": "module",
5
5
  "description": "",
6
6
  "bin": {
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();
package/dev.js DELETED
@@ -1,62 +0,0 @@
1
- import { BasicAuth, HTTP, Transport, Unit } from "geonix";
2
- import { Gateway } from "./src/Gateway.js";
3
-
4
- const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
5
-
6
- const middleware = [
7
- BasicAuth({ realm: "Test", username: "u", password: "pa" })
8
- ];
9
-
10
- class TimeService {
11
-
12
- getTime() {
13
- return new Date().toISOString();
14
- }
15
-
16
- [HTTP.GET("/time", middleware)] = async (req, res) => {
17
- res.setHeader("X-Test", "Test");
18
- return {
19
- time: this.getTime(),
20
- id: this.$meta.id
21
- };
22
- };
23
-
24
- [HTTP.GET("/time2", middleware)] = async (req, res) => {
25
- res.setHeader("X-Test", "Test2");
26
- return {
27
- time: this.getTime(),
28
- id: this.$meta.id
29
- };
30
- };
31
-
32
- [HTTP.filter] = async () => {
33
-
34
- };
35
-
36
- [HTTP.ERROR()] = async () => {
37
- return {
38
- error: "Unexpected error"
39
- };
40
- };
41
-
42
- }
43
-
44
- const transport = await Transport.start("nats://localhost:4222");
45
-
46
- await Unit.start(TimeService, {
47
- meta: {
48
- id: "first",
49
- },
50
- transport,
51
- port: 30000
52
- });
53
-
54
- await Unit.start(TimeService, {
55
- meta: {
56
- id: "second",
57
- },
58
- transport,
59
- port: 30001
60
- });
61
-
62
- Gateway.start({ transport, gatewayPort: 8080 });