sprinklers3/server/index.ts

35 lines
933 B
TypeScript
Raw Normal View History

/* tslint:disable:ordered-imports */
import "reflect-metadata";
import "./configureAlias";
2018-07-25 12:53:33 -06:00
import "@common/env";
import "./configureLogger";
import log from "@common/logger";
2018-05-24 10:36:16 -06:00
import {Server} from "http";
2017-10-09 08:09:08 -06:00
import * as WebSocket from "ws";
import { ServerState } from "./state";
import { createApp } from "./express";
import { WebSocketApi } from "./sprinklersRpc/WebSocketApi";
const state = new ServerState();
const app = createApp(state);
const webSocketApi = new WebSocketApi(state);
2017-09-07 12:26:23 -06:00
const port = +(process.env.PORT || 8080);
const host = process.env.HOST || "0.0.0.0";
2017-10-09 08:09:08 -06:00
const server = new Server(app);
2018-05-24 10:36:16 -06:00
const webSocketServer = new WebSocket.Server({server});
webSocketApi.listen(webSocketServer);
2017-10-09 08:09:08 -06:00
state.start()
.then(() => {
server.listen(port, host, () => {
log.info(`listening at ${host}:${port}`);
});
})
.catch((err) => {
log.error({ err }, "error starting server");
});