UNPKG

3.99 kBJavaScriptView Raw
1'use strict';
2
3let serve = (() => {
4 var _ref = _asyncToGenerator(function* (bundler, port, useHTTPS = false) {
5 let handler = middleware(bundler);
6 let server;
7 if (!useHTTPS) {
8 server = http.createServer(handler);
9 } else if (typeof useHTTPS === 'boolean') {
10 server = https.createServer(generateCertificate(bundler.options), handler);
11 } else {
12 server = https.createServer((yield getCertificate(useHTTPS)), handler);
13 }
14
15 let freePort = yield getPort({ port });
16 server.listen(freePort);
17
18 return new Promise(function (resolve, reject) {
19 server.on('error', function (err) {
20 logger.error(new Error(serverErrors(err, server.address().port)));
21 reject(err);
22 });
23
24 server.once('listening', function () {
25 let addon = server.address().port !== port ? `- ${logger.chalk.yellow(`configured port ${port} could not be used.`)}` : '';
26
27 logger.persistent(`Server running at ${logger.chalk.cyan(`${useHTTPS ? 'https' : 'http'}://localhost:${server.address().port}`)} ${addon}`);
28
29 resolve(server);
30 });
31 });
32 });
33
34 return function serve(_x, _x2) {
35 return _ref.apply(this, arguments);
36 };
37})();
38
39function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
40
41const http = require('http');
42const https = require('https');
43const serveStatic = require('serve-static');
44const getPort = require('get-port');
45const serverErrors = require('./utils/customErrors').serverErrors;
46const generateCertificate = require('./utils/generateCertificate');
47const getCertificate = require('./utils/getCertificate');
48const logger = require('./Logger');
49const path = require('path');
50
51serveStatic.mime.define({
52 'application/wasm': ['wasm']
53});
54
55function setHeaders(res) {
56 enableCors(res);
57}
58
59function enableCors(res) {
60 res.setHeader('Access-Control-Allow-Origin', '*');
61 res.setHeader('Access-Control-Allow-Methods', 'GET, HEAD, PUT, PATCH, POST, DELETE');
62 res.setHeader('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept, Content-Type');
63}
64
65function middleware(bundler) {
66 const serve = serveStatic(bundler.options.outDir, {
67 index: false,
68 setHeaders: setHeaders
69 });
70
71 return function (req, res, next) {
72 // Wait for the bundler to finish bundling if needed
73 if (bundler.pending) {
74 bundler.once('bundled', respond);
75 } else {
76 respond();
77 }
78
79 function respond() {
80 if (bundler.errored) {
81 return send500();
82 } else if (!req.url.startsWith(bundler.options.publicURL) || path.extname(req.url) === '') {
83 // If the URL doesn't start with the public path, or the URL doesn't
84 // have a file extension, send the main HTML bundle.
85 return sendIndex();
86 } else {
87 // Otherwise, serve the file from the dist folder
88 req.url = req.url.slice(bundler.options.publicURL.length);
89 return serve(req, res, send404);
90 }
91 }
92
93 function sendIndex() {
94 // If the main asset is an HTML file, serve it
95 if (bundler.mainBundle.type === 'html') {
96 req.url = `/${path.basename(bundler.mainBundle.name)}`;
97 serve(req, res, send404);
98 } else {
99 send404();
100 }
101 }
102
103 function send500() {
104 res.setHeader('Content-Type', 'text/plain; charset=utf-8');
105 res.writeHead(500);
106 res.end('🚨 Build error, check the console for details.');
107 }
108
109 function send404() {
110 if (next) {
111 return next();
112 }
113
114 res.writeHead(404);
115 res.end();
116 }
117 };
118}
119
120exports.middleware = middleware;
121exports.serve = serve;
\No newline at end of file