forked from connectrpc/examples-es
-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.ts
90 lines (84 loc) · 3.15 KB
/
server.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// Copyright 2021-2023 The Connect Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import { connectNodeAdapter } from "@connectrpc/connect-node";
import { cors as connectCors } from "@connectrpc/connect";
import cors from "cors";
import routes from "./connect.js";
import * as esbuild from "esbuild";
import http from "node:http";
import { readFileSync } from "node:fs";
if (process.argv[1] === new URL(import.meta.url).pathname) {
const PORT = parseInt(process.argv[2] ?? 3000);
build().listen({ host: "localhost", port: PORT });
console.log(`The app is running on http://localhost:${PORT}`);
console.log("Run `npm run client` for a terminal client.");
}
export function build() {
// The adapter turns our RPC routes into as Node.js request handler.
const handler = connectNodeAdapter({
routes,
// If none of the RPC routes match, this handler is called.
// We serve our web interface here:
fallback(req, res) {
switch (req.url) {
case "/":
res.writeHead(200, { "content-type": "text/html" });
res.write(readFileSync("www/index.html", "utf8"), "utf8");
res.end();
break;
case "/app.css":
res.writeHead(200, { "content-type": "text/css" });
res.write(readFileSync("www/app.css", "utf8"), "utf8");
res.end();
break;
case "/webclient.js":
void esbuild
.build({
entryPoints: ["webclient.ts"],
bundle: true,
write: false,
globalName: "eliza",
})
.then((result) => {
res.writeHead(200, {
"content-type": "application/javascript",
});
res.write(result.outputFiles[0].text, "utf8");
res.end();
});
break;
default:
res.writeHead(404);
res.end();
}
},
});
// CORS example using Express middleware with vanilla HTTP server
// The @connectrpc/connect package exports convenience variables for
// configuring a CORS setup.
const corsHandler = cors({
// Reflects the request origin. This should only be used for development.
// Production should explicitly specify an origin
origin: true,
methods: [...connectCors.allowedMethods],
allowedHeaders: [...connectCors.allowedHeaders],
exposedHeaders: [...connectCors.exposedHeaders],
});
// If the CORS middleware is not needed, simply start the server with the
// handler only using http.createServer(handler)
return http
.createServer((req, res) => {
corsHandler(req, res, () => handler(req, res));
});
}