|
| 1 | +#!/usr/bin/env node |
| 2 | +"use strict"; |
| 3 | + |
| 4 | +//module dependencies |
| 5 | +var server = require("../dist/server"); |
| 6 | +var debug = require("debug")("express:server"); |
| 7 | +var http = require("http"); |
| 8 | + |
| 9 | +//create http server |
| 10 | +var httpPort = normalizePort(process.env.PORT || 8080); |
| 11 | +var app = server.Server.bootstrap().app; |
| 12 | +app.set("port", httpPort); |
| 13 | +var httpServer = http.createServer(app); |
| 14 | + |
| 15 | +//listen on provided ports |
| 16 | +httpServer.listen(httpPort); |
| 17 | + |
| 18 | +//add error handler |
| 19 | +httpServer.on("error", onError); |
| 20 | + |
| 21 | +//start listening on port |
| 22 | +httpServer.on("listening", onListening); |
| 23 | + |
| 24 | + |
| 25 | +/** |
| 26 | + * Normalize a port into a number, string, or false. |
| 27 | + */ |
| 28 | +function normalizePort(val) { |
| 29 | + var port = parseInt(val, 10); |
| 30 | + |
| 31 | + if (isNaN(port)) { |
| 32 | + // named pipe |
| 33 | + return val; |
| 34 | + } |
| 35 | + |
| 36 | + if (port >= 0) { |
| 37 | + // port number |
| 38 | + return port; |
| 39 | + } |
| 40 | + |
| 41 | + return false; |
| 42 | +} |
| 43 | + |
| 44 | +/** |
| 45 | + * Event listener for HTTP server "error" event. |
| 46 | + */ |
| 47 | +function onError(error) { |
| 48 | + if (error.syscall !== "listen") { |
| 49 | + throw error; |
| 50 | + } |
| 51 | + |
| 52 | + var bind = typeof port === "string" |
| 53 | + ? "Pipe " + port |
| 54 | + : "Port " + port; |
| 55 | + |
| 56 | + // handle specific listen errors with friendly messages |
| 57 | + switch (error.code) { |
| 58 | + case "EACCES": |
| 59 | + console.error(bind + " requires elevated privileges"); |
| 60 | + process.exit(1); |
| 61 | + break; |
| 62 | + case "EADDRINUSE": |
| 63 | + console.error(bind + " is already in use"); |
| 64 | + process.exit(1); |
| 65 | + break; |
| 66 | + default: |
| 67 | + throw error; |
| 68 | + } |
| 69 | +} |
| 70 | + |
| 71 | +/** |
| 72 | + * Event listener for HTTP server "listening" event. |
| 73 | + */ |
| 74 | +function onListening() { |
| 75 | + var addr = httpServer.address(); |
| 76 | + var bind = typeof addr === "string" |
| 77 | + ? "pipe " + addr |
| 78 | + : "port " + addr.port; |
| 79 | + debug("Listening on " + bind); |
| 80 | +} |
0 commit comments