index.ts 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. import { setDefaultWasm } from "@certusone/wormhole-sdk/lib/cjs/solana/wasm";
  2. import * as listen from "./listen";
  3. import * as worker from "./worker";
  4. import * as rest from "./rest";
  5. import * as helpers from "./helpers";
  6. import { logger } from "./helpers";
  7. import { PromHelper } from "./promHelpers";
  8. import { Relay } from "./relay/iface";
  9. import { TerraRelay } from "./relay/terra";
  10. let configFile: string = ".env";
  11. if (process.env.PYTH_RELAY_CONFIG) {
  12. configFile = process.env.PYTH_RELAY_CONFIG;
  13. }
  14. console.log("Loading config file [%s]", configFile);
  15. require("dotenv").config({ path: configFile });
  16. setDefaultWasm("node");
  17. // Set up the logger.
  18. helpers.initLogger();
  19. let error: boolean = false;
  20. let listenOnly: boolean = false;
  21. let relayImpl: Relay;
  22. for (let idx = 0; idx < process.argv.length; ++idx) {
  23. if (process.argv[idx] === "--listen_only") {
  24. logger.info("running in listen only mode, will not relay anything!");
  25. listenOnly = true;
  26. }
  27. }
  28. relayImpl = new TerraRelay({
  29. nodeUrl: helpers.envOrErr("TERRA_NODE_URL"),
  30. terraChainId: helpers.envOrErr("TERRA_CHAIN_ID"),
  31. walletPrivateKey: helpers.envOrErr("TERRA_PRIVATE_KEY"),
  32. coin: helpers.envOrErr("TERRA_COIN"),
  33. contractAddress: helpers.envOrErr("TERRA_PYTH_CONTRACT_ADDRESS"),
  34. });
  35. if (
  36. !error &&
  37. listen.init(listenOnly) &&
  38. worker.init(!listenOnly, relayImpl) &&
  39. rest.init(!listenOnly)
  40. ) {
  41. // Start the Prometheus client with the app name and http port
  42. let promPort = 8081;
  43. if (process.env.PROM_PORT) {
  44. promPort = parseInt(process.env.PROM_PORT);
  45. }
  46. logger.info("prometheus client listening on port " + promPort);
  47. const promClient = new PromHelper("pyth_relay", promPort);
  48. listen.run(promClient);
  49. if (!listenOnly) {
  50. worker.run(promClient);
  51. rest.run();
  52. }
  53. if (process.env.READINESS_PORT) {
  54. const readinessPort: number = parseInt(process.env.READINESS_PORT);
  55. const Net = require("net");
  56. const readinessServer = new Net.Server();
  57. readinessServer.listen(readinessPort, function () {
  58. logger.info("listening for readiness requests on port " + readinessPort);
  59. });
  60. readinessServer.on("connection", function (socket: any) {
  61. //logger.debug("readiness connection");
  62. });
  63. }
  64. }