Updated the files.
This commit is contained in:
parent
1553e6b971
commit
753967d4f5
23418 changed files with 3784666 additions and 0 deletions
20
my-app/node_modules/webpack-dev-server/LICENSE
generated
vendored
Executable file
20
my-app/node_modules/webpack-dev-server/LICENSE
generated
vendored
Executable file
|
@ -0,0 +1,20 @@
|
|||
Copyright JS Foundation and other contributors
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining
|
||||
a copy of this software and associated documentation files (the
|
||||
'Software'), to deal in the Software without restriction, including
|
||||
without limitation the rights to use, copy, modify, merge, publish,
|
||||
distribute, sublicense, and/or sell copies of the Software, and to
|
||||
permit persons to whom the Software is furnished to do so, subject to
|
||||
the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be
|
||||
included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
345
my-app/node_modules/webpack-dev-server/README.md
generated
vendored
Executable file
345
my-app/node_modules/webpack-dev-server/README.md
generated
vendored
Executable file
|
@ -0,0 +1,345 @@
|
|||
<div align="center">
|
||||
<a href="https://github.com/webpack/webpack">
|
||||
<img width="200" height="200" src="https://webpack.js.org/assets/icon-square-big.svg">
|
||||
</a>
|
||||
</div>
|
||||
|
||||
[![npm][npm]][npm-url]
|
||||
[![node][node]][node-url]
|
||||
[![tests][tests]][tests-url]
|
||||
[![coverage][cover]][cover-url]
|
||||
[![chat][chat]][chat-url]
|
||||
[![downloads][downloads]][npm-url]
|
||||
[![contributors][contributors]][contributors-url]
|
||||
|
||||
# webpack-dev-server
|
||||
|
||||
Use [webpack](https://webpack.js.org) with a development server that provides
|
||||
live reloading. This should be used for **development only**.
|
||||
|
||||
It uses [webpack-dev-middleware][middleware-url] under the hood, which provides
|
||||
fast in-memory access to the webpack assets.
|
||||
|
||||
## Table of Contents
|
||||
|
||||
- [Getting Started](#getting-started)
|
||||
- [Usage](#usage)
|
||||
- [With the CLI](#with-the-cli)
|
||||
- [With NPM Scripts](#with-npm-scripts)
|
||||
- [With the API](#with-the-api)
|
||||
- [With TypeScript](#with-typescript)
|
||||
- [The Result](#the-result)
|
||||
- [Browser Support](#browser-support)
|
||||
- [Support](#support)
|
||||
- [Contributing](#contributing)
|
||||
- [Attribution](#attribution)
|
||||
- [License](#license)
|
||||
|
||||
## Getting Started
|
||||
|
||||
First things first, install the module:
|
||||
|
||||
```console
|
||||
npm install webpack-dev-server --save-dev
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```console
|
||||
yarn add -D webpack-dev-server
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```console
|
||||
pnpm add -D webpack-dev-server
|
||||
```
|
||||
|
||||
_Note: While you can install and run webpack-dev-server globally, we recommend
|
||||
installing it locally. webpack-dev-server will always use a local installation
|
||||
over a global one._
|
||||
|
||||
## Usage
|
||||
|
||||
There are two main, recommended methods of using the module:
|
||||
|
||||
### With the CLI
|
||||
|
||||
The easiest way to use it is with the [webpack CLI](https://webpack.js.org/api/cli/). In the directory where your
|
||||
`webpack.config.js` is, run:
|
||||
|
||||
```console
|
||||
npx webpack serve
|
||||
```
|
||||
|
||||
Following options are available with `webpack serve`:
|
||||
|
||||
```
|
||||
Usage: webpack serve|server|s [entries...] [options]
|
||||
|
||||
Run the webpack dev server.
|
||||
|
||||
Options:
|
||||
-c, --config <value...> Provide path to a webpack configuration file e.g. ./webpack.config.js.
|
||||
--config-name <value...> Name of the configuration to use.
|
||||
-m, --merge Merge two or more configurations using 'webpack-merge'.
|
||||
--env <value...> Environment passed to the configuration when it is a function.
|
||||
--node-env <value> Sets process.env.NODE_ENV to the specified value.
|
||||
--progress [value] Print compilation progress during build.
|
||||
-j, --json [value] Prints result as JSON or store it in a file.
|
||||
-d, --devtool <value> Determine source maps to use.
|
||||
--no-devtool Do not generate source maps.
|
||||
--entry <value...> The entry point(s) of your application e.g. ./src/main.js.
|
||||
--mode <value> Defines the mode to pass to webpack.
|
||||
--name <value> Name of the configuration. Used when loading multiple configurations.
|
||||
-o, --output-path <value> Output location of the file generated by webpack e.g. ./dist/.
|
||||
--stats [value] It instructs webpack on how to treat the stats e.g. verbose.
|
||||
--no-stats Disable stats output.
|
||||
-t, --target <value...> Sets the build target e.g. node.
|
||||
--no-target Negative 'target' option.
|
||||
--watch-options-stdin Stop watching when stdin stream has ended.
|
||||
--no-watch-options-stdin Do not stop watching when stdin stream has ended.
|
||||
--allowed-hosts <value...> Allows to enumerate the hosts from which access to the dev server are allowed (useful when you are proxying dev server, by default is 'auto').
|
||||
--allowed-hosts-reset Clear all items provided in 'allowedHosts' configuration. Allows to enumerate the hosts from which access to the dev server are allowed (useful when you are proxying dev server, by default is 'auto').
|
||||
--bonjour Allows to broadcasts dev server via ZeroConf networking on start.
|
||||
--no-bonjour Disallows to broadcasts dev server via ZeroConf networking on start.
|
||||
--no-client Disables client script.
|
||||
--client-logging <value> Allows to set log level in the browser.
|
||||
--client-overlay Enables a full-screen overlay in the browser when there are compiler errors or warnings.
|
||||
--no-client-overlay Disables the full-screen overlay in the browser when there are compiler errors or warnings.
|
||||
--client-overlay-errors Enables a full-screen overlay in the browser when there are compiler errors.
|
||||
--no-client-overlay-errors Disables the full-screen overlay in the browser when there are compiler errors.
|
||||
--client-overlay-warnings Enables a full-screen overlay in the browser when there are compiler warnings.
|
||||
--no-client-overlay-warnings Disables the full-screen overlay in the browser when there are compiler warnings.
|
||||
--client-overlay-trusted-types-policy-name <value> The name of a Trusted Types policy for the overlay. Defaults to 'webpack-dev-server#overlay'.
|
||||
--client-progress Prints compilation progress in percentage in the browser.
|
||||
--no-client-progress Does not print compilation progress in percentage in the browser.
|
||||
--client-reconnect [value] Tells dev-server the number of times it should try to reconnect the client.
|
||||
--no-client-reconnect Tells dev-server to not to try to reconnect the client.
|
||||
--client-web-socket-transport <value> Allows to set custom web socket transport to communicate with dev server.
|
||||
--client-web-socket-url <value> Allows to specify URL to web socket server (useful when you're proxying dev server and client script does not always know where to connect to).
|
||||
--client-web-socket-url-hostname <value> Tells clients connected to devServer to use the provided hostname.
|
||||
--client-web-socket-url-pathname <value> Tells clients connected to devServer to use the provided path to connect.
|
||||
--client-web-socket-url-password <value> Tells clients connected to devServer to use the provided password to authenticate.
|
||||
--client-web-socket-url-port <value> Tells clients connected to devServer to use the provided port.
|
||||
--client-web-socket-url-protocol <value> Tells clients connected to devServer to use the provided protocol.
|
||||
--client-web-socket-url-username <value> Tells clients connected to devServer to use the provided username to authenticate.
|
||||
--compress Enables gzip compression for everything served.
|
||||
--no-compress Disables gzip compression for everything served.
|
||||
--history-api-fallback Allows to proxy requests through a specified index page (by default 'index.html'), useful for Single Page Applications that utilise the HTML5 History API.
|
||||
--no-history-api-fallback Disallows to proxy requests through a specified index page.
|
||||
--host <value> Allows to specify a hostname to use.
|
||||
--hot [value] Enables Hot Module Replacement.
|
||||
--no-hot Disables Hot Module Replacement.
|
||||
--http2 Allows to serve over HTTP/2 using SPDY. Deprecated, use the `server` option.
|
||||
--no-http2 Does not serve over HTTP/2 using SPDY.
|
||||
--https Allows to configure the server's listening socket for TLS (by default, dev server will be served over HTTP). Deprecated, use the `server` option.
|
||||
--no-https Disallows to configure the server's listening socket for TLS (by default, dev server will be served over HTTP).
|
||||
--https-passphrase <value> Passphrase for a pfx file. Deprecated, use the `server.options.passphrase` option.
|
||||
--https-request-cert Request for an SSL certificate. Deprecated, use the `server.options.requestCert` option.
|
||||
--no-https-request-cert Does not request for an SSL certificate.
|
||||
--https-ca <value...> Path to an SSL CA certificate or content of an SSL CA certificate. Deprecated, use the `server.options.ca` option.
|
||||
--https-ca-reset Clear all items provided in 'https.ca' configuration. Path to an SSL CA certificate or content of an SSL CA certificate. Deprecated, use the `server.options.ca` option.
|
||||
--https-cacert <value...> Path to an SSL CA certificate or content of an SSL CA certificate. Deprecated, use the `server.options.ca` option.
|
||||
--https-cacert-reset Clear all items provided in 'https.cacert' configuration. Path to an SSL CA certificate or content of an SSL CA certificate. Deprecated, use the `server.options.ca` option.
|
||||
--https-cert <value...> Path to an SSL certificate or content of an SSL certificate. Deprecated, use the `server.options.cert` option.
|
||||
--https-cert-reset Clear all items provided in 'https.cert' configuration. Path to an SSL certificate or content of an SSL certificate. Deprecated, use the `server.options.cert` option.
|
||||
--https-crl <value...> Path to PEM formatted CRLs (Certificate Revocation Lists) or content of PEM formatted CRLs (Certificate Revocation Lists). Deprecated, use the `server.options.crl` option.
|
||||
--https-crl-reset Clear all items provided in 'https.crl' configuration. Path to PEM formatted CRLs (Certificate Revocation Lists) or content of PEM formatted CRLs (Certificate Revocation Lists). Deprecated, use the `server.options.crl` option.
|
||||
--https-key <value...> Path to an SSL key or content of an SSL key. Deprecated, use the `server.options.key` option.
|
||||
--https-key-reset Clear all items provided in 'https.key' configuration. Path to an SSL key or content of an SSL key. Deprecated, use the `server.options.key` option.
|
||||
--https-pfx <value...> Path to an SSL pfx file or content of an SSL pfx file. Deprecated, use the `server.options.pfx` option.
|
||||
--https-pfx-reset Clear all items provided in 'https.pfx' configuration. Path to an SSL pfx file or content of an SSL pfx file. Deprecated, use the `server.options.pfx` option.
|
||||
--ipc [value] Listen to a unix socket.
|
||||
--live-reload Enables reload/refresh the page(s) when file changes are detected (enabled by default).
|
||||
--no-live-reload Disables reload/refresh the page(s) when file changes are detected (enabled by default).
|
||||
--magic-html Tells dev-server whether to enable magic HTML routes (routes corresponding to your webpack output, for example '/main' for 'main.js').
|
||||
--no-magic-html Disables magic HTML routes (routes corresponding to your webpack output, for example '/main' for 'main.js').
|
||||
--open [value...] Allows to configure dev server to open the browser(s) and page(s) after server had been started (set it to true to open your default browser).
|
||||
--no-open Does not open the default browser.
|
||||
--open-target <value...> Opens specified page in browser.
|
||||
--open-app-name <value...> Open specified browser.
|
||||
--open-app <value...> Open specified browser. Deprecated: please use '--open-app-name'.
|
||||
--open-reset Clear all items provided in 'open' configuration. Allows to configure dev server to open the browser(s) and page(s) after server had been started (set it to true to open your default browser).
|
||||
--open-target-reset Clear all items provided in 'open.target' configuration. Opens specified page in browser.
|
||||
--open-app-name-reset Clear all items provided in 'open.app.name' configuration. Open specified browser.
|
||||
--port <value> Allows to specify a port to use.
|
||||
--server-type <value> Allows to set server and options (by default 'http').
|
||||
--server-options-passphrase <value> Passphrase for a pfx file.
|
||||
--server-options-request-cert Request for an SSL certificate.
|
||||
--no-server-options-request-cert Does not request for an SSL certificate.
|
||||
--server-options-ca <value...> Path to an SSL CA certificate or content of an SSL CA certificate.
|
||||
--server-options-ca-reset Clear all items provided in 'server.options.ca' configuration. Path to an SSL CA certificate or content of an SSL CA certificate.
|
||||
--server-options-cacert <value...> Path to an SSL CA certificate or content of an SSL CA certificate. Deprecated, use the `server.options.ca` option.
|
||||
--server-options-cacert-reset Clear all items provided in 'server.options.cacert' configuration. Path to an SSL CA certificate or content of an SSL CA certificate. Deprecated, use the `server.options.ca` option.
|
||||
--server-options-cert <value...> Path to an SSL certificate or content of an SSL certificate.
|
||||
--server-options-cert-reset Clear all items provided in 'server.options.cert' configuration. Path to an SSL certificate or content of an SSL certificate.
|
||||
--server-options-crl <value...> Path to PEM formatted CRLs (Certificate Revocation Lists) or content of PEM formatted CRLs (Certificate Revocation Lists).
|
||||
--server-options-crl-reset Clear all items provided in 'server.options.crl' configuration. Path to PEM formatted CRLs (Certificate Revocation Lists) or content of PEM formatted CRLs (Certificate Revocation Lists).
|
||||
--server-options-key <value...> Path to an SSL key or content of an SSL key.
|
||||
--server-options-key-reset Clear all items provided in 'server.options.key' configuration. Path to an SSL key or content of an SSL key.
|
||||
--server-options-pfx <value...> Path to an SSL pfx file or content of an SSL pfx file.
|
||||
--server-options-pfx-reset Clear all items provided in 'server.options.pfx' configuration. Path to an SSL pfx file or content of an SSL pfx file.
|
||||
--static [value...] Allows to configure options for serving static files from directory (by default 'public' directory).
|
||||
--no-static Disallows to configure options for serving static files from directory.
|
||||
--static-directory <value...> Directory for static contents.
|
||||
--static-public-path <value...> The static files will be available in the browser under this public path.
|
||||
--static-serve-index Tells dev server to use serveIndex middleware when enabled.
|
||||
--no-static-serve-index Does not tell dev server to use serveIndex middleware.
|
||||
--static-watch Watches for files in static content directory.
|
||||
--no-static-watch Does not watch for files in static content directory.
|
||||
--static-reset Clear all items provided in 'static' configuration. Allows to configure options for serving static files from directory (by default 'public' directory).
|
||||
--static-public-path-reset Clear all items provided in 'static.publicPath' configuration. The static files will be available in the browser under this public path.
|
||||
--watch-files <value...> Allows to configure list of globs/directories/files to watch for file changes.
|
||||
--watch-files-reset Clear all items provided in 'watchFiles' configuration. Allows to configure list of globs/directories/files to watch for file changes.
|
||||
--web-socket-server <value> Deprecated: please use '--web-socket-server-type' option. Allows to set web socket server and options (by default 'ws').
|
||||
--no-web-socket-server Disallows to set web socket server and options.
|
||||
--web-socket-server-type <value> Allows to set web socket server and options (by default 'ws').
|
||||
|
||||
Global options:
|
||||
--color Enable colors on console.
|
||||
--no-color Disable colors on console.
|
||||
-v, --version Output the version number of 'webpack', 'webpack-cli' and 'webpack-dev-server' and commands.
|
||||
-h, --help [verbose] Display help for commands and options.
|
||||
|
||||
To see list of all supported commands and options run 'webpack --help=verbose'.
|
||||
|
||||
Webpack documentation: https://webpack.js.org/.
|
||||
CLI documentation: https://webpack.js.org/api/cli/.
|
||||
Made with ♥ by the webpack team.
|
||||
```
|
||||
|
||||
> **Note**
|
||||
>
|
||||
> _Detailed documentation for above options is available on this [link](https://webpack.js.org/configuration/dev-server/)._
|
||||
|
||||
### With NPM Scripts
|
||||
|
||||
NPM package.json scripts are a convenient and useful means to run locally installed
|
||||
binaries without having to be concerned about their full paths. Simply define a
|
||||
script as such:
|
||||
|
||||
```json
|
||||
{
|
||||
"scripts": {
|
||||
"serve": "webpack serve"
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
And run the following in your terminal/console:
|
||||
|
||||
```console
|
||||
npm run serve
|
||||
```
|
||||
|
||||
NPM will automatically refer to the the binary in `node_modules` for you, and
|
||||
execute the file or command.
|
||||
|
||||
### With the API
|
||||
|
||||
While it's recommended to run webpack-dev-server via the CLI, you may also choose to start a server via the API.
|
||||
|
||||
See the related [API documentation for `webpack-dev-server`](https://webpack.js.org/api/webpack-dev-server/).
|
||||
|
||||
### With TypeScript
|
||||
|
||||
If you use TypeScript in the webpack config, you'll need to properly type `devServer` property in order to avoid TS errors (e.g. `'devServer' does not exist in type 'Configuration'`). For that use either:
|
||||
|
||||
```ts
|
||||
/// <reference path="node_modules/webpack-dev-server/types/lib/Server.d.ts"/>
|
||||
import type { Configuration } from "webpack";
|
||||
|
||||
// Your logic
|
||||
```
|
||||
|
||||
Or you can import the type from `webpack-dev-server`, i.e.
|
||||
|
||||
```ts
|
||||
import type { Configuration as DevServerConfiguration } from "webpack-dev-server";
|
||||
import type { Configuration } from "webpack";
|
||||
|
||||
const devServer: DevServerConfiguration = {};
|
||||
const config: Configuration = { devServer };
|
||||
|
||||
// module.exports
|
||||
export default config;
|
||||
```
|
||||
|
||||
### The Result
|
||||
|
||||
Either method will start a server instance and begin listening for connections
|
||||
from `localhost` on port `8080`.
|
||||
|
||||
webpack-dev-server is configured by default to support live-reload of files as
|
||||
you edit your assets while the server is running.
|
||||
|
||||
See [**the documentation**][docs-url] for more use cases and options.
|
||||
|
||||
## Browser Support
|
||||
|
||||
While `webpack-dev-server` transpiles the client (browser) scripts to an ES5
|
||||
state, the project only officially supports the _last two versions of major
|
||||
browsers_. We simply don't have the resources to support every whacky
|
||||
browser out there.
|
||||
|
||||
If you find a bug with an obscure / old browser, we would actively welcome a
|
||||
Pull Request to resolve the bug.
|
||||
|
||||
## Support
|
||||
|
||||
We do our best to keep issues in the repository focused on bugs, features, and
|
||||
needed modifications to the code for the module. Because of that, we ask users
|
||||
with general support, "how-to", or "why isn't this working" questions to try one
|
||||
of the other support channels that are available.
|
||||
|
||||
Your first-stop-shop for support for webpack-dev-server should be the excellent
|
||||
[documentation][docs-url] for the module. If you see an opportunity for improvement
|
||||
of those docs, please head over to the [webpack.js.org repo][wjo-url] and open a
|
||||
pull request.
|
||||
|
||||
From there, we encourage users to visit the [webpack Gitter chat][chat-url] and
|
||||
talk to the fine folks there. If your quest for answers comes up dry in chat,
|
||||
head over to [StackOverflow][stack-url] and do a quick search or open a new
|
||||
question. Remember; It's always much easier to answer questions that include your
|
||||
`webpack.config.js` and relevant files!
|
||||
|
||||
If you're twitter-savvy you can tweet [#webpack][hash-url] with your question
|
||||
and someone should be able to reach out and lend a hand.
|
||||
|
||||
If you have discovered a :bug:, have a feature suggestion, or would like to see
|
||||
a modification, please feel free to create an issue on Github. _Note: The issue
|
||||
template isn't optional, so please be sure not to remove it, and please fill it
|
||||
out completely._
|
||||
|
||||
## Contributing
|
||||
|
||||
We welcome your contributions! Please have a read of [CONTRIBUTING.md](CONTRIBUTING.md) for more information on how to get involved.
|
||||
|
||||
## Attribution
|
||||
|
||||
This project is heavily inspired by [peerigon/nof5](https://github.com/peerigon/nof5).
|
||||
|
||||
## License
|
||||
|
||||
#### [MIT](./LICENSE)
|
||||
|
||||
[npm]: https://img.shields.io/npm/v/webpack-dev-server.svg
|
||||
[npm-url]: https://npmjs.com/package/webpack-dev-server
|
||||
[node]: https://img.shields.io/node/v/webpack-dev-server.svg
|
||||
[node-url]: https://nodejs.org
|
||||
[tests]: https://github.com/webpack/webpack-dev-server/workflows/webpack-dev-server/badge.svg
|
||||
[tests-url]: https://github.com/webpack/webpack-dev-server/actions?query=workflow%3Awebpack-dev-server
|
||||
[cover]: https://codecov.io/gh/webpack/webpack-dev-server/branch/master/graph/badge.svg
|
||||
[cover-url]: https://codecov.io/gh/webpack/webpack-dev-server
|
||||
[chat]: https://badges.gitter.im/webpack/webpack.svg
|
||||
[chat-url]: https://gitter.im/webpack/webpack
|
||||
[docs-url]: https://webpack.js.org/configuration/dev-server/#devserver
|
||||
[hash-url]: https://twitter.com/search?q=webpack
|
||||
[middleware-url]: https://github.com/webpack/webpack-dev-middleware
|
||||
[stack-url]: https://stackoverflow.com/questions/tagged/webpack-dev-server
|
||||
[uglify-url]: https://github.com/webpack-contrib/uglifyjs-webpack-plugin
|
||||
[wjo-url]: https://github.com/webpack/webpack.js.org
|
||||
[downloads]: https://img.shields.io/npm/dm/webpack-dev-server.svg
|
||||
[contributors-url]: https://github.com/webpack/webpack-dev-server/graphs/contributors
|
||||
[contributors]: https://img.shields.io/github/contributors/webpack/webpack-dev-server.svg
|
1294
my-app/node_modules/webpack-dev-server/bin/cli-flags.js
generated
vendored
Executable file
1294
my-app/node_modules/webpack-dev-server/bin/cli-flags.js
generated
vendored
Executable file
File diff suppressed because it is too large
Load diff
412
my-app/node_modules/webpack-dev-server/bin/process-arguments.js
generated
vendored
Executable file
412
my-app/node_modules/webpack-dev-server/bin/process-arguments.js
generated
vendored
Executable file
|
@ -0,0 +1,412 @@
|
|||
"use strict";
|
||||
|
||||
const path = require("path");
|
||||
|
||||
// Based on https://github.com/webpack/webpack/blob/master/lib/cli.js
|
||||
// Please do not modify it
|
||||
|
||||
/** @typedef {"unknown-argument" | "unexpected-non-array-in-path" | "unexpected-non-object-in-path" | "multiple-values-unexpected" | "invalid-value"} ProblemType */
|
||||
|
||||
/**
|
||||
* @typedef {Object} Problem
|
||||
* @property {ProblemType} type
|
||||
* @property {string} path
|
||||
* @property {string} argument
|
||||
* @property {any=} value
|
||||
* @property {number=} index
|
||||
* @property {string=} expected
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} LocalProblem
|
||||
* @property {ProblemType} type
|
||||
* @property {string} path
|
||||
* @property {string=} expected
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} ArgumentConfig
|
||||
* @property {string} description
|
||||
* @property {string} path
|
||||
* @property {boolean} multiple
|
||||
* @property {"enum"|"string"|"path"|"number"|"boolean"|"RegExp"|"reset"} type
|
||||
* @property {any[]=} values
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} Argument
|
||||
* @property {string} description
|
||||
* @property {"string"|"number"|"boolean"} simpleType
|
||||
* @property {boolean} multiple
|
||||
* @property {ArgumentConfig[]} configs
|
||||
*/
|
||||
|
||||
const cliAddedItems = new WeakMap();
|
||||
|
||||
/**
|
||||
* @param {any} config configuration
|
||||
* @param {string} schemaPath path in the config
|
||||
* @param {number | undefined} index index of value when multiple values are provided, otherwise undefined
|
||||
* @returns {{ problem?: LocalProblem, object?: any, property?: string | number, value?: any }} problem or object with property and value
|
||||
*/
|
||||
const getObjectAndProperty = (config, schemaPath, index = 0) => {
|
||||
if (!schemaPath) {
|
||||
return { value: config };
|
||||
}
|
||||
|
||||
const parts = schemaPath.split(".");
|
||||
const property = parts.pop();
|
||||
let current = config;
|
||||
let i = 0;
|
||||
|
||||
for (const part of parts) {
|
||||
const isArray = part.endsWith("[]");
|
||||
const name = isArray ? part.slice(0, -2) : part;
|
||||
let value = current[name];
|
||||
|
||||
if (isArray) {
|
||||
// eslint-disable-next-line no-undefined
|
||||
if (value === undefined) {
|
||||
value = {};
|
||||
current[name] = [...Array.from({ length: index }), value];
|
||||
cliAddedItems.set(current[name], index + 1);
|
||||
} else if (!Array.isArray(value)) {
|
||||
return {
|
||||
problem: {
|
||||
type: "unexpected-non-array-in-path",
|
||||
path: parts.slice(0, i).join("."),
|
||||
},
|
||||
};
|
||||
} else {
|
||||
let addedItems = cliAddedItems.get(value) || 0;
|
||||
|
||||
while (addedItems <= index) {
|
||||
// eslint-disable-next-line no-undefined
|
||||
value.push(undefined);
|
||||
// eslint-disable-next-line no-plusplus
|
||||
addedItems++;
|
||||
}
|
||||
|
||||
cliAddedItems.set(value, addedItems);
|
||||
|
||||
const x = value.length - addedItems + index;
|
||||
|
||||
// eslint-disable-next-line no-undefined
|
||||
if (value[x] === undefined) {
|
||||
value[x] = {};
|
||||
} else if (value[x] === null || typeof value[x] !== "object") {
|
||||
return {
|
||||
problem: {
|
||||
type: "unexpected-non-object-in-path",
|
||||
path: parts.slice(0, i).join("."),
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
value = value[x];
|
||||
}
|
||||
// eslint-disable-next-line no-undefined
|
||||
} else if (value === undefined) {
|
||||
// eslint-disable-next-line no-multi-assign
|
||||
value = current[name] = {};
|
||||
} else if (value === null || typeof value !== "object") {
|
||||
return {
|
||||
problem: {
|
||||
type: "unexpected-non-object-in-path",
|
||||
path: parts.slice(0, i).join("."),
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
current = value;
|
||||
// eslint-disable-next-line no-plusplus
|
||||
i++;
|
||||
}
|
||||
|
||||
const value = current[/** @type {string} */ (property)];
|
||||
|
||||
if (/** @type {string} */ (property).endsWith("[]")) {
|
||||
const name = /** @type {string} */ (property).slice(0, -2);
|
||||
// eslint-disable-next-line no-shadow
|
||||
const value = current[name];
|
||||
|
||||
// eslint-disable-next-line no-undefined
|
||||
if (value === undefined) {
|
||||
// eslint-disable-next-line no-undefined
|
||||
current[name] = [...Array.from({ length: index }), undefined];
|
||||
cliAddedItems.set(current[name], index + 1);
|
||||
|
||||
// eslint-disable-next-line no-undefined
|
||||
return { object: current[name], property: index, value: undefined };
|
||||
} else if (!Array.isArray(value)) {
|
||||
// eslint-disable-next-line no-undefined
|
||||
current[name] = [value, ...Array.from({ length: index }), undefined];
|
||||
cliAddedItems.set(current[name], index + 1);
|
||||
|
||||
// eslint-disable-next-line no-undefined
|
||||
return { object: current[name], property: index + 1, value: undefined };
|
||||
}
|
||||
|
||||
let addedItems = cliAddedItems.get(value) || 0;
|
||||
|
||||
while (addedItems <= index) {
|
||||
// eslint-disable-next-line no-undefined
|
||||
value.push(undefined);
|
||||
// eslint-disable-next-line no-plusplus
|
||||
addedItems++;
|
||||
}
|
||||
|
||||
cliAddedItems.set(value, addedItems);
|
||||
|
||||
const x = value.length - addedItems + index;
|
||||
|
||||
// eslint-disable-next-line no-undefined
|
||||
if (value[x] === undefined) {
|
||||
value[x] = {};
|
||||
} else if (value[x] === null || typeof value[x] !== "object") {
|
||||
return {
|
||||
problem: {
|
||||
type: "unexpected-non-object-in-path",
|
||||
path: schemaPath,
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
return {
|
||||
object: value,
|
||||
property: x,
|
||||
value: value[x],
|
||||
};
|
||||
}
|
||||
|
||||
return { object: current, property, value };
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {ArgumentConfig} argConfig processing instructions
|
||||
* @param {any} value the value
|
||||
* @returns {any | undefined} parsed value
|
||||
*/
|
||||
const parseValueForArgumentConfig = (argConfig, value) => {
|
||||
// eslint-disable-next-line default-case
|
||||
switch (argConfig.type) {
|
||||
case "string":
|
||||
if (typeof value === "string") {
|
||||
return value;
|
||||
}
|
||||
break;
|
||||
case "path":
|
||||
if (typeof value === "string") {
|
||||
return path.resolve(value);
|
||||
}
|
||||
break;
|
||||
case "number":
|
||||
if (typeof value === "number") {
|
||||
return value;
|
||||
}
|
||||
|
||||
if (typeof value === "string" && /^[+-]?\d*(\.\d*)[eE]\d+$/) {
|
||||
const n = +value;
|
||||
if (!isNaN(n)) return n;
|
||||
}
|
||||
|
||||
break;
|
||||
case "boolean":
|
||||
if (typeof value === "boolean") {
|
||||
return value;
|
||||
}
|
||||
|
||||
if (value === "true") {
|
||||
return true;
|
||||
}
|
||||
|
||||
if (value === "false") {
|
||||
return false;
|
||||
}
|
||||
|
||||
break;
|
||||
case "RegExp":
|
||||
if (value instanceof RegExp) {
|
||||
return value;
|
||||
}
|
||||
|
||||
if (typeof value === "string") {
|
||||
// cspell:word yugi
|
||||
const match = /^\/(.*)\/([yugi]*)$/.exec(value);
|
||||
|
||||
if (match && !/[^\\]\//.test(match[1])) {
|
||||
return new RegExp(match[1], match[2]);
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
case "enum":
|
||||
if (/** @type {any[]} */ (argConfig.values).includes(value)) {
|
||||
return value;
|
||||
}
|
||||
|
||||
for (const item of /** @type {any[]} */ (argConfig.values)) {
|
||||
if (`${item}` === value) return item;
|
||||
}
|
||||
|
||||
break;
|
||||
case "reset":
|
||||
if (value === true) {
|
||||
return [];
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {ArgumentConfig} argConfig processing instructions
|
||||
* @returns {string | undefined} expected message
|
||||
*/
|
||||
const getExpectedValue = (argConfig) => {
|
||||
switch (argConfig.type) {
|
||||
default:
|
||||
return argConfig.type;
|
||||
case "boolean":
|
||||
return "true | false";
|
||||
case "RegExp":
|
||||
return "regular expression (example: /ab?c*/)";
|
||||
case "enum":
|
||||
return /** @type {any[]} */ (argConfig.values)
|
||||
.map((v) => `${v}`)
|
||||
.join(" | ");
|
||||
case "reset":
|
||||
return "true (will reset the previous value to an empty array)";
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {any} config configuration
|
||||
* @param {string} schemaPath path in the config
|
||||
* @param {any} value parsed value
|
||||
* @param {number | undefined} index index of value when multiple values are provided, otherwise undefined
|
||||
* @returns {LocalProblem | null} problem or null for success
|
||||
*/
|
||||
const setValue = (config, schemaPath, value, index) => {
|
||||
const { problem, object, property } = getObjectAndProperty(
|
||||
config,
|
||||
schemaPath,
|
||||
index
|
||||
);
|
||||
|
||||
if (problem) {
|
||||
return problem;
|
||||
}
|
||||
|
||||
object[/** @type {string} */ (property)] = value;
|
||||
|
||||
return null;
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {ArgumentConfig} argConfig processing instructions
|
||||
* @param {any} config configuration
|
||||
* @param {any} value the value
|
||||
* @param {number | undefined} index the index if multiple values provided
|
||||
* @returns {LocalProblem | null} a problem if any
|
||||
*/
|
||||
const processArgumentConfig = (argConfig, config, value, index) => {
|
||||
// eslint-disable-next-line no-undefined
|
||||
if (index !== undefined && !argConfig.multiple) {
|
||||
return {
|
||||
type: "multiple-values-unexpected",
|
||||
path: argConfig.path,
|
||||
};
|
||||
}
|
||||
|
||||
const parsed = parseValueForArgumentConfig(argConfig, value);
|
||||
|
||||
// eslint-disable-next-line no-undefined
|
||||
if (parsed === undefined) {
|
||||
return {
|
||||
type: "invalid-value",
|
||||
path: argConfig.path,
|
||||
expected: getExpectedValue(argConfig),
|
||||
};
|
||||
}
|
||||
|
||||
const problem = setValue(config, argConfig.path, parsed, index);
|
||||
|
||||
if (problem) {
|
||||
return problem;
|
||||
}
|
||||
|
||||
return null;
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {Record<string, Argument>} args object of arguments
|
||||
* @param {any} config configuration
|
||||
* @param {Record<string, string | number | boolean | RegExp | (string | number | boolean | RegExp)[]>} values object with values
|
||||
* @returns {Problem[] | null} problems or null for success
|
||||
*/
|
||||
const processArguments = (args, config, values) => {
|
||||
/**
|
||||
* @type {Problem[]}
|
||||
*/
|
||||
const problems = [];
|
||||
|
||||
for (const key of Object.keys(values)) {
|
||||
const arg = args[key];
|
||||
|
||||
if (!arg) {
|
||||
problems.push({
|
||||
type: "unknown-argument",
|
||||
path: "",
|
||||
argument: key,
|
||||
});
|
||||
|
||||
// eslint-disable-next-line no-continue
|
||||
continue;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {any} value
|
||||
* @param {number | undefined} i
|
||||
*/
|
||||
const processValue = (value, i) => {
|
||||
const currentProblems = [];
|
||||
|
||||
for (const argConfig of arg.configs) {
|
||||
const problem = processArgumentConfig(argConfig, config, value, i);
|
||||
|
||||
if (!problem) {
|
||||
return;
|
||||
}
|
||||
|
||||
currentProblems.push({
|
||||
...problem,
|
||||
argument: key,
|
||||
value,
|
||||
index: i,
|
||||
});
|
||||
}
|
||||
|
||||
problems.push(...currentProblems);
|
||||
};
|
||||
|
||||
const value = values[key];
|
||||
|
||||
if (Array.isArray(value)) {
|
||||
for (let i = 0; i < value.length; i++) {
|
||||
processValue(value[i], i);
|
||||
}
|
||||
} else {
|
||||
// eslint-disable-next-line no-undefined
|
||||
processValue(value, undefined);
|
||||
}
|
||||
}
|
||||
|
||||
if (problems.length === 0) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return problems;
|
||||
};
|
||||
|
||||
module.exports = processArguments;
|
199
my-app/node_modules/webpack-dev-server/bin/webpack-dev-server.js
generated
vendored
Executable file
199
my-app/node_modules/webpack-dev-server/bin/webpack-dev-server.js
generated
vendored
Executable file
|
@ -0,0 +1,199 @@
|
|||
#!/usr/bin/env node
|
||||
/* Based on webpack/bin/webpack.js */
|
||||
/* eslint-disable no-console */
|
||||
|
||||
"use strict";
|
||||
|
||||
/**
|
||||
* @param {string} command process to run
|
||||
* @param {string[]} args command line arguments
|
||||
* @returns {Promise<void>} promise
|
||||
*/
|
||||
const runCommand = (command, args) => {
|
||||
const cp = require("child_process");
|
||||
return new Promise((resolve, reject) => {
|
||||
const executedCommand = cp.spawn(command, args, {
|
||||
stdio: "inherit",
|
||||
shell: true,
|
||||
});
|
||||
|
||||
executedCommand.on("error", (error) => {
|
||||
reject(error);
|
||||
});
|
||||
|
||||
executedCommand.on("exit", (code) => {
|
||||
if (code === 0) {
|
||||
resolve();
|
||||
} else {
|
||||
reject();
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {string} packageName name of the package
|
||||
* @returns {boolean} is the package installed?
|
||||
*/
|
||||
const isInstalled = (packageName) => {
|
||||
if (process.versions.pnp) {
|
||||
return true;
|
||||
}
|
||||
|
||||
const path = require("path");
|
||||
const fs = require("graceful-fs");
|
||||
|
||||
let dir = __dirname;
|
||||
|
||||
do {
|
||||
try {
|
||||
if (
|
||||
fs.statSync(path.join(dir, "node_modules", packageName)).isDirectory()
|
||||
) {
|
||||
return true;
|
||||
}
|
||||
} catch (_error) {
|
||||
// Nothing
|
||||
}
|
||||
// eslint-disable-next-line no-cond-assign
|
||||
} while (dir !== (dir = path.dirname(dir)));
|
||||
|
||||
// https://github.com/nodejs/node/blob/v18.9.1/lib/internal/modules/cjs/loader.js#L1274
|
||||
// @ts-ignore
|
||||
for (const internalPath of require("module").globalPaths) {
|
||||
try {
|
||||
if (fs.statSync(path.join(internalPath, packageName)).isDirectory()) {
|
||||
return true;
|
||||
}
|
||||
} catch (_error) {
|
||||
// Nothing
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {CliOption} cli options
|
||||
* @returns {void}
|
||||
*/
|
||||
const runCli = (cli) => {
|
||||
if (cli.preprocess) {
|
||||
cli.preprocess();
|
||||
}
|
||||
const path = require("path");
|
||||
const pkgPath = require.resolve(`${cli.package}/package.json`);
|
||||
// eslint-disable-next-line import/no-dynamic-require
|
||||
const pkg = require(pkgPath);
|
||||
|
||||
if (pkg.type === "module" || /\.mjs/i.test(pkg.bin[cli.binName])) {
|
||||
import(path.resolve(path.dirname(pkgPath), pkg.bin[cli.binName])).catch(
|
||||
(error) => {
|
||||
console.error(error);
|
||||
process.exitCode = 1;
|
||||
}
|
||||
);
|
||||
} else {
|
||||
// eslint-disable-next-line import/no-dynamic-require
|
||||
require(path.resolve(path.dirname(pkgPath), pkg.bin[cli.binName]));
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* @typedef {Object} CliOption
|
||||
* @property {string} name display name
|
||||
* @property {string} package npm package name
|
||||
* @property {string} binName name of the executable file
|
||||
* @property {boolean} installed currently installed?
|
||||
* @property {string} url homepage
|
||||
* @property {function} preprocess preprocessor
|
||||
*/
|
||||
|
||||
/** @type {CliOption} */
|
||||
const cli = {
|
||||
name: "webpack-cli",
|
||||
package: "webpack-cli",
|
||||
binName: "webpack-cli",
|
||||
installed: isInstalled("webpack-cli"),
|
||||
url: "https://github.com/webpack/webpack-cli",
|
||||
preprocess() {
|
||||
process.argv.splice(2, 0, "serve");
|
||||
},
|
||||
};
|
||||
|
||||
if (!cli.installed) {
|
||||
const path = require("path");
|
||||
const fs = require("graceful-fs");
|
||||
const readLine = require("readline");
|
||||
|
||||
const notify = `CLI for webpack must be installed.\n ${cli.name} (${cli.url})\n`;
|
||||
|
||||
console.error(notify);
|
||||
|
||||
/**
|
||||
* @type {string}
|
||||
*/
|
||||
let packageManager;
|
||||
|
||||
if (fs.existsSync(path.resolve(process.cwd(), "yarn.lock"))) {
|
||||
packageManager = "yarn";
|
||||
} else if (fs.existsSync(path.resolve(process.cwd(), "pnpm-lock.yaml"))) {
|
||||
packageManager = "pnpm";
|
||||
} else {
|
||||
packageManager = "npm";
|
||||
}
|
||||
|
||||
const installOptions = [packageManager === "yarn" ? "add" : "install", "-D"];
|
||||
|
||||
console.error(
|
||||
`We will use "${packageManager}" to install the CLI via "${packageManager} ${installOptions.join(
|
||||
" "
|
||||
)} ${cli.package}".`
|
||||
);
|
||||
|
||||
const question = `Do you want to install 'webpack-cli' (yes/no): `;
|
||||
|
||||
const questionInterface = readLine.createInterface({
|
||||
input: process.stdin,
|
||||
output: process.stderr,
|
||||
});
|
||||
|
||||
// In certain scenarios (e.g. when STDIN is not in terminal mode), the callback function will not be
|
||||
// executed. Setting the exit code here to ensure the script exits correctly in those cases. The callback
|
||||
// function is responsible for clearing the exit code if the user wishes to install webpack-cli.
|
||||
process.exitCode = 1;
|
||||
questionInterface.question(question, (answer) => {
|
||||
questionInterface.close();
|
||||
|
||||
const normalizedAnswer = answer.toLowerCase().startsWith("y");
|
||||
|
||||
if (!normalizedAnswer) {
|
||||
console.error(
|
||||
"You need to install 'webpack-cli' to use webpack via CLI.\n" +
|
||||
"You can also install the CLI manually."
|
||||
);
|
||||
|
||||
return;
|
||||
}
|
||||
process.exitCode = 0;
|
||||
|
||||
console.log(
|
||||
`Installing '${
|
||||
cli.package
|
||||
}' (running '${packageManager} ${installOptions.join(" ")} ${
|
||||
cli.package
|
||||
}')...`
|
||||
);
|
||||
|
||||
runCommand(packageManager, installOptions.concat(cli.package))
|
||||
.then(() => {
|
||||
runCli(cli);
|
||||
})
|
||||
.catch((error) => {
|
||||
console.error(error);
|
||||
process.exitCode = 1;
|
||||
});
|
||||
});
|
||||
} else {
|
||||
runCli(cli);
|
||||
}
|
61
my-app/node_modules/webpack-dev-server/client/clients/SockJSClient.js
generated
vendored
Executable file
61
my-app/node_modules/webpack-dev-server/client/clients/SockJSClient.js
generated
vendored
Executable file
|
@ -0,0 +1,61 @@
|
|||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
|
||||
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
||||
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
||||
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
||||
import SockJS from "../modules/sockjs-client/index.js";
|
||||
import { log } from "../utils/log.js";
|
||||
var SockJSClient = /*#__PURE__*/function () {
|
||||
/**
|
||||
* @param {string} url
|
||||
*/
|
||||
function SockJSClient(url) {
|
||||
_classCallCheck(this, SockJSClient);
|
||||
// SockJS requires `http` and `https` protocols
|
||||
this.sock = new SockJS(url.replace(/^ws:/i, "http:").replace(/^wss:/i, "https:"));
|
||||
this.sock.onerror =
|
||||
/**
|
||||
* @param {Error} error
|
||||
*/
|
||||
function (error) {
|
||||
log.error(error);
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {(...args: any[]) => void} f
|
||||
*/
|
||||
_createClass(SockJSClient, [{
|
||||
key: "onOpen",
|
||||
value: function onOpen(f) {
|
||||
this.sock.onopen = f;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {(...args: any[]) => void} f
|
||||
*/
|
||||
}, {
|
||||
key: "onClose",
|
||||
value: function onClose(f) {
|
||||
this.sock.onclose = f;
|
||||
}
|
||||
|
||||
// call f with the message string as the first argument
|
||||
/**
|
||||
* @param {(...args: any[]) => void} f
|
||||
*/
|
||||
}, {
|
||||
key: "onMessage",
|
||||
value: function onMessage(f) {
|
||||
this.sock.onmessage =
|
||||
/**
|
||||
* @param {Error & { data: string }} e
|
||||
*/
|
||||
function (e) {
|
||||
f(e.data);
|
||||
};
|
||||
}
|
||||
}]);
|
||||
return SockJSClient;
|
||||
}();
|
||||
export { SockJSClient as default };
|
51
my-app/node_modules/webpack-dev-server/client/clients/WebSocketClient.js
generated
vendored
Executable file
51
my-app/node_modules/webpack-dev-server/client/clients/WebSocketClient.js
generated
vendored
Executable file
|
@ -0,0 +1,51 @@
|
|||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
|
||||
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
||||
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
||||
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
||||
import { log } from "../utils/log.js";
|
||||
var WebSocketClient = /*#__PURE__*/function () {
|
||||
/**
|
||||
* @param {string} url
|
||||
*/
|
||||
function WebSocketClient(url) {
|
||||
_classCallCheck(this, WebSocketClient);
|
||||
this.client = new WebSocket(url);
|
||||
this.client.onerror = function (error) {
|
||||
log.error(error);
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {(...args: any[]) => void} f
|
||||
*/
|
||||
_createClass(WebSocketClient, [{
|
||||
key: "onOpen",
|
||||
value: function onOpen(f) {
|
||||
this.client.onopen = f;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {(...args: any[]) => void} f
|
||||
*/
|
||||
}, {
|
||||
key: "onClose",
|
||||
value: function onClose(f) {
|
||||
this.client.onclose = f;
|
||||
}
|
||||
|
||||
// call f with the message string as the first argument
|
||||
/**
|
||||
* @param {(...args: any[]) => void} f
|
||||
*/
|
||||
}, {
|
||||
key: "onMessage",
|
||||
value: function onMessage(f) {
|
||||
this.client.onmessage = function (e) {
|
||||
f(e.data);
|
||||
};
|
||||
}
|
||||
}]);
|
||||
return WebSocketClient;
|
||||
}();
|
||||
export { WebSocketClient as default };
|
320
my-app/node_modules/webpack-dev-server/client/index.js
generated
vendored
Executable file
320
my-app/node_modules/webpack-dev-server/client/index.js
generated
vendored
Executable file
|
@ -0,0 +1,320 @@
|
|||
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
||||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
||||
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
||||
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
||||
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
||||
/* global __resourceQuery, __webpack_hash__ */
|
||||
/// <reference types="webpack/module" />
|
||||
import webpackHotLog from "webpack/hot/log.js";
|
||||
import stripAnsi from "./utils/stripAnsi.js";
|
||||
import parseURL from "./utils/parseURL.js";
|
||||
import socket from "./socket.js";
|
||||
import { formatProblem, createOverlay } from "./overlay.js";
|
||||
import { log, logEnabledFeatures, setLogLevel } from "./utils/log.js";
|
||||
import sendMessage from "./utils/sendMessage.js";
|
||||
import reloadApp from "./utils/reloadApp.js";
|
||||
import createSocketURL from "./utils/createSocketURL.js";
|
||||
|
||||
/**
|
||||
* @typedef {Object} OverlayOptions
|
||||
* @property {boolean | (error: Error) => boolean} [warnings]
|
||||
* @property {boolean | (error: Error) => boolean} [errors]
|
||||
* @property {boolean | (error: Error) => boolean} [runtimeErrors]
|
||||
* @property {string} [trustedTypesPolicyName]
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} Options
|
||||
* @property {boolean} hot
|
||||
* @property {boolean} liveReload
|
||||
* @property {boolean} progress
|
||||
* @property {boolean | OverlayOptions} overlay
|
||||
* @property {string} [logging]
|
||||
* @property {number} [reconnect]
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} Status
|
||||
* @property {boolean} isUnloading
|
||||
* @property {string} currentHash
|
||||
* @property {string} [previousHash]
|
||||
*/
|
||||
|
||||
/**
|
||||
* @param {boolean | { warnings?: boolean | string; errors?: boolean | string; runtimeErrors?: boolean | string; }} overlayOptions
|
||||
*/
|
||||
var decodeOverlayOptions = function decodeOverlayOptions(overlayOptions) {
|
||||
if (typeof overlayOptions === "object") {
|
||||
["warnings", "errors", "runtimeErrors"].forEach(function (property) {
|
||||
if (typeof overlayOptions[property] === "string") {
|
||||
var overlayFilterFunctionString = decodeURIComponent(overlayOptions[property]);
|
||||
|
||||
// eslint-disable-next-line no-new-func
|
||||
var overlayFilterFunction = new Function("message", "var callback = ".concat(overlayFilterFunctionString, "\n return callback(message)"));
|
||||
overlayOptions[property] = overlayFilterFunction;
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* @type {Status}
|
||||
*/
|
||||
var status = {
|
||||
isUnloading: false,
|
||||
// TODO Workaround for webpack v4, `__webpack_hash__` is not replaced without HotModuleReplacement
|
||||
// eslint-disable-next-line camelcase
|
||||
currentHash: typeof __webpack_hash__ !== "undefined" ? __webpack_hash__ : ""
|
||||
};
|
||||
|
||||
/** @type {Options} */
|
||||
var options = {
|
||||
hot: false,
|
||||
liveReload: false,
|
||||
progress: false,
|
||||
overlay: false
|
||||
};
|
||||
var parsedResourceQuery = parseURL(__resourceQuery);
|
||||
var enabledFeatures = {
|
||||
"Hot Module Replacement": false,
|
||||
"Live Reloading": false,
|
||||
Progress: false,
|
||||
Overlay: false
|
||||
};
|
||||
if (parsedResourceQuery.hot === "true") {
|
||||
options.hot = true;
|
||||
enabledFeatures["Hot Module Replacement"] = true;
|
||||
}
|
||||
if (parsedResourceQuery["live-reload"] === "true") {
|
||||
options.liveReload = true;
|
||||
enabledFeatures["Live Reloading"] = true;
|
||||
}
|
||||
if (parsedResourceQuery.progress === "true") {
|
||||
options.progress = true;
|
||||
enabledFeatures.Progress = true;
|
||||
}
|
||||
if (parsedResourceQuery.overlay) {
|
||||
try {
|
||||
options.overlay = JSON.parse(parsedResourceQuery.overlay);
|
||||
} catch (e) {
|
||||
log.error("Error parsing overlay options from resource query:", e);
|
||||
}
|
||||
|
||||
// Fill in default "true" params for partially-specified objects.
|
||||
if (typeof options.overlay === "object") {
|
||||
options.overlay = _objectSpread({
|
||||
errors: true,
|
||||
warnings: true,
|
||||
runtimeErrors: true
|
||||
}, options.overlay);
|
||||
decodeOverlayOptions(options.overlay);
|
||||
}
|
||||
enabledFeatures.Overlay = true;
|
||||
}
|
||||
if (parsedResourceQuery.logging) {
|
||||
options.logging = parsedResourceQuery.logging;
|
||||
}
|
||||
if (typeof parsedResourceQuery.reconnect !== "undefined") {
|
||||
options.reconnect = Number(parsedResourceQuery.reconnect);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} level
|
||||
*/
|
||||
function setAllLogLevel(level) {
|
||||
// This is needed because the HMR logger operate separately from dev server logger
|
||||
webpackHotLog.setLogLevel(level === "verbose" || level === "log" ? "info" : level);
|
||||
setLogLevel(level);
|
||||
}
|
||||
if (options.logging) {
|
||||
setAllLogLevel(options.logging);
|
||||
}
|
||||
logEnabledFeatures(enabledFeatures);
|
||||
self.addEventListener("beforeunload", function () {
|
||||
status.isUnloading = true;
|
||||
});
|
||||
var overlay = typeof window !== "undefined" ? createOverlay(typeof options.overlay === "object" ? {
|
||||
trustedTypesPolicyName: options.overlay.trustedTypesPolicyName,
|
||||
catchRuntimeError: options.overlay.runtimeErrors
|
||||
} : {
|
||||
trustedTypesPolicyName: false,
|
||||
catchRuntimeError: options.overlay
|
||||
}) : {
|
||||
send: function send() {}
|
||||
};
|
||||
var onSocketMessage = {
|
||||
hot: function hot() {
|
||||
if (parsedResourceQuery.hot === "false") {
|
||||
return;
|
||||
}
|
||||
options.hot = true;
|
||||
},
|
||||
liveReload: function liveReload() {
|
||||
if (parsedResourceQuery["live-reload"] === "false") {
|
||||
return;
|
||||
}
|
||||
options.liveReload = true;
|
||||
},
|
||||
invalid: function invalid() {
|
||||
log.info("App updated. Recompiling...");
|
||||
|
||||
// Fixes #1042. overlay doesn't clear if errors are fixed but warnings remain.
|
||||
if (options.overlay) {
|
||||
overlay.send({
|
||||
type: "DISMISS"
|
||||
});
|
||||
}
|
||||
sendMessage("Invalid");
|
||||
},
|
||||
/**
|
||||
* @param {string} hash
|
||||
*/
|
||||
hash: function hash(_hash) {
|
||||
status.previousHash = status.currentHash;
|
||||
status.currentHash = _hash;
|
||||
},
|
||||
logging: setAllLogLevel,
|
||||
/**
|
||||
* @param {boolean} value
|
||||
*/
|
||||
overlay: function overlay(value) {
|
||||
if (typeof document === "undefined") {
|
||||
return;
|
||||
}
|
||||
options.overlay = value;
|
||||
decodeOverlayOptions(options.overlay);
|
||||
},
|
||||
/**
|
||||
* @param {number} value
|
||||
*/
|
||||
reconnect: function reconnect(value) {
|
||||
if (parsedResourceQuery.reconnect === "false") {
|
||||
return;
|
||||
}
|
||||
options.reconnect = value;
|
||||
},
|
||||
/**
|
||||
* @param {boolean} value
|
||||
*/
|
||||
progress: function progress(value) {
|
||||
options.progress = value;
|
||||
},
|
||||
/**
|
||||
* @param {{ pluginName?: string, percent: number, msg: string }} data
|
||||
*/
|
||||
"progress-update": function progressUpdate(data) {
|
||||
if (options.progress) {
|
||||
log.info("".concat(data.pluginName ? "[".concat(data.pluginName, "] ") : "").concat(data.percent, "% - ").concat(data.msg, "."));
|
||||
}
|
||||
sendMessage("Progress", data);
|
||||
},
|
||||
"still-ok": function stillOk() {
|
||||
log.info("Nothing changed.");
|
||||
if (options.overlay) {
|
||||
overlay.send({
|
||||
type: "DISMISS"
|
||||
});
|
||||
}
|
||||
sendMessage("StillOk");
|
||||
},
|
||||
ok: function ok() {
|
||||
sendMessage("Ok");
|
||||
if (options.overlay) {
|
||||
overlay.send({
|
||||
type: "DISMISS"
|
||||
});
|
||||
}
|
||||
reloadApp(options, status);
|
||||
},
|
||||
// TODO: remove in v5 in favor of 'static-changed'
|
||||
/**
|
||||
* @param {string} file
|
||||
*/
|
||||
"content-changed": function contentChanged(file) {
|
||||
log.info("".concat(file ? "\"".concat(file, "\"") : "Content", " from static directory was changed. Reloading..."));
|
||||
self.location.reload();
|
||||
},
|
||||
/**
|
||||
* @param {string} file
|
||||
*/
|
||||
"static-changed": function staticChanged(file) {
|
||||
log.info("".concat(file ? "\"".concat(file, "\"") : "Content", " from static directory was changed. Reloading..."));
|
||||
self.location.reload();
|
||||
},
|
||||
/**
|
||||
* @param {Error[]} warnings
|
||||
* @param {any} params
|
||||
*/
|
||||
warnings: function warnings(_warnings, params) {
|
||||
log.warn("Warnings while compiling.");
|
||||
var printableWarnings = _warnings.map(function (error) {
|
||||
var _formatProblem = formatProblem("warning", error),
|
||||
header = _formatProblem.header,
|
||||
body = _formatProblem.body;
|
||||
return "".concat(header, "\n").concat(stripAnsi(body));
|
||||
});
|
||||
sendMessage("Warnings", printableWarnings);
|
||||
for (var i = 0; i < printableWarnings.length; i++) {
|
||||
log.warn(printableWarnings[i]);
|
||||
}
|
||||
var overlayWarningsSetting = typeof options.overlay === "boolean" ? options.overlay : options.overlay && options.overlay.warnings;
|
||||
if (overlayWarningsSetting) {
|
||||
var warningsToDisplay = typeof overlayWarningsSetting === "function" ? _warnings.filter(overlayWarningsSetting) : _warnings;
|
||||
if (warningsToDisplay.length) {
|
||||
overlay.send({
|
||||
type: "BUILD_ERROR",
|
||||
level: "warning",
|
||||
messages: _warnings
|
||||
});
|
||||
}
|
||||
}
|
||||
if (params && params.preventReloading) {
|
||||
return;
|
||||
}
|
||||
reloadApp(options, status);
|
||||
},
|
||||
/**
|
||||
* @param {Error[]} errors
|
||||
*/
|
||||
errors: function errors(_errors) {
|
||||
log.error("Errors while compiling. Reload prevented.");
|
||||
var printableErrors = _errors.map(function (error) {
|
||||
var _formatProblem2 = formatProblem("error", error),
|
||||
header = _formatProblem2.header,
|
||||
body = _formatProblem2.body;
|
||||
return "".concat(header, "\n").concat(stripAnsi(body));
|
||||
});
|
||||
sendMessage("Errors", printableErrors);
|
||||
for (var i = 0; i < printableErrors.length; i++) {
|
||||
log.error(printableErrors[i]);
|
||||
}
|
||||
var overlayErrorsSettings = typeof options.overlay === "boolean" ? options.overlay : options.overlay && options.overlay.errors;
|
||||
if (overlayErrorsSettings) {
|
||||
var errorsToDisplay = typeof overlayErrorsSettings === "function" ? _errors.filter(overlayErrorsSettings) : _errors;
|
||||
if (errorsToDisplay.length) {
|
||||
overlay.send({
|
||||
type: "BUILD_ERROR",
|
||||
level: "error",
|
||||
messages: _errors
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
/**
|
||||
* @param {Error} error
|
||||
*/
|
||||
error: function error(_error) {
|
||||
log.error(_error);
|
||||
},
|
||||
close: function close() {
|
||||
log.info("Disconnected!");
|
||||
if (options.overlay) {
|
||||
overlay.send({
|
||||
type: "DISMISS"
|
||||
});
|
||||
}
|
||||
sendMessage("Close");
|
||||
}
|
||||
};
|
||||
var socketURL = createSocketURL(parsedResourceQuery);
|
||||
socket(socketURL, onSocketMessage, options.reconnect);
|
728
my-app/node_modules/webpack-dev-server/client/modules/logger/index.js
generated
vendored
Executable file
728
my-app/node_modules/webpack-dev-server/client/modules/logger/index.js
generated
vendored
Executable file
|
@ -0,0 +1,728 @@
|
|||
/******/ (function() { // webpackBootstrap
|
||||
/******/ "use strict";
|
||||
/******/ var __webpack_modules__ = ({
|
||||
|
||||
/***/ "./client-src/modules/logger/SyncBailHookFake.js":
|
||||
/*!*******************************************************!*\
|
||||
!*** ./client-src/modules/logger/SyncBailHookFake.js ***!
|
||||
\*******************************************************/
|
||||
/***/ (function(module) {
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Client stub for tapable SyncBailHook
|
||||
*/
|
||||
module.exports = function clientTapableSyncBailHook() {
|
||||
return {
|
||||
call: function call() {}
|
||||
};
|
||||
};
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "./node_modules/webpack/lib/logging/Logger.js":
|
||||
/*!****************************************************!*\
|
||||
!*** ./node_modules/webpack/lib/logging/Logger.js ***!
|
||||
\****************************************************/
|
||||
/***/ (function(__unused_webpack_module, exports) {
|
||||
|
||||
/*
|
||||
MIT License http://www.opensource.org/licenses/mit-license.php
|
||||
Author Tobias Koppers @sokra
|
||||
*/
|
||||
|
||||
|
||||
|
||||
function _toConsumableArray(arr) {
|
||||
return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
|
||||
}
|
||||
function _nonIterableSpread() {
|
||||
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
||||
}
|
||||
function _unsupportedIterableToArray(o, minLen) {
|
||||
if (!o) return;
|
||||
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
|
||||
var n = Object.prototype.toString.call(o).slice(8, -1);
|
||||
if (n === "Object" && o.constructor) n = o.constructor.name;
|
||||
if (n === "Map" || n === "Set") return Array.from(o);
|
||||
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
|
||||
}
|
||||
function _iterableToArray(iter) {
|
||||
if (typeof (typeof Symbol !== "undefined" ? Symbol : function (i) { return i; }) !== "undefined" && iter[(typeof Symbol !== "undefined" ? Symbol : function (i) { return i; }).iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
|
||||
}
|
||||
function _arrayWithoutHoles(arr) {
|
||||
if (Array.isArray(arr)) return _arrayLikeToArray(arr);
|
||||
}
|
||||
function _arrayLikeToArray(arr, len) {
|
||||
if (len == null || len > arr.length) len = arr.length;
|
||||
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
|
||||
return arr2;
|
||||
}
|
||||
function _classCallCheck(instance, Constructor) {
|
||||
if (!(instance instanceof Constructor)) {
|
||||
throw new TypeError("Cannot call a class as a function");
|
||||
}
|
||||
}
|
||||
function _defineProperties(target, props) {
|
||||
for (var i = 0; i < props.length; i++) {
|
||||
var descriptor = props[i];
|
||||
descriptor.enumerable = descriptor.enumerable || false;
|
||||
descriptor.configurable = true;
|
||||
if ("value" in descriptor) descriptor.writable = true;
|
||||
Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);
|
||||
}
|
||||
}
|
||||
function _createClass(Constructor, protoProps, staticProps) {
|
||||
if (protoProps) _defineProperties(Constructor.prototype, protoProps);
|
||||
if (staticProps) _defineProperties(Constructor, staticProps);
|
||||
Object.defineProperty(Constructor, "prototype", {
|
||||
writable: false
|
||||
});
|
||||
return Constructor;
|
||||
}
|
||||
function _toPropertyKey(arg) {
|
||||
var key = _toPrimitive(arg, "string");
|
||||
return typeof key === "symbol" ? key : String(key);
|
||||
}
|
||||
function _toPrimitive(input, hint) {
|
||||
if (typeof input !== "object" || input === null) return input;
|
||||
var prim = input[(typeof Symbol !== "undefined" ? Symbol : function (i) { return i; }).toPrimitive];
|
||||
if (prim !== undefined) {
|
||||
var res = prim.call(input, hint || "default");
|
||||
if (typeof res !== "object") return res;
|
||||
throw new TypeError("@@toPrimitive must return a primitive value.");
|
||||
}
|
||||
return (hint === "string" ? String : Number)(input);
|
||||
}
|
||||
var LogType = Object.freeze({
|
||||
error: /** @type {"error"} */"error",
|
||||
// message, c style arguments
|
||||
warn: /** @type {"warn"} */"warn",
|
||||
// message, c style arguments
|
||||
info: /** @type {"info"} */"info",
|
||||
// message, c style arguments
|
||||
log: /** @type {"log"} */"log",
|
||||
// message, c style arguments
|
||||
debug: /** @type {"debug"} */"debug",
|
||||
// message, c style arguments
|
||||
|
||||
trace: /** @type {"trace"} */"trace",
|
||||
// no arguments
|
||||
|
||||
group: /** @type {"group"} */"group",
|
||||
// [label]
|
||||
groupCollapsed: /** @type {"groupCollapsed"} */"groupCollapsed",
|
||||
// [label]
|
||||
groupEnd: /** @type {"groupEnd"} */"groupEnd",
|
||||
// [label]
|
||||
|
||||
profile: /** @type {"profile"} */"profile",
|
||||
// [profileName]
|
||||
profileEnd: /** @type {"profileEnd"} */"profileEnd",
|
||||
// [profileName]
|
||||
|
||||
time: /** @type {"time"} */"time",
|
||||
// name, time as [seconds, nanoseconds]
|
||||
|
||||
clear: /** @type {"clear"} */"clear",
|
||||
// no arguments
|
||||
status: /** @type {"status"} */"status" // message, arguments
|
||||
});
|
||||
|
||||
exports.LogType = LogType;
|
||||
|
||||
/** @typedef {typeof LogType[keyof typeof LogType]} LogTypeEnum */
|
||||
|
||||
var LOG_SYMBOL = (typeof Symbol !== "undefined" ? Symbol : function (i) { return i; })("webpack logger raw log method");
|
||||
var TIMERS_SYMBOL = (typeof Symbol !== "undefined" ? Symbol : function (i) { return i; })("webpack logger times");
|
||||
var TIMERS_AGGREGATES_SYMBOL = (typeof Symbol !== "undefined" ? Symbol : function (i) { return i; })("webpack logger aggregated times");
|
||||
var WebpackLogger = /*#__PURE__*/function () {
|
||||
/**
|
||||
* @param {function(LogTypeEnum, any[]=): void} log log function
|
||||
* @param {function(string | function(): string): WebpackLogger} getChildLogger function to create child logger
|
||||
*/
|
||||
function WebpackLogger(log, getChildLogger) {
|
||||
_classCallCheck(this, WebpackLogger);
|
||||
this[LOG_SYMBOL] = log;
|
||||
this.getChildLogger = getChildLogger;
|
||||
}
|
||||
_createClass(WebpackLogger, [{
|
||||
key: "error",
|
||||
value: function error() {
|
||||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
||||
args[_key] = arguments[_key];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.error, args);
|
||||
}
|
||||
}, {
|
||||
key: "warn",
|
||||
value: function warn() {
|
||||
for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
||||
args[_key2] = arguments[_key2];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.warn, args);
|
||||
}
|
||||
}, {
|
||||
key: "info",
|
||||
value: function info() {
|
||||
for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
|
||||
args[_key3] = arguments[_key3];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.info, args);
|
||||
}
|
||||
}, {
|
||||
key: "log",
|
||||
value: function log() {
|
||||
for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
|
||||
args[_key4] = arguments[_key4];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.log, args);
|
||||
}
|
||||
}, {
|
||||
key: "debug",
|
||||
value: function debug() {
|
||||
for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
|
||||
args[_key5] = arguments[_key5];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.debug, args);
|
||||
}
|
||||
}, {
|
||||
key: "assert",
|
||||
value: function assert(assertion) {
|
||||
if (!assertion) {
|
||||
for (var _len6 = arguments.length, args = new Array(_len6 > 1 ? _len6 - 1 : 0), _key6 = 1; _key6 < _len6; _key6++) {
|
||||
args[_key6 - 1] = arguments[_key6];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.error, args);
|
||||
}
|
||||
}
|
||||
}, {
|
||||
key: "trace",
|
||||
value: function trace() {
|
||||
this[LOG_SYMBOL](LogType.trace, ["Trace"]);
|
||||
}
|
||||
}, {
|
||||
key: "clear",
|
||||
value: function clear() {
|
||||
this[LOG_SYMBOL](LogType.clear);
|
||||
}
|
||||
}, {
|
||||
key: "status",
|
||||
value: function status() {
|
||||
for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {
|
||||
args[_key7] = arguments[_key7];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.status, args);
|
||||
}
|
||||
}, {
|
||||
key: "group",
|
||||
value: function group() {
|
||||
for (var _len8 = arguments.length, args = new Array(_len8), _key8 = 0; _key8 < _len8; _key8++) {
|
||||
args[_key8] = arguments[_key8];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.group, args);
|
||||
}
|
||||
}, {
|
||||
key: "groupCollapsed",
|
||||
value: function groupCollapsed() {
|
||||
for (var _len9 = arguments.length, args = new Array(_len9), _key9 = 0; _key9 < _len9; _key9++) {
|
||||
args[_key9] = arguments[_key9];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.groupCollapsed, args);
|
||||
}
|
||||
}, {
|
||||
key: "groupEnd",
|
||||
value: function groupEnd() {
|
||||
for (var _len10 = arguments.length, args = new Array(_len10), _key10 = 0; _key10 < _len10; _key10++) {
|
||||
args[_key10] = arguments[_key10];
|
||||
}
|
||||
this[LOG_SYMBOL](LogType.groupEnd, args);
|
||||
}
|
||||
}, {
|
||||
key: "profile",
|
||||
value: function profile(label) {
|
||||
this[LOG_SYMBOL](LogType.profile, [label]);
|
||||
}
|
||||
}, {
|
||||
key: "profileEnd",
|
||||
value: function profileEnd(label) {
|
||||
this[LOG_SYMBOL](LogType.profileEnd, [label]);
|
||||
}
|
||||
}, {
|
||||
key: "time",
|
||||
value: function time(label) {
|
||||
this[TIMERS_SYMBOL] = this[TIMERS_SYMBOL] || new Map();
|
||||
this[TIMERS_SYMBOL].set(label, process.hrtime());
|
||||
}
|
||||
}, {
|
||||
key: "timeLog",
|
||||
value: function timeLog(label) {
|
||||
var prev = this[TIMERS_SYMBOL] && this[TIMERS_SYMBOL].get(label);
|
||||
if (!prev) {
|
||||
throw new Error("No such label '".concat(label, "' for WebpackLogger.timeLog()"));
|
||||
}
|
||||
var time = process.hrtime(prev);
|
||||
this[LOG_SYMBOL](LogType.time, [label].concat(_toConsumableArray(time)));
|
||||
}
|
||||
}, {
|
||||
key: "timeEnd",
|
||||
value: function timeEnd(label) {
|
||||
var prev = this[TIMERS_SYMBOL] && this[TIMERS_SYMBOL].get(label);
|
||||
if (!prev) {
|
||||
throw new Error("No such label '".concat(label, "' for WebpackLogger.timeEnd()"));
|
||||
}
|
||||
var time = process.hrtime(prev);
|
||||
this[TIMERS_SYMBOL].delete(label);
|
||||
this[LOG_SYMBOL](LogType.time, [label].concat(_toConsumableArray(time)));
|
||||
}
|
||||
}, {
|
||||
key: "timeAggregate",
|
||||
value: function timeAggregate(label) {
|
||||
var prev = this[TIMERS_SYMBOL] && this[TIMERS_SYMBOL].get(label);
|
||||
if (!prev) {
|
||||
throw new Error("No such label '".concat(label, "' for WebpackLogger.timeAggregate()"));
|
||||
}
|
||||
var time = process.hrtime(prev);
|
||||
this[TIMERS_SYMBOL].delete(label);
|
||||
this[TIMERS_AGGREGATES_SYMBOL] = this[TIMERS_AGGREGATES_SYMBOL] || new Map();
|
||||
var current = this[TIMERS_AGGREGATES_SYMBOL].get(label);
|
||||
if (current !== undefined) {
|
||||
if (time[1] + current[1] > 1e9) {
|
||||
time[0] += current[0] + 1;
|
||||
time[1] = time[1] - 1e9 + current[1];
|
||||
} else {
|
||||
time[0] += current[0];
|
||||
time[1] += current[1];
|
||||
}
|
||||
}
|
||||
this[TIMERS_AGGREGATES_SYMBOL].set(label, time);
|
||||
}
|
||||
}, {
|
||||
key: "timeAggregateEnd",
|
||||
value: function timeAggregateEnd(label) {
|
||||
if (this[TIMERS_AGGREGATES_SYMBOL] === undefined) return;
|
||||
var time = this[TIMERS_AGGREGATES_SYMBOL].get(label);
|
||||
if (time === undefined) return;
|
||||
this[TIMERS_AGGREGATES_SYMBOL].delete(label);
|
||||
this[LOG_SYMBOL](LogType.time, [label].concat(_toConsumableArray(time)));
|
||||
}
|
||||
}]);
|
||||
return WebpackLogger;
|
||||
}();
|
||||
exports.Logger = WebpackLogger;
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "./node_modules/webpack/lib/logging/createConsoleLogger.js":
|
||||
/*!*****************************************************************!*\
|
||||
!*** ./node_modules/webpack/lib/logging/createConsoleLogger.js ***!
|
||||
\*****************************************************************/
|
||||
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
|
||||
|
||||
/*
|
||||
MIT License http://www.opensource.org/licenses/mit-license.php
|
||||
Author Tobias Koppers @sokra
|
||||
*/
|
||||
|
||||
|
||||
|
||||
function _toConsumableArray(arr) {
|
||||
return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
|
||||
}
|
||||
function _nonIterableSpread() {
|
||||
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
||||
}
|
||||
function _unsupportedIterableToArray(o, minLen) {
|
||||
if (!o) return;
|
||||
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
|
||||
var n = Object.prototype.toString.call(o).slice(8, -1);
|
||||
if (n === "Object" && o.constructor) n = o.constructor.name;
|
||||
if (n === "Map" || n === "Set") return Array.from(o);
|
||||
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
|
||||
}
|
||||
function _iterableToArray(iter) {
|
||||
if (typeof (typeof Symbol !== "undefined" ? Symbol : function (i) { return i; }) !== "undefined" && iter[(typeof Symbol !== "undefined" ? Symbol : function (i) { return i; }).iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
|
||||
}
|
||||
function _arrayWithoutHoles(arr) {
|
||||
if (Array.isArray(arr)) return _arrayLikeToArray(arr);
|
||||
}
|
||||
function _arrayLikeToArray(arr, len) {
|
||||
if (len == null || len > arr.length) len = arr.length;
|
||||
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
|
||||
return arr2;
|
||||
}
|
||||
var _require = __webpack_require__(/*! ./Logger */ "./node_modules/webpack/lib/logging/Logger.js"),
|
||||
LogType = _require.LogType;
|
||||
|
||||
/** @typedef {import("../../declarations/WebpackOptions").FilterItemTypes} FilterItemTypes */
|
||||
/** @typedef {import("../../declarations/WebpackOptions").FilterTypes} FilterTypes */
|
||||
/** @typedef {import("./Logger").LogTypeEnum} LogTypeEnum */
|
||||
|
||||
/** @typedef {function(string): boolean} FilterFunction */
|
||||
|
||||
/**
|
||||
* @typedef {Object} LoggerConsole
|
||||
* @property {function(): void} clear
|
||||
* @property {function(): void} trace
|
||||
* @property {(...args: any[]) => void} info
|
||||
* @property {(...args: any[]) => void} log
|
||||
* @property {(...args: any[]) => void} warn
|
||||
* @property {(...args: any[]) => void} error
|
||||
* @property {(...args: any[]) => void=} debug
|
||||
* @property {(...args: any[]) => void=} group
|
||||
* @property {(...args: any[]) => void=} groupCollapsed
|
||||
* @property {(...args: any[]) => void=} groupEnd
|
||||
* @property {(...args: any[]) => void=} status
|
||||
* @property {(...args: any[]) => void=} profile
|
||||
* @property {(...args: any[]) => void=} profileEnd
|
||||
* @property {(...args: any[]) => void=} logTime
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} LoggerOptions
|
||||
* @property {false|true|"none"|"error"|"warn"|"info"|"log"|"verbose"} level loglevel
|
||||
* @property {FilterTypes|boolean} debug filter for debug logging
|
||||
* @property {LoggerConsole} console the console to log to
|
||||
*/
|
||||
|
||||
/**
|
||||
* @param {FilterItemTypes} item an input item
|
||||
* @returns {FilterFunction} filter function
|
||||
*/
|
||||
var filterToFunction = function filterToFunction(item) {
|
||||
if (typeof item === "string") {
|
||||
var regExp = new RegExp("[\\\\/]".concat(item.replace(
|
||||
// eslint-disable-next-line no-useless-escape
|
||||
/[-[\]{}()*+?.\\^$|]/g, "\\$&"), "([\\\\/]|$|!|\\?)"));
|
||||
return function (ident) {
|
||||
return regExp.test(ident);
|
||||
};
|
||||
}
|
||||
if (item && typeof item === "object" && typeof item.test === "function") {
|
||||
return function (ident) {
|
||||
return item.test(ident);
|
||||
};
|
||||
}
|
||||
if (typeof item === "function") {
|
||||
return item;
|
||||
}
|
||||
if (typeof item === "boolean") {
|
||||
return function () {
|
||||
return item;
|
||||
};
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* @enum {number}
|
||||
*/
|
||||
var LogLevel = {
|
||||
none: 6,
|
||||
false: 6,
|
||||
error: 5,
|
||||
warn: 4,
|
||||
info: 3,
|
||||
log: 2,
|
||||
true: 2,
|
||||
verbose: 1
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {LoggerOptions} options options object
|
||||
* @returns {function(string, LogTypeEnum, any[]): void} logging function
|
||||
*/
|
||||
module.exports = function (_ref) {
|
||||
var _ref$level = _ref.level,
|
||||
level = _ref$level === void 0 ? "info" : _ref$level,
|
||||
_ref$debug = _ref.debug,
|
||||
debug = _ref$debug === void 0 ? false : _ref$debug,
|
||||
console = _ref.console;
|
||||
var debugFilters = typeof debug === "boolean" ? [function () {
|
||||
return debug;
|
||||
}] : /** @type {FilterItemTypes[]} */[].concat(debug).map(filterToFunction);
|
||||
/** @type {number} */
|
||||
var loglevel = LogLevel["".concat(level)] || 0;
|
||||
|
||||
/**
|
||||
* @param {string} name name of the logger
|
||||
* @param {LogTypeEnum} type type of the log entry
|
||||
* @param {any[]} args arguments of the log entry
|
||||
* @returns {void}
|
||||
*/
|
||||
var logger = function logger(name, type, args) {
|
||||
var labeledArgs = function labeledArgs() {
|
||||
if (Array.isArray(args)) {
|
||||
if (args.length > 0 && typeof args[0] === "string") {
|
||||
return ["[".concat(name, "] ").concat(args[0])].concat(_toConsumableArray(args.slice(1)));
|
||||
} else {
|
||||
return ["[".concat(name, "]")].concat(_toConsumableArray(args));
|
||||
}
|
||||
} else {
|
||||
return [];
|
||||
}
|
||||
};
|
||||
var debug = debugFilters.some(function (f) {
|
||||
return f(name);
|
||||
});
|
||||
switch (type) {
|
||||
case LogType.debug:
|
||||
if (!debug) return;
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
if (typeof console.debug === "function") {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
console.debug.apply(console, _toConsumableArray(labeledArgs()));
|
||||
} else {
|
||||
console.log.apply(console, _toConsumableArray(labeledArgs()));
|
||||
}
|
||||
break;
|
||||
case LogType.log:
|
||||
if (!debug && loglevel > LogLevel.log) return;
|
||||
console.log.apply(console, _toConsumableArray(labeledArgs()));
|
||||
break;
|
||||
case LogType.info:
|
||||
if (!debug && loglevel > LogLevel.info) return;
|
||||
console.info.apply(console, _toConsumableArray(labeledArgs()));
|
||||
break;
|
||||
case LogType.warn:
|
||||
if (!debug && loglevel > LogLevel.warn) return;
|
||||
console.warn.apply(console, _toConsumableArray(labeledArgs()));
|
||||
break;
|
||||
case LogType.error:
|
||||
if (!debug && loglevel > LogLevel.error) return;
|
||||
console.error.apply(console, _toConsumableArray(labeledArgs()));
|
||||
break;
|
||||
case LogType.trace:
|
||||
if (!debug) return;
|
||||
console.trace();
|
||||
break;
|
||||
case LogType.groupCollapsed:
|
||||
if (!debug && loglevel > LogLevel.log) return;
|
||||
if (!debug && loglevel > LogLevel.verbose) {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
if (typeof console.groupCollapsed === "function") {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
console.groupCollapsed.apply(console, _toConsumableArray(labeledArgs()));
|
||||
} else {
|
||||
console.log.apply(console, _toConsumableArray(labeledArgs()));
|
||||
}
|
||||
break;
|
||||
}
|
||||
// falls through
|
||||
case LogType.group:
|
||||
if (!debug && loglevel > LogLevel.log) return;
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
if (typeof console.group === "function") {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
console.group.apply(console, _toConsumableArray(labeledArgs()));
|
||||
} else {
|
||||
console.log.apply(console, _toConsumableArray(labeledArgs()));
|
||||
}
|
||||
break;
|
||||
case LogType.groupEnd:
|
||||
if (!debug && loglevel > LogLevel.log) return;
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
if (typeof console.groupEnd === "function") {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
console.groupEnd();
|
||||
}
|
||||
break;
|
||||
case LogType.time:
|
||||
{
|
||||
if (!debug && loglevel > LogLevel.log) return;
|
||||
var ms = args[1] * 1000 + args[2] / 1000000;
|
||||
var msg = "[".concat(name, "] ").concat(args[0], ": ").concat(ms, " ms");
|
||||
if (typeof console.logTime === "function") {
|
||||
console.logTime(msg);
|
||||
} else {
|
||||
console.log(msg);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case LogType.profile:
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
if (typeof console.profile === "function") {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
console.profile.apply(console, _toConsumableArray(labeledArgs()));
|
||||
}
|
||||
break;
|
||||
case LogType.profileEnd:
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
if (typeof console.profileEnd === "function") {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
console.profileEnd.apply(console, _toConsumableArray(labeledArgs()));
|
||||
}
|
||||
break;
|
||||
case LogType.clear:
|
||||
if (!debug && loglevel > LogLevel.log) return;
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
if (typeof console.clear === "function") {
|
||||
// eslint-disable-next-line node/no-unsupported-features/node-builtins
|
||||
console.clear();
|
||||
}
|
||||
break;
|
||||
case LogType.status:
|
||||
if (!debug && loglevel > LogLevel.info) return;
|
||||
if (typeof console.status === "function") {
|
||||
if (args.length === 0) {
|
||||
console.status();
|
||||
} else {
|
||||
console.status.apply(console, _toConsumableArray(labeledArgs()));
|
||||
}
|
||||
} else {
|
||||
if (args.length !== 0) {
|
||||
console.info.apply(console, _toConsumableArray(labeledArgs()));
|
||||
}
|
||||
}
|
||||
break;
|
||||
default:
|
||||
throw new Error("Unexpected LogType ".concat(type));
|
||||
}
|
||||
};
|
||||
return logger;
|
||||
};
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "./node_modules/webpack/lib/logging/runtime.js":
|
||||
/*!*****************************************************!*\
|
||||
!*** ./node_modules/webpack/lib/logging/runtime.js ***!
|
||||
\*****************************************************/
|
||||
/***/ (function(__unused_webpack_module, exports, __webpack_require__) {
|
||||
|
||||
/*
|
||||
MIT License http://www.opensource.org/licenses/mit-license.php
|
||||
Author Tobias Koppers @sokra
|
||||
*/
|
||||
|
||||
|
||||
|
||||
function _extends() {
|
||||
_extends = Object.assign ? Object.assign.bind() : function (target) {
|
||||
for (var i = 1; i < arguments.length; i++) {
|
||||
var source = arguments[i];
|
||||
for (var key in source) {
|
||||
if (Object.prototype.hasOwnProperty.call(source, key)) {
|
||||
target[key] = source[key];
|
||||
}
|
||||
}
|
||||
}
|
||||
return target;
|
||||
};
|
||||
return _extends.apply(this, arguments);
|
||||
}
|
||||
var SyncBailHook = __webpack_require__(/*! tapable/lib/SyncBailHook */ "./client-src/modules/logger/SyncBailHookFake.js");
|
||||
var _require = __webpack_require__(/*! ./Logger */ "./node_modules/webpack/lib/logging/Logger.js"),
|
||||
Logger = _require.Logger;
|
||||
var createConsoleLogger = __webpack_require__(/*! ./createConsoleLogger */ "./node_modules/webpack/lib/logging/createConsoleLogger.js");
|
||||
|
||||
/** @type {createConsoleLogger.LoggerOptions} */
|
||||
var currentDefaultLoggerOptions = {
|
||||
level: "info",
|
||||
debug: false,
|
||||
console: console
|
||||
};
|
||||
var currentDefaultLogger = createConsoleLogger(currentDefaultLoggerOptions);
|
||||
|
||||
/**
|
||||
* @param {string} name name of the logger
|
||||
* @returns {Logger} a logger
|
||||
*/
|
||||
exports.getLogger = function (name) {
|
||||
return new Logger(function (type, args) {
|
||||
if (exports.hooks.log.call(name, type, args) === undefined) {
|
||||
currentDefaultLogger(name, type, args);
|
||||
}
|
||||
}, function (childName) {
|
||||
return exports.getLogger("".concat(name, "/").concat(childName));
|
||||
});
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {createConsoleLogger.LoggerOptions} options new options, merge with old options
|
||||
* @returns {void}
|
||||
*/
|
||||
exports.configureDefaultLogger = function (options) {
|
||||
_extends(currentDefaultLoggerOptions, options);
|
||||
currentDefaultLogger = createConsoleLogger(currentDefaultLoggerOptions);
|
||||
};
|
||||
exports.hooks = {
|
||||
log: new SyncBailHook(["origin", "type", "args"])
|
||||
};
|
||||
|
||||
/***/ })
|
||||
|
||||
/******/ });
|
||||
/************************************************************************/
|
||||
/******/ // The module cache
|
||||
/******/ var __webpack_module_cache__ = {};
|
||||
/******/
|
||||
/******/ // The require function
|
||||
/******/ function __webpack_require__(moduleId) {
|
||||
/******/ // Check if module is in cache
|
||||
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
||||
/******/ if (cachedModule !== undefined) {
|
||||
/******/ return cachedModule.exports;
|
||||
/******/ }
|
||||
/******/ // Create a new module (and put it into the cache)
|
||||
/******/ var module = __webpack_module_cache__[moduleId] = {
|
||||
/******/ // no module.id needed
|
||||
/******/ // no module.loaded needed
|
||||
/******/ exports: {}
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // Execute the module function
|
||||
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
||||
/******/
|
||||
/******/ // Return the exports of the module
|
||||
/******/ return module.exports;
|
||||
/******/ }
|
||||
/******/
|
||||
/************************************************************************/
|
||||
/******/ /* webpack/runtime/define property getters */
|
||||
/******/ !function() {
|
||||
/******/ // define getter functions for harmony exports
|
||||
/******/ __webpack_require__.d = function(exports, definition) {
|
||||
/******/ for(var key in definition) {
|
||||
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
||||
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
||||
/******/ }
|
||||
/******/ }
|
||||
/******/ };
|
||||
/******/ }();
|
||||
/******/
|
||||
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
||||
/******/ !function() {
|
||||
/******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
|
||||
/******/ }();
|
||||
/******/
|
||||
/******/ /* webpack/runtime/make namespace object */
|
||||
/******/ !function() {
|
||||
/******/ // define __esModule on exports
|
||||
/******/ __webpack_require__.r = function(exports) {
|
||||
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
||||
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
||||
/******/ }
|
||||
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
||||
/******/ };
|
||||
/******/ }();
|
||||
/******/
|
||||
/************************************************************************/
|
||||
var __webpack_exports__ = {};
|
||||
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
|
||||
!function() {
|
||||
/*!********************************************!*\
|
||||
!*** ./client-src/modules/logger/index.js ***!
|
||||
\********************************************/
|
||||
__webpack_require__.r(__webpack_exports__);
|
||||
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
|
||||
/* harmony export */ "default": function() { return /* reexport default export from named module */ webpack_lib_logging_runtime_js__WEBPACK_IMPORTED_MODULE_0__; }
|
||||
/* harmony export */ });
|
||||
/* harmony import */ var webpack_lib_logging_runtime_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! webpack/lib/logging/runtime.js */ "./node_modules/webpack/lib/logging/runtime.js");
|
||||
|
||||
}();
|
||||
var __webpack_export_target__ = exports;
|
||||
for(var i in __webpack_exports__) __webpack_export_target__[i] = __webpack_exports__[i];
|
||||
if(__webpack_exports__.__esModule) Object.defineProperty(__webpack_export_target__, "__esModule", { value: true });
|
||||
/******/ })()
|
||||
;
|
5039
my-app/node_modules/webpack-dev-server/client/modules/sockjs-client/index.js
generated
vendored
Executable file
5039
my-app/node_modules/webpack-dev-server/client/modules/sockjs-client/index.js
generated
vendored
Executable file
File diff suppressed because it is too large
Load diff
268
my-app/node_modules/webpack-dev-server/client/overlay.js
generated
vendored
Executable file
268
my-app/node_modules/webpack-dev-server/client/overlay.js
generated
vendored
Executable file
|
@ -0,0 +1,268 @@
|
|||
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
||||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
||||
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
||||
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
||||
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
||||
// The error overlay is inspired (and mostly copied) from Create React App (https://github.com/facebookincubator/create-react-app)
|
||||
// They, in turn, got inspired by webpack-hot-middleware (https://github.com/glenjamin/webpack-hot-middleware).
|
||||
|
||||
import ansiHTML from "ansi-html-community";
|
||||
import { encode } from "html-entities";
|
||||
import { listenToRuntimeError, listenToUnhandledRejection, parseErrorToStacks } from "./overlay/runtime-error.js";
|
||||
import createOverlayMachine from "./overlay/state-machine.js";
|
||||
import { containerStyle, dismissButtonStyle, headerStyle, iframeStyle, msgStyles, msgTextStyle, msgTypeStyle } from "./overlay/styles.js";
|
||||
var colors = {
|
||||
reset: ["transparent", "transparent"],
|
||||
black: "181818",
|
||||
red: "E36049",
|
||||
green: "B3CB74",
|
||||
yellow: "FFD080",
|
||||
blue: "7CAFC2",
|
||||
magenta: "7FACCA",
|
||||
cyan: "C3C2EF",
|
||||
lightgrey: "EBE7E3",
|
||||
darkgrey: "6D7891"
|
||||
};
|
||||
ansiHTML.setColors(colors);
|
||||
|
||||
/**
|
||||
* @param {string} type
|
||||
* @param {string | { file?: string, moduleName?: string, loc?: string, message?: string; stack?: string[] }} item
|
||||
* @returns {{ header: string, body: string }}
|
||||
*/
|
||||
function formatProblem(type, item) {
|
||||
var header = type === "warning" ? "WARNING" : "ERROR";
|
||||
var body = "";
|
||||
if (typeof item === "string") {
|
||||
body += item;
|
||||
} else {
|
||||
var file = item.file || "";
|
||||
// eslint-disable-next-line no-nested-ternary
|
||||
var moduleName = item.moduleName ? item.moduleName.indexOf("!") !== -1 ? "".concat(item.moduleName.replace(/^(\s|\S)*!/, ""), " (").concat(item.moduleName, ")") : "".concat(item.moduleName) : "";
|
||||
var loc = item.loc;
|
||||
header += "".concat(moduleName || file ? " in ".concat(moduleName ? "".concat(moduleName).concat(file ? " (".concat(file, ")") : "") : file).concat(loc ? " ".concat(loc) : "") : "");
|
||||
body += item.message || "";
|
||||
}
|
||||
if (Array.isArray(item.stack)) {
|
||||
item.stack.forEach(function (stack) {
|
||||
if (typeof stack === "string") {
|
||||
body += "\r\n".concat(stack);
|
||||
}
|
||||
});
|
||||
}
|
||||
return {
|
||||
header: header,
|
||||
body: body
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* @typedef {Object} CreateOverlayOptions
|
||||
* @property {string | null} trustedTypesPolicyName
|
||||
* @property {boolean | (error: Error) => void} [catchRuntimeError]
|
||||
*/
|
||||
|
||||
/**
|
||||
*
|
||||
* @param {CreateOverlayOptions} options
|
||||
*/
|
||||
var createOverlay = function createOverlay(options) {
|
||||
/** @type {HTMLIFrameElement | null | undefined} */
|
||||
var iframeContainerElement;
|
||||
/** @type {HTMLDivElement | null | undefined} */
|
||||
var containerElement;
|
||||
/** @type {HTMLDivElement | null | undefined} */
|
||||
var headerElement;
|
||||
/** @type {Array<(element: HTMLDivElement) => void>} */
|
||||
var onLoadQueue = [];
|
||||
/** @type {TrustedTypePolicy | undefined} */
|
||||
var overlayTrustedTypesPolicy;
|
||||
|
||||
/**
|
||||
*
|
||||
* @param {HTMLElement} element
|
||||
* @param {CSSStyleDeclaration} style
|
||||
*/
|
||||
function applyStyle(element, style) {
|
||||
Object.keys(style).forEach(function (prop) {
|
||||
element.style[prop] = style[prop];
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string | null} trustedTypesPolicyName
|
||||
*/
|
||||
function createContainer(trustedTypesPolicyName) {
|
||||
// Enable Trusted Types if they are available in the current browser.
|
||||
if (window.trustedTypes) {
|
||||
overlayTrustedTypesPolicy = window.trustedTypes.createPolicy(trustedTypesPolicyName || "webpack-dev-server#overlay", {
|
||||
createHTML: function createHTML(value) {
|
||||
return value;
|
||||
}
|
||||
});
|
||||
}
|
||||
iframeContainerElement = document.createElement("iframe");
|
||||
iframeContainerElement.id = "webpack-dev-server-client-overlay";
|
||||
iframeContainerElement.src = "about:blank";
|
||||
applyStyle(iframeContainerElement, iframeStyle);
|
||||
iframeContainerElement.onload = function () {
|
||||
var contentElement = /** @type {Document} */
|
||||
/** @type {HTMLIFrameElement} */
|
||||
iframeContainerElement.contentDocument.createElement("div");
|
||||
containerElement = /** @type {Document} */
|
||||
/** @type {HTMLIFrameElement} */
|
||||
iframeContainerElement.contentDocument.createElement("div");
|
||||
contentElement.id = "webpack-dev-server-client-overlay-div";
|
||||
applyStyle(contentElement, containerStyle);
|
||||
headerElement = document.createElement("div");
|
||||
headerElement.innerText = "Compiled with problems:";
|
||||
applyStyle(headerElement, headerStyle);
|
||||
var closeButtonElement = document.createElement("button");
|
||||
applyStyle(closeButtonElement, dismissButtonStyle);
|
||||
closeButtonElement.innerText = "×";
|
||||
closeButtonElement.ariaLabel = "Dismiss";
|
||||
closeButtonElement.addEventListener("click", function () {
|
||||
// eslint-disable-next-line no-use-before-define
|
||||
overlayService.send({
|
||||
type: "DISMISS"
|
||||
});
|
||||
});
|
||||
contentElement.appendChild(headerElement);
|
||||
contentElement.appendChild(closeButtonElement);
|
||||
contentElement.appendChild(containerElement);
|
||||
|
||||
/** @type {Document} */
|
||||
/** @type {HTMLIFrameElement} */
|
||||
iframeContainerElement.contentDocument.body.appendChild(contentElement);
|
||||
onLoadQueue.forEach(function (onLoad) {
|
||||
onLoad( /** @type {HTMLDivElement} */contentElement);
|
||||
});
|
||||
onLoadQueue = [];
|
||||
|
||||
/** @type {HTMLIFrameElement} */
|
||||
iframeContainerElement.onload = null;
|
||||
};
|
||||
document.body.appendChild(iframeContainerElement);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {(element: HTMLDivElement) => void} callback
|
||||
* @param {string | null} trustedTypesPolicyName
|
||||
*/
|
||||
function ensureOverlayExists(callback, trustedTypesPolicyName) {
|
||||
if (containerElement) {
|
||||
containerElement.innerHTML = "";
|
||||
// Everything is ready, call the callback right away.
|
||||
callback(containerElement);
|
||||
return;
|
||||
}
|
||||
onLoadQueue.push(callback);
|
||||
if (iframeContainerElement) {
|
||||
return;
|
||||
}
|
||||
createContainer(trustedTypesPolicyName);
|
||||
}
|
||||
|
||||
// Successful compilation.
|
||||
function hide() {
|
||||
if (!iframeContainerElement) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Clean up and reset internal state.
|
||||
document.body.removeChild(iframeContainerElement);
|
||||
iframeContainerElement = null;
|
||||
containerElement = null;
|
||||
}
|
||||
|
||||
// Compilation with errors (e.g. syntax error or missing modules).
|
||||
/**
|
||||
* @param {string} type
|
||||
* @param {Array<string | { moduleIdentifier?: string, moduleName?: string, loc?: string, message?: string }>} messages
|
||||
* @param {string | null} trustedTypesPolicyName
|
||||
* @param {'build' | 'runtime'} messageSource
|
||||
*/
|
||||
function show(type, messages, trustedTypesPolicyName, messageSource) {
|
||||
ensureOverlayExists(function () {
|
||||
headerElement.innerText = messageSource === "runtime" ? "Uncaught runtime errors:" : "Compiled with problems:";
|
||||
messages.forEach(function (message) {
|
||||
var entryElement = document.createElement("div");
|
||||
var msgStyle = type === "warning" ? msgStyles.warning : msgStyles.error;
|
||||
applyStyle(entryElement, _objectSpread(_objectSpread({}, msgStyle), {}, {
|
||||
padding: "1rem 1rem 1.5rem 1rem"
|
||||
}));
|
||||
var typeElement = document.createElement("div");
|
||||
var _formatProblem = formatProblem(type, message),
|
||||
header = _formatProblem.header,
|
||||
body = _formatProblem.body;
|
||||
typeElement.innerText = header;
|
||||
applyStyle(typeElement, msgTypeStyle);
|
||||
if (message.moduleIdentifier) {
|
||||
applyStyle(typeElement, {
|
||||
cursor: "pointer"
|
||||
});
|
||||
// element.dataset not supported in IE
|
||||
typeElement.setAttribute("data-can-open", true);
|
||||
typeElement.addEventListener("click", function () {
|
||||
fetch("/webpack-dev-server/open-editor?fileName=".concat(message.moduleIdentifier));
|
||||
});
|
||||
}
|
||||
|
||||
// Make it look similar to our terminal.
|
||||
var text = ansiHTML(encode(body));
|
||||
var messageTextNode = document.createElement("div");
|
||||
applyStyle(messageTextNode, msgTextStyle);
|
||||
messageTextNode.innerHTML = overlayTrustedTypesPolicy ? overlayTrustedTypesPolicy.createHTML(text) : text;
|
||||
entryElement.appendChild(typeElement);
|
||||
entryElement.appendChild(messageTextNode);
|
||||
|
||||
/** @type {HTMLDivElement} */
|
||||
containerElement.appendChild(entryElement);
|
||||
});
|
||||
}, trustedTypesPolicyName);
|
||||
}
|
||||
var overlayService = createOverlayMachine({
|
||||
showOverlay: function showOverlay(_ref) {
|
||||
var _ref$level = _ref.level,
|
||||
level = _ref$level === void 0 ? "error" : _ref$level,
|
||||
messages = _ref.messages,
|
||||
messageSource = _ref.messageSource;
|
||||
return show(level, messages, options.trustedTypesPolicyName, messageSource);
|
||||
},
|
||||
hideOverlay: hide
|
||||
});
|
||||
if (options.catchRuntimeError) {
|
||||
/**
|
||||
* @param {Error | undefined} error
|
||||
* @param {string} fallbackMessage
|
||||
*/
|
||||
var handleError = function handleError(error, fallbackMessage) {
|
||||
var errorObject = error instanceof Error ? error : new Error(error || fallbackMessage);
|
||||
var shouldDisplay = typeof options.catchRuntimeError === "function" ? options.catchRuntimeError(errorObject) : true;
|
||||
if (shouldDisplay) {
|
||||
overlayService.send({
|
||||
type: "RUNTIME_ERROR",
|
||||
messages: [{
|
||||
message: errorObject.message,
|
||||
stack: parseErrorToStacks(errorObject)
|
||||
}]
|
||||
});
|
||||
}
|
||||
};
|
||||
listenToRuntimeError(function (errorEvent) {
|
||||
// error property may be empty in older browser like IE
|
||||
var error = errorEvent.error,
|
||||
message = errorEvent.message;
|
||||
if (!error && !message) {
|
||||
return;
|
||||
}
|
||||
handleError(error, message);
|
||||
});
|
||||
listenToUnhandledRejection(function (promiseRejectionEvent) {
|
||||
var reason = promiseRejectionEvent.reason;
|
||||
handleError(reason, "Unknown promise rejection reason");
|
||||
});
|
||||
}
|
||||
return overlayService;
|
||||
};
|
||||
export { formatProblem, createOverlay };
|
64
my-app/node_modules/webpack-dev-server/client/overlay/fsm.js
generated
vendored
Executable file
64
my-app/node_modules/webpack-dev-server/client/overlay/fsm.js
generated
vendored
Executable file
|
@ -0,0 +1,64 @@
|
|||
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
||||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
||||
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
||||
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
||||
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
||||
/**
|
||||
* @typedef {Object} StateDefinitions
|
||||
* @property {{[event: string]: { target: string; actions?: Array<string> }}} [on]
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} Options
|
||||
* @property {{[state: string]: StateDefinitions}} states
|
||||
* @property {object} context;
|
||||
* @property {string} initial
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} Implementation
|
||||
* @property {{[actionName: string]: (ctx: object, event: any) => object}} actions
|
||||
*/
|
||||
|
||||
/**
|
||||
* A simplified `createMachine` from `@xstate/fsm` with the following differences:
|
||||
*
|
||||
* - the returned machine is technically a "service". No `interpret(machine).start()` is needed.
|
||||
* - the state definition only support `on` and target must be declared with { target: 'nextState', actions: [] } explicitly.
|
||||
* - event passed to `send` must be an object with `type` property.
|
||||
* - actions implementation will be [assign action](https://xstate.js.org/docs/guides/context.html#assign-action) if you return any value.
|
||||
* Do not return anything if you just want to invoke side effect.
|
||||
*
|
||||
* The goal of this custom function is to avoid installing the entire `'xstate/fsm'` package, while enabling modeling using
|
||||
* state machine. You can copy the first parameter into the editor at https://stately.ai/viz to visualize the state machine.
|
||||
*
|
||||
* @param {Options} options
|
||||
* @param {Implementation} implementation
|
||||
*/
|
||||
function createMachine(_ref, _ref2) {
|
||||
var states = _ref.states,
|
||||
context = _ref.context,
|
||||
initial = _ref.initial;
|
||||
var actions = _ref2.actions;
|
||||
var currentState = initial;
|
||||
var currentContext = context;
|
||||
return {
|
||||
send: function send(event) {
|
||||
var currentStateOn = states[currentState].on;
|
||||
var transitionConfig = currentStateOn && currentStateOn[event.type];
|
||||
if (transitionConfig) {
|
||||
currentState = transitionConfig.target;
|
||||
if (transitionConfig.actions) {
|
||||
transitionConfig.actions.forEach(function (actName) {
|
||||
var actionImpl = actions[actName];
|
||||
var nextContextValue = actionImpl && actionImpl(currentContext, event);
|
||||
if (nextContextValue) {
|
||||
currentContext = _objectSpread(_objectSpread({}, currentContext), nextContextValue);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
export default createMachine;
|
47
my-app/node_modules/webpack-dev-server/client/overlay/runtime-error.js
generated
vendored
Executable file
47
my-app/node_modules/webpack-dev-server/client/overlay/runtime-error.js
generated
vendored
Executable file
|
@ -0,0 +1,47 @@
|
|||
/**
|
||||
*
|
||||
* @param {Error} error
|
||||
*/
|
||||
function parseErrorToStacks(error) {
|
||||
if (!error || !(error instanceof Error)) {
|
||||
throw new Error("parseErrorToStacks expects Error object");
|
||||
}
|
||||
if (typeof error.stack === "string") {
|
||||
return error.stack.split("\n").filter(function (stack) {
|
||||
return stack !== "Error: ".concat(error.message);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @callback ErrorCallback
|
||||
* @param {ErrorEvent} error
|
||||
* @returns {void}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @param {ErrorCallback} callback
|
||||
*/
|
||||
function listenToRuntimeError(callback) {
|
||||
window.addEventListener("error", callback);
|
||||
return function cleanup() {
|
||||
window.removeEventListener("error", callback);
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* @callback UnhandledRejectionCallback
|
||||
* @param {PromiseRejectionEvent} rejectionEvent
|
||||
* @returns {void}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @param {UnhandledRejectionCallback} callback
|
||||
*/
|
||||
function listenToUnhandledRejection(callback) {
|
||||
window.addEventListener("unhandledrejection", callback);
|
||||
return function cleanup() {
|
||||
window.removeEventListener("unhandledrejection", callback);
|
||||
};
|
||||
}
|
||||
export { listenToRuntimeError, listenToUnhandledRejection, parseErrorToStacks };
|
100
my-app/node_modules/webpack-dev-server/client/overlay/state-machine.js
generated
vendored
Executable file
100
my-app/node_modules/webpack-dev-server/client/overlay/state-machine.js
generated
vendored
Executable file
|
@ -0,0 +1,100 @@
|
|||
import createMachine from "./fsm.js";
|
||||
|
||||
/**
|
||||
* @typedef {Object} ShowOverlayData
|
||||
* @property {'warning' | 'error'} level
|
||||
* @property {Array<string | { moduleIdentifier?: string, moduleName?: string, loc?: string, message?: string }>} messages
|
||||
* @property {'build' | 'runtime'} messageSource
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} CreateOverlayMachineOptions
|
||||
* @property {(data: ShowOverlayData) => void} showOverlay
|
||||
* @property {() => void} hideOverlay
|
||||
*/
|
||||
|
||||
/**
|
||||
* @param {CreateOverlayMachineOptions} options
|
||||
*/
|
||||
var createOverlayMachine = function createOverlayMachine(options) {
|
||||
var hideOverlay = options.hideOverlay,
|
||||
showOverlay = options.showOverlay;
|
||||
var overlayMachine = createMachine({
|
||||
initial: "hidden",
|
||||
context: {
|
||||
level: "error",
|
||||
messages: [],
|
||||
messageSource: "build"
|
||||
},
|
||||
states: {
|
||||
hidden: {
|
||||
on: {
|
||||
BUILD_ERROR: {
|
||||
target: "displayBuildError",
|
||||
actions: ["setMessages", "showOverlay"]
|
||||
},
|
||||
RUNTIME_ERROR: {
|
||||
target: "displayRuntimeError",
|
||||
actions: ["setMessages", "showOverlay"]
|
||||
}
|
||||
}
|
||||
},
|
||||
displayBuildError: {
|
||||
on: {
|
||||
DISMISS: {
|
||||
target: "hidden",
|
||||
actions: ["dismissMessages", "hideOverlay"]
|
||||
},
|
||||
BUILD_ERROR: {
|
||||
target: "displayBuildError",
|
||||
actions: ["appendMessages", "showOverlay"]
|
||||
}
|
||||
}
|
||||
},
|
||||
displayRuntimeError: {
|
||||
on: {
|
||||
DISMISS: {
|
||||
target: "hidden",
|
||||
actions: ["dismissMessages", "hideOverlay"]
|
||||
},
|
||||
RUNTIME_ERROR: {
|
||||
target: "displayRuntimeError",
|
||||
actions: ["appendMessages", "showOverlay"]
|
||||
},
|
||||
BUILD_ERROR: {
|
||||
target: "displayBuildError",
|
||||
actions: ["setMessages", "showOverlay"]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, {
|
||||
actions: {
|
||||
dismissMessages: function dismissMessages() {
|
||||
return {
|
||||
messages: [],
|
||||
level: "error",
|
||||
messageSource: "build"
|
||||
};
|
||||
},
|
||||
appendMessages: function appendMessages(context, event) {
|
||||
return {
|
||||
messages: context.messages.concat(event.messages),
|
||||
level: event.level || context.level,
|
||||
messageSource: event.type === "RUNTIME_ERROR" ? "runtime" : "build"
|
||||
};
|
||||
},
|
||||
setMessages: function setMessages(context, event) {
|
||||
return {
|
||||
messages: event.messages,
|
||||
level: event.level || context.level,
|
||||
messageSource: event.type === "RUNTIME_ERROR" ? "runtime" : "build"
|
||||
};
|
||||
},
|
||||
hideOverlay: hideOverlay,
|
||||
showOverlay: showOverlay
|
||||
}
|
||||
});
|
||||
return overlayMachine;
|
||||
};
|
||||
export default createOverlayMachine;
|
74
my-app/node_modules/webpack-dev-server/client/overlay/styles.js
generated
vendored
Executable file
74
my-app/node_modules/webpack-dev-server/client/overlay/styles.js
generated
vendored
Executable file
|
@ -0,0 +1,74 @@
|
|||
// styles are inspired by `react-error-overlay`
|
||||
|
||||
var msgStyles = {
|
||||
error: {
|
||||
backgroundColor: "rgba(206, 17, 38, 0.1)",
|
||||
color: "#fccfcf"
|
||||
},
|
||||
warning: {
|
||||
backgroundColor: "rgba(251, 245, 180, 0.1)",
|
||||
color: "#fbf5b4"
|
||||
}
|
||||
};
|
||||
var iframeStyle = {
|
||||
position: "fixed",
|
||||
top: 0,
|
||||
left: 0,
|
||||
right: 0,
|
||||
bottom: 0,
|
||||
width: "100vw",
|
||||
height: "100vh",
|
||||
border: "none",
|
||||
"z-index": 9999999999
|
||||
};
|
||||
var containerStyle = {
|
||||
position: "fixed",
|
||||
boxSizing: "border-box",
|
||||
left: 0,
|
||||
top: 0,
|
||||
right: 0,
|
||||
bottom: 0,
|
||||
width: "100vw",
|
||||
height: "100vh",
|
||||
fontSize: "large",
|
||||
padding: "2rem 2rem 4rem 2rem",
|
||||
lineHeight: "1.2",
|
||||
whiteSpace: "pre-wrap",
|
||||
overflow: "auto",
|
||||
backgroundColor: "rgba(0, 0, 0, 0.9)",
|
||||
color: "white"
|
||||
};
|
||||
var headerStyle = {
|
||||
color: "#e83b46",
|
||||
fontSize: "2em",
|
||||
whiteSpace: "pre-wrap",
|
||||
fontFamily: "sans-serif",
|
||||
margin: "0 2rem 2rem 0",
|
||||
flex: "0 0 auto",
|
||||
maxHeight: "50%",
|
||||
overflow: "auto"
|
||||
};
|
||||
var dismissButtonStyle = {
|
||||
color: "#ffffff",
|
||||
lineHeight: "1rem",
|
||||
fontSize: "1.5rem",
|
||||
padding: "1rem",
|
||||
cursor: "pointer",
|
||||
position: "absolute",
|
||||
right: 0,
|
||||
top: 0,
|
||||
backgroundColor: "transparent",
|
||||
border: "none"
|
||||
};
|
||||
var msgTypeStyle = {
|
||||
color: "#e83b46",
|
||||
fontSize: "1.2em",
|
||||
marginBottom: "1rem",
|
||||
fontFamily: "sans-serif"
|
||||
};
|
||||
var msgTextStyle = {
|
||||
lineHeight: "1.5",
|
||||
fontSize: "1rem",
|
||||
fontFamily: "Menlo, Consolas, monospace"
|
||||
};
|
||||
export { msgStyles, iframeStyle, containerStyle, headerStyle, dismissButtonStyle, msgTypeStyle, msgTextStyle };
|
66
my-app/node_modules/webpack-dev-server/client/socket.js
generated
vendored
Executable file
66
my-app/node_modules/webpack-dev-server/client/socket.js
generated
vendored
Executable file
|
@ -0,0 +1,66 @@
|
|||
/* global __webpack_dev_server_client__ */
|
||||
|
||||
import WebSocketClient from "./clients/WebSocketClient.js";
|
||||
import { log } from "./utils/log.js";
|
||||
|
||||
// this WebsocketClient is here as a default fallback, in case the client is not injected
|
||||
/* eslint-disable camelcase */
|
||||
var Client =
|
||||
// eslint-disable-next-line no-nested-ternary
|
||||
typeof __webpack_dev_server_client__ !== "undefined" ? typeof __webpack_dev_server_client__.default !== "undefined" ? __webpack_dev_server_client__.default : __webpack_dev_server_client__ : WebSocketClient;
|
||||
/* eslint-enable camelcase */
|
||||
|
||||
var retries = 0;
|
||||
var maxRetries = 10;
|
||||
|
||||
// Initialized client is exported so external consumers can utilize the same instance
|
||||
// It is mutable to enforce singleton
|
||||
// eslint-disable-next-line import/no-mutable-exports
|
||||
export var client = null;
|
||||
|
||||
/**
|
||||
* @param {string} url
|
||||
* @param {{ [handler: string]: (data?: any, params?: any) => any }} handlers
|
||||
* @param {number} [reconnect]
|
||||
*/
|
||||
var socket = function initSocket(url, handlers, reconnect) {
|
||||
client = new Client(url);
|
||||
client.onOpen(function () {
|
||||
retries = 0;
|
||||
if (typeof reconnect !== "undefined") {
|
||||
maxRetries = reconnect;
|
||||
}
|
||||
});
|
||||
client.onClose(function () {
|
||||
if (retries === 0) {
|
||||
handlers.close();
|
||||
}
|
||||
|
||||
// Try to reconnect.
|
||||
client = null;
|
||||
|
||||
// After 10 retries stop trying, to prevent logspam.
|
||||
if (retries < maxRetries) {
|
||||
// Exponentially increase timeout to reconnect.
|
||||
// Respectfully copied from the package `got`.
|
||||
// eslint-disable-next-line no-restricted-properties
|
||||
var retryInMs = 1000 * Math.pow(2, retries) + Math.random() * 100;
|
||||
retries += 1;
|
||||
log.info("Trying to reconnect...");
|
||||
setTimeout(function () {
|
||||
socket(url, handlers, reconnect);
|
||||
}, retryInMs);
|
||||
}
|
||||
});
|
||||
client.onMessage(
|
||||
/**
|
||||
* @param {any} data
|
||||
*/
|
||||
function (data) {
|
||||
var message = JSON.parse(data);
|
||||
if (handlers[message.type]) {
|
||||
handlers[message.type](message.data, message.params);
|
||||
}
|
||||
});
|
||||
};
|
||||
export default socket;
|
121
my-app/node_modules/webpack-dev-server/client/utils/createSocketURL.js
generated
vendored
Executable file
121
my-app/node_modules/webpack-dev-server/client/utils/createSocketURL.js
generated
vendored
Executable file
|
@ -0,0 +1,121 @@
|
|||
/**
|
||||
* @param {{ protocol?: string, auth?: string, hostname?: string, port?: string, pathname?: string, search?: string, hash?: string, slashes?: boolean }} objURL
|
||||
* @returns {string}
|
||||
*/
|
||||
function format(objURL) {
|
||||
var protocol = objURL.protocol || "";
|
||||
if (protocol && protocol.substr(-1) !== ":") {
|
||||
protocol += ":";
|
||||
}
|
||||
var auth = objURL.auth || "";
|
||||
if (auth) {
|
||||
auth = encodeURIComponent(auth);
|
||||
auth = auth.replace(/%3A/i, ":");
|
||||
auth += "@";
|
||||
}
|
||||
var host = "";
|
||||
if (objURL.hostname) {
|
||||
host = auth + (objURL.hostname.indexOf(":") === -1 ? objURL.hostname : "[".concat(objURL.hostname, "]"));
|
||||
if (objURL.port) {
|
||||
host += ":".concat(objURL.port);
|
||||
}
|
||||
}
|
||||
var pathname = objURL.pathname || "";
|
||||
if (objURL.slashes) {
|
||||
host = "//".concat(host || "");
|
||||
if (pathname && pathname.charAt(0) !== "/") {
|
||||
pathname = "/".concat(pathname);
|
||||
}
|
||||
} else if (!host) {
|
||||
host = "";
|
||||
}
|
||||
var search = objURL.search || "";
|
||||
if (search && search.charAt(0) !== "?") {
|
||||
search = "?".concat(search);
|
||||
}
|
||||
var hash = objURL.hash || "";
|
||||
if (hash && hash.charAt(0) !== "#") {
|
||||
hash = "#".concat(hash);
|
||||
}
|
||||
pathname = pathname.replace(/[?#]/g,
|
||||
/**
|
||||
* @param {string} match
|
||||
* @returns {string}
|
||||
*/
|
||||
function (match) {
|
||||
return encodeURIComponent(match);
|
||||
});
|
||||
search = search.replace("#", "%23");
|
||||
return "".concat(protocol).concat(host).concat(pathname).concat(search).concat(hash);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {URL & { fromCurrentScript?: boolean }} parsedURL
|
||||
* @returns {string}
|
||||
*/
|
||||
function createSocketURL(parsedURL) {
|
||||
var hostname = parsedURL.hostname;
|
||||
|
||||
// Node.js module parses it as `::`
|
||||
// `new URL(urlString, [baseURLString])` parses it as '[::]'
|
||||
var isInAddrAny = hostname === "0.0.0.0" || hostname === "::" || hostname === "[::]";
|
||||
|
||||
// why do we need this check?
|
||||
// hostname n/a for file protocol (example, when using electron, ionic)
|
||||
// see: https://github.com/webpack/webpack-dev-server/pull/384
|
||||
if (isInAddrAny && self.location.hostname && self.location.protocol.indexOf("http") === 0) {
|
||||
hostname = self.location.hostname;
|
||||
}
|
||||
var socketURLProtocol = parsedURL.protocol || self.location.protocol;
|
||||
|
||||
// When https is used in the app, secure web sockets are always necessary because the browser doesn't accept non-secure web sockets.
|
||||
if (socketURLProtocol === "auto:" || hostname && isInAddrAny && self.location.protocol === "https:") {
|
||||
socketURLProtocol = self.location.protocol;
|
||||
}
|
||||
socketURLProtocol = socketURLProtocol.replace(/^(?:http|.+-extension|file)/i, "ws");
|
||||
var socketURLAuth = "";
|
||||
|
||||
// `new URL(urlString, [baseURLstring])` doesn't have `auth` property
|
||||
// Parse authentication credentials in case we need them
|
||||
if (parsedURL.username) {
|
||||
socketURLAuth = parsedURL.username;
|
||||
|
||||
// Since HTTP basic authentication does not allow empty username,
|
||||
// we only include password if the username is not empty.
|
||||
if (parsedURL.password) {
|
||||
// Result: <username>:<password>
|
||||
socketURLAuth = socketURLAuth.concat(":", parsedURL.password);
|
||||
}
|
||||
}
|
||||
|
||||
// In case the host is a raw IPv6 address, it can be enclosed in
|
||||
// the brackets as the brackets are needed in the final URL string.
|
||||
// Need to remove those as url.format blindly adds its own set of brackets
|
||||
// if the host string contains colons. That would lead to non-working
|
||||
// double brackets (e.g. [[::]]) host
|
||||
//
|
||||
// All of these web socket url params are optionally passed in through resourceQuery,
|
||||
// so we need to fall back to the default if they are not provided
|
||||
var socketURLHostname = (hostname || self.location.hostname || "localhost").replace(/^\[(.*)\]$/, "$1");
|
||||
var socketURLPort = parsedURL.port;
|
||||
if (!socketURLPort || socketURLPort === "0") {
|
||||
socketURLPort = self.location.port;
|
||||
}
|
||||
|
||||
// If path is provided it'll be passed in via the resourceQuery as a
|
||||
// query param so it has to be parsed out of the querystring in order for the
|
||||
// client to open the socket to the correct location.
|
||||
var socketURLPathname = "/ws";
|
||||
if (parsedURL.pathname && !parsedURL.fromCurrentScript) {
|
||||
socketURLPathname = parsedURL.pathname;
|
||||
}
|
||||
return format({
|
||||
protocol: socketURLProtocol,
|
||||
auth: socketURLAuth,
|
||||
hostname: socketURLHostname,
|
||||
port: socketURLPort,
|
||||
pathname: socketURLPathname,
|
||||
slashes: true
|
||||
});
|
||||
}
|
||||
export default createSocketURL;
|
24
my-app/node_modules/webpack-dev-server/client/utils/getCurrentScriptSource.js
generated
vendored
Executable file
24
my-app/node_modules/webpack-dev-server/client/utils/getCurrentScriptSource.js
generated
vendored
Executable file
|
@ -0,0 +1,24 @@
|
|||
/**
|
||||
* @returns {string}
|
||||
*/
|
||||
function getCurrentScriptSource() {
|
||||
// `document.currentScript` is the most accurate way to find the current script,
|
||||
// but is not supported in all browsers.
|
||||
if (document.currentScript) {
|
||||
return document.currentScript.getAttribute("src");
|
||||
}
|
||||
|
||||
// Fallback to getting all scripts running in the document.
|
||||
var scriptElements = document.scripts || [];
|
||||
var scriptElementsWithSrc = Array.prototype.filter.call(scriptElements, function (element) {
|
||||
return element.getAttribute("src");
|
||||
});
|
||||
if (scriptElementsWithSrc.length > 0) {
|
||||
var currentScript = scriptElementsWithSrc[scriptElementsWithSrc.length - 1];
|
||||
return currentScript.getAttribute("src");
|
||||
}
|
||||
|
||||
// Fail as there was no script to use.
|
||||
throw new Error("[webpack-dev-server] Failed to get current script source.");
|
||||
}
|
||||
export default getCurrentScriptSource;
|
35
my-app/node_modules/webpack-dev-server/client/utils/log.js
generated
vendored
Executable file
35
my-app/node_modules/webpack-dev-server/client/utils/log.js
generated
vendored
Executable file
|
@ -0,0 +1,35 @@
|
|||
import logger from "../modules/logger/index.js";
|
||||
var name = "webpack-dev-server";
|
||||
// default level is set on the client side, so it does not need
|
||||
// to be set by the CLI or API
|
||||
var defaultLevel = "info";
|
||||
|
||||
// options new options, merge with old options
|
||||
/**
|
||||
* @param {false | true | "none" | "error" | "warn" | "info" | "log" | "verbose"} level
|
||||
* @returns {void}
|
||||
*/
|
||||
function setLogLevel(level) {
|
||||
logger.configureDefaultLogger({
|
||||
level: level
|
||||
});
|
||||
}
|
||||
setLogLevel(defaultLevel);
|
||||
var log = logger.getLogger(name);
|
||||
var logEnabledFeatures = function logEnabledFeatures(features) {
|
||||
var enabledFeatures = Object.keys(features);
|
||||
if (!features || enabledFeatures.length === 0) {
|
||||
return;
|
||||
}
|
||||
var logString = "Server started:";
|
||||
|
||||
// Server started: Hot Module Replacement enabled, Live Reloading enabled, Overlay disabled.
|
||||
for (var i = 0; i < enabledFeatures.length; i++) {
|
||||
var key = enabledFeatures[i];
|
||||
logString += " ".concat(key, " ").concat(features[key] ? "enabled" : "disabled", ",");
|
||||
}
|
||||
// replace last comma with a period
|
||||
logString = logString.slice(0, -1).concat(".");
|
||||
log.info(logString);
|
||||
};
|
||||
export { log, logEnabledFeatures, setLogLevel };
|
36
my-app/node_modules/webpack-dev-server/client/utils/parseURL.js
generated
vendored
Executable file
36
my-app/node_modules/webpack-dev-server/client/utils/parseURL.js
generated
vendored
Executable file
|
@ -0,0 +1,36 @@
|
|||
import getCurrentScriptSource from "./getCurrentScriptSource.js";
|
||||
|
||||
/**
|
||||
* @param {string} resourceQuery
|
||||
* @returns {{ [key: string]: string | boolean }}
|
||||
*/
|
||||
function parseURL(resourceQuery) {
|
||||
/** @type {{ [key: string]: string }} */
|
||||
var options = {};
|
||||
if (typeof resourceQuery === "string" && resourceQuery !== "") {
|
||||
var searchParams = resourceQuery.slice(1).split("&");
|
||||
for (var i = 0; i < searchParams.length; i++) {
|
||||
var pair = searchParams[i].split("=");
|
||||
options[pair[0]] = decodeURIComponent(pair[1]);
|
||||
}
|
||||
} else {
|
||||
// Else, get the url from the <script> this file was called with.
|
||||
var scriptSource = getCurrentScriptSource();
|
||||
var scriptSourceURL;
|
||||
try {
|
||||
// The placeholder `baseURL` with `window.location.href`,
|
||||
// is to allow parsing of path-relative or protocol-relative URLs,
|
||||
// and will have no effect if `scriptSource` is a fully valid URL.
|
||||
scriptSourceURL = new URL(scriptSource, self.location.href);
|
||||
} catch (error) {
|
||||
// URL parsing failed, do nothing.
|
||||
// We will still proceed to see if we can recover using `resourceQuery`
|
||||
}
|
||||
if (scriptSourceURL) {
|
||||
options = scriptSourceURL;
|
||||
options.fromCurrentScript = true;
|
||||
}
|
||||
}
|
||||
return options;
|
||||
}
|
||||
export default parseURL;
|
63
my-app/node_modules/webpack-dev-server/client/utils/reloadApp.js
generated
vendored
Executable file
63
my-app/node_modules/webpack-dev-server/client/utils/reloadApp.js
generated
vendored
Executable file
|
@ -0,0 +1,63 @@
|
|||
import hotEmitter from "webpack/hot/emitter.js";
|
||||
import { log } from "./log.js";
|
||||
|
||||
/** @typedef {import("../index").Options} Options
|
||||
/** @typedef {import("../index").Status} Status
|
||||
|
||||
/**
|
||||
* @param {Options} options
|
||||
* @param {Status} status
|
||||
*/
|
||||
function reloadApp(_ref, status) {
|
||||
var hot = _ref.hot,
|
||||
liveReload = _ref.liveReload;
|
||||
if (status.isUnloading) {
|
||||
return;
|
||||
}
|
||||
var currentHash = status.currentHash,
|
||||
previousHash = status.previousHash;
|
||||
var isInitial = currentHash.indexOf( /** @type {string} */previousHash) >= 0;
|
||||
if (isInitial) {
|
||||
return;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {Window} rootWindow
|
||||
* @param {number} intervalId
|
||||
*/
|
||||
function applyReload(rootWindow, intervalId) {
|
||||
clearInterval(intervalId);
|
||||
log.info("App updated. Reloading...");
|
||||
rootWindow.location.reload();
|
||||
}
|
||||
var search = self.location.search.toLowerCase();
|
||||
var allowToHot = search.indexOf("webpack-dev-server-hot=false") === -1;
|
||||
var allowToLiveReload = search.indexOf("webpack-dev-server-live-reload=false") === -1;
|
||||
if (hot && allowToHot) {
|
||||
log.info("App hot update...");
|
||||
hotEmitter.emit("webpackHotUpdate", status.currentHash);
|
||||
if (typeof self !== "undefined" && self.window) {
|
||||
// broadcast update to window
|
||||
self.postMessage("webpackHotUpdate".concat(status.currentHash), "*");
|
||||
}
|
||||
}
|
||||
// allow refreshing the page only if liveReload isn't disabled
|
||||
else if (liveReload && allowToLiveReload) {
|
||||
var rootWindow = self;
|
||||
|
||||
// use parent window for reload (in case we're in an iframe with no valid src)
|
||||
var intervalId = self.setInterval(function () {
|
||||
if (rootWindow.location.protocol !== "about:") {
|
||||
// reload immediately if protocol is valid
|
||||
applyReload(rootWindow, intervalId);
|
||||
} else {
|
||||
rootWindow = rootWindow.parent;
|
||||
if (rootWindow.parent === rootWindow) {
|
||||
// if parent equals current window we've reached the root which would continue forever, so trigger a reload anyways
|
||||
applyReload(rootWindow, intervalId);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
export default reloadApp;
|
16
my-app/node_modules/webpack-dev-server/client/utils/sendMessage.js
generated
vendored
Executable file
16
my-app/node_modules/webpack-dev-server/client/utils/sendMessage.js
generated
vendored
Executable file
|
@ -0,0 +1,16 @@
|
|||
/* global __resourceQuery WorkerGlobalScope */
|
||||
|
||||
// Send messages to the outside, so plugins can consume it.
|
||||
/**
|
||||
* @param {string} type
|
||||
* @param {any} [data]
|
||||
*/
|
||||
function sendMsg(type, data) {
|
||||
if (typeof self !== "undefined" && (typeof WorkerGlobalScope === "undefined" || !(self instanceof WorkerGlobalScope))) {
|
||||
self.postMessage({
|
||||
type: "webpack".concat(type),
|
||||
data: data
|
||||
}, "*");
|
||||
}
|
||||
}
|
||||
export default sendMsg;
|
18
my-app/node_modules/webpack-dev-server/client/utils/stripAnsi.js
generated
vendored
Executable file
18
my-app/node_modules/webpack-dev-server/client/utils/stripAnsi.js
generated
vendored
Executable file
|
@ -0,0 +1,18 @@
|
|||
var ansiRegex = new RegExp(["[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)", "(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-nq-uy=><~]))"].join("|"), "g");
|
||||
|
||||
/**
|
||||
*
|
||||
* Strip [ANSI escape codes](https://en.wikipedia.org/wiki/ANSI_escape_code) from a string.
|
||||
* Adapted from code originally released by Sindre Sorhus
|
||||
* Licensed the MIT License
|
||||
*
|
||||
* @param {string} string
|
||||
* @return {string}
|
||||
*/
|
||||
function stripAnsi(string) {
|
||||
if (typeof string !== "string") {
|
||||
throw new TypeError("Expected a `string`, got `".concat(typeof string, "`"));
|
||||
}
|
||||
return string.replace(ansiRegex, "");
|
||||
}
|
||||
export default stripAnsi;
|
3593
my-app/node_modules/webpack-dev-server/lib/Server.js
generated
vendored
Executable file
3593
my-app/node_modules/webpack-dev-server/lib/Server.js
generated
vendored
Executable file
File diff suppressed because it is too large
Load diff
133
my-app/node_modules/webpack-dev-server/lib/getPort.js
generated
vendored
Executable file
133
my-app/node_modules/webpack-dev-server/lib/getPort.js
generated
vendored
Executable file
|
@ -0,0 +1,133 @@
|
|||
"use strict";
|
||||
|
||||
/*
|
||||
* Based on the packages get-port https://www.npmjs.com/package/get-port
|
||||
* and portfinder https://www.npmjs.com/package/portfinder
|
||||
* The code structure is similar to get-port, but it searches
|
||||
* ports deterministically like portfinder
|
||||
*/
|
||||
const net = require("net");
|
||||
const os = require("os");
|
||||
|
||||
const minPort = 1024;
|
||||
const maxPort = 65_535;
|
||||
|
||||
/**
|
||||
* @return {Set<string|undefined>}
|
||||
*/
|
||||
const getLocalHosts = () => {
|
||||
const interfaces = os.networkInterfaces();
|
||||
|
||||
// Add undefined value for createServer function to use default host,
|
||||
// and default IPv4 host in case createServer defaults to IPv6.
|
||||
// eslint-disable-next-line no-undefined
|
||||
const results = new Set([undefined, "0.0.0.0"]);
|
||||
|
||||
for (const _interface of Object.values(interfaces)) {
|
||||
if (_interface) {
|
||||
for (const config of _interface) {
|
||||
results.add(config.address);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return results;
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {number} basePort
|
||||
* @param {string | undefined} host
|
||||
* @return {Promise<number>}
|
||||
*/
|
||||
const checkAvailablePort = (basePort, host) =>
|
||||
new Promise((resolve, reject) => {
|
||||
const server = net.createServer();
|
||||
server.unref();
|
||||
server.on("error", reject);
|
||||
|
||||
server.listen(basePort, host, () => {
|
||||
// Next line should return AdressInfo because we're calling it after listen() and before close()
|
||||
const { port } = /** @type {import("net").AddressInfo} */ (
|
||||
server.address()
|
||||
);
|
||||
server.close(() => {
|
||||
resolve(port);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
/**
|
||||
* @param {number} port
|
||||
* @param {Set<string|undefined>} hosts
|
||||
* @return {Promise<number>}
|
||||
*/
|
||||
const getAvailablePort = async (port, hosts) => {
|
||||
/**
|
||||
* Errors that mean that host is not available.
|
||||
* @type {Set<string | undefined>}
|
||||
*/
|
||||
const nonExistentInterfaceErrors = new Set(["EADDRNOTAVAIL", "EINVAL"]);
|
||||
/* Check if the post is available on every local host name */
|
||||
for (const host of hosts) {
|
||||
try {
|
||||
await checkAvailablePort(port, host); // eslint-disable-line no-await-in-loop
|
||||
} catch (error) {
|
||||
/* We throw an error only if the interface exists */
|
||||
if (
|
||||
!nonExistentInterfaceErrors.has(
|
||||
/** @type {NodeJS.ErrnoException} */ (error).code
|
||||
)
|
||||
) {
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return port;
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {number} basePort
|
||||
* @param {string=} host
|
||||
* @return {Promise<number>}
|
||||
*/
|
||||
async function getPorts(basePort, host) {
|
||||
if (basePort < minPort || basePort > maxPort) {
|
||||
throw new Error(`Port number must lie between ${minPort} and ${maxPort}`);
|
||||
}
|
||||
|
||||
let port = basePort;
|
||||
const localhosts = getLocalHosts();
|
||||
let hosts;
|
||||
if (host && !localhosts.has(host)) {
|
||||
hosts = new Set([host]);
|
||||
} else {
|
||||
/* If the host is equivalent to localhost
|
||||
we need to check every equivalent host
|
||||
else the port might falsely appear as available
|
||||
on some operating systems */
|
||||
hosts = localhosts;
|
||||
}
|
||||
/** @type {Set<string | undefined>} */
|
||||
const portUnavailableErrors = new Set(["EADDRINUSE", "EACCES"]);
|
||||
while (port <= maxPort) {
|
||||
try {
|
||||
const availablePort = await getAvailablePort(port, hosts); // eslint-disable-line no-await-in-loop
|
||||
return availablePort;
|
||||
} catch (error) {
|
||||
/* Try next port if port is busy; throw for any other error */
|
||||
if (
|
||||
!portUnavailableErrors.has(
|
||||
/** @type {NodeJS.ErrnoException} */ (error).code
|
||||
)
|
||||
) {
|
||||
throw error;
|
||||
}
|
||||
port += 1;
|
||||
}
|
||||
}
|
||||
|
||||
throw new Error("No available ports found");
|
||||
}
|
||||
|
||||
module.exports = getPorts;
|
1266
my-app/node_modules/webpack-dev-server/lib/options.json
generated
vendored
Executable file
1266
my-app/node_modules/webpack-dev-server/lib/options.json
generated
vendored
Executable file
File diff suppressed because it is too large
Load diff
18
my-app/node_modules/webpack-dev-server/lib/servers/BaseServer.js
generated
vendored
Executable file
18
my-app/node_modules/webpack-dev-server/lib/servers/BaseServer.js
generated
vendored
Executable file
|
@ -0,0 +1,18 @@
|
|||
"use strict";
|
||||
|
||||
/** @typedef {import("../Server").ClientConnection} ClientConnection */
|
||||
|
||||
// base class that users should extend if they are making their own
|
||||
// server implementation
|
||||
module.exports = class BaseServer {
|
||||
/**
|
||||
* @param {import("../Server")} server
|
||||
*/
|
||||
constructor(server) {
|
||||
/** @type {import("../Server")} */
|
||||
this.server = server;
|
||||
|
||||
/** @type {ClientConnection[]} */
|
||||
this.clients = [];
|
||||
}
|
||||
};
|
126
my-app/node_modules/webpack-dev-server/lib/servers/SockJSServer.js
generated
vendored
Executable file
126
my-app/node_modules/webpack-dev-server/lib/servers/SockJSServer.js
generated
vendored
Executable file
|
@ -0,0 +1,126 @@
|
|||
"use strict";
|
||||
|
||||
const sockjs = require("sockjs");
|
||||
const BaseServer = require("./BaseServer");
|
||||
|
||||
/** @typedef {import("../Server").WebSocketServerConfiguration} WebSocketServerConfiguration */
|
||||
/** @typedef {import("../Server").ClientConnection} ClientConnection */
|
||||
|
||||
// Workaround for sockjs@~0.3.19
|
||||
// sockjs will remove Origin header, however Origin header is required for checking host.
|
||||
// See https://github.com/webpack/webpack-dev-server/issues/1604 for more information
|
||||
{
|
||||
// @ts-ignore
|
||||
const SockjsSession = require("sockjs/lib/transport").Session;
|
||||
const decorateConnection = SockjsSession.prototype.decorateConnection;
|
||||
|
||||
/**
|
||||
* @param {import("http").IncomingMessage} req
|
||||
*/
|
||||
// eslint-disable-next-line func-names
|
||||
SockjsSession.prototype.decorateConnection = function (req) {
|
||||
decorateConnection.call(this, req);
|
||||
|
||||
const connection = this.connection;
|
||||
|
||||
if (
|
||||
connection.headers &&
|
||||
!("origin" in connection.headers) &&
|
||||
"origin" in req.headers
|
||||
) {
|
||||
connection.headers.origin = req.headers.origin;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
module.exports = class SockJSServer extends BaseServer {
|
||||
// options has: error (function), debug (function), server (http/s server), path (string)
|
||||
/**
|
||||
* @param {import("../Server")} server
|
||||
*/
|
||||
constructor(server) {
|
||||
super(server);
|
||||
|
||||
const webSocketServerOptions =
|
||||
/** @type {NonNullable<WebSocketServerConfiguration["options"]>} */
|
||||
(
|
||||
/** @type {WebSocketServerConfiguration} */
|
||||
(this.server.options.webSocketServer).options
|
||||
);
|
||||
|
||||
/**
|
||||
* @param {NonNullable<WebSocketServerConfiguration["options"]>} options
|
||||
* @returns {string}
|
||||
*/
|
||||
const getSockjsUrl = (options) => {
|
||||
if (typeof options.sockjsUrl !== "undefined") {
|
||||
return options.sockjsUrl;
|
||||
}
|
||||
|
||||
return "/__webpack_dev_server__/sockjs.bundle.js";
|
||||
};
|
||||
|
||||
this.implementation = sockjs.createServer({
|
||||
// Use provided up-to-date sockjs-client
|
||||
sockjs_url: getSockjsUrl(webSocketServerOptions),
|
||||
// Default logger is very annoy. Limit useless logs.
|
||||
/**
|
||||
* @param {string} severity
|
||||
* @param {string} line
|
||||
*/
|
||||
log: (severity, line) => {
|
||||
if (severity === "error") {
|
||||
this.server.logger.error(line);
|
||||
} else if (severity === "info") {
|
||||
this.server.logger.log(line);
|
||||
} else {
|
||||
this.server.logger.debug(line);
|
||||
}
|
||||
},
|
||||
});
|
||||
|
||||
/**
|
||||
* @param {import("sockjs").ServerOptions & { path?: string }} options
|
||||
* @returns {string | undefined}
|
||||
*/
|
||||
const getPrefix = (options) => {
|
||||
if (typeof options.prefix !== "undefined") {
|
||||
return options.prefix;
|
||||
}
|
||||
|
||||
return options.path;
|
||||
};
|
||||
|
||||
const options = {
|
||||
...webSocketServerOptions,
|
||||
prefix: getPrefix(webSocketServerOptions),
|
||||
};
|
||||
|
||||
this.implementation.installHandlers(
|
||||
/** @type {import("http").Server} */ (this.server.server),
|
||||
options
|
||||
);
|
||||
|
||||
this.implementation.on("connection", (client) => {
|
||||
// @ts-ignore
|
||||
// Implement the the same API as for `ws`
|
||||
client.send = client.write;
|
||||
// @ts-ignore
|
||||
client.terminate = client.close;
|
||||
|
||||
this.clients.push(/** @type {ClientConnection} */ (client));
|
||||
|
||||
client.on("close", () => {
|
||||
this.clients.splice(
|
||||
this.clients.indexOf(/** @type {ClientConnection} */ (client)),
|
||||
1
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
// @ts-ignore
|
||||
this.implementation.close = (callback) => {
|
||||
callback();
|
||||
};
|
||||
}
|
||||
};
|
105
my-app/node_modules/webpack-dev-server/lib/servers/WebsocketServer.js
generated
vendored
Executable file
105
my-app/node_modules/webpack-dev-server/lib/servers/WebsocketServer.js
generated
vendored
Executable file
|
@ -0,0 +1,105 @@
|
|||
"use strict";
|
||||
|
||||
const WebSocket = require("ws");
|
||||
const BaseServer = require("./BaseServer");
|
||||
|
||||
/** @typedef {import("../Server").WebSocketServerConfiguration} WebSocketServerConfiguration */
|
||||
/** @typedef {import("../Server").ClientConnection} ClientConnection */
|
||||
|
||||
module.exports = class WebsocketServer extends BaseServer {
|
||||
static heartbeatInterval = 1000;
|
||||
|
||||
/**
|
||||
* @param {import("../Server")} server
|
||||
*/
|
||||
constructor(server) {
|
||||
super(server);
|
||||
|
||||
/** @type {import("ws").ServerOptions} */
|
||||
const options = {
|
||||
.../** @type {WebSocketServerConfiguration} */
|
||||
(this.server.options.webSocketServer).options,
|
||||
clientTracking: false,
|
||||
};
|
||||
const isNoServerMode =
|
||||
typeof options.port === "undefined" &&
|
||||
typeof options.server === "undefined";
|
||||
|
||||
if (isNoServerMode) {
|
||||
options.noServer = true;
|
||||
}
|
||||
|
||||
this.implementation = new WebSocket.Server(options);
|
||||
|
||||
/** @type {import("http").Server} */
|
||||
(this.server.server).on(
|
||||
"upgrade",
|
||||
/**
|
||||
* @param {import("http").IncomingMessage} req
|
||||
* @param {import("stream").Duplex} sock
|
||||
* @param {Buffer} head
|
||||
*/
|
||||
(req, sock, head) => {
|
||||
if (!this.implementation.shouldHandle(req)) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.implementation.handleUpgrade(req, sock, head, (connection) => {
|
||||
this.implementation.emit("connection", connection, req);
|
||||
});
|
||||
}
|
||||
);
|
||||
|
||||
this.implementation.on(
|
||||
"error",
|
||||
/**
|
||||
* @param {Error} err
|
||||
*/
|
||||
(err) => {
|
||||
this.server.logger.error(err.message);
|
||||
}
|
||||
);
|
||||
|
||||
const interval = setInterval(() => {
|
||||
this.clients.forEach(
|
||||
/**
|
||||
* @param {ClientConnection} client
|
||||
*/
|
||||
(client) => {
|
||||
if (client.isAlive === false) {
|
||||
client.terminate();
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
client.isAlive = false;
|
||||
client.ping(() => {});
|
||||
}
|
||||
);
|
||||
}, WebsocketServer.heartbeatInterval);
|
||||
|
||||
this.implementation.on(
|
||||
"connection",
|
||||
/**
|
||||
* @param {ClientConnection} client
|
||||
*/
|
||||
(client) => {
|
||||
this.clients.push(client);
|
||||
|
||||
client.isAlive = true;
|
||||
|
||||
client.on("pong", () => {
|
||||
client.isAlive = true;
|
||||
});
|
||||
|
||||
client.on("close", () => {
|
||||
this.clients.splice(this.clients.indexOf(client), 1);
|
||||
});
|
||||
}
|
||||
);
|
||||
|
||||
this.implementation.on("close", () => {
|
||||
clearInterval(interval);
|
||||
});
|
||||
}
|
||||
};
|
26
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/Changes.md
generated
vendored
Executable file
26
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/Changes.md
generated
vendored
Executable file
|
@ -0,0 +1,26 @@
|
|||
### 2.1.0 - 2023-05-23
|
||||
|
||||
- un-deprecate IPv6.toString() and make it an alias to toRFC5952String()
|
||||
- add reserved 198.18.0.0/15 block
|
||||
- add reserved blocks in 2001: space
|
||||
|
||||
|
||||
### 2.0.1 - 2020-01-06
|
||||
|
||||
- add support for deprecated IPv4 compatible IPv6 addresses #142
|
||||
- drop node 8 testing, add v14
|
||||
- fix parseInt for decimal, octal, hex
|
||||
- add support for classful (2,3 octet) IPv4
|
||||
|
||||
|
||||
### 2.0.0 - 2019-10-13
|
||||
|
||||
- use es6 templates instead of concatenated strings
|
||||
- lint: update tests with no-var
|
||||
- lint: allow no-cond-assign with extra parens
|
||||
- es6: replace var with const/let
|
||||
- update README with es6 examples #125
|
||||
- replace nodeunit with mocha
|
||||
- rewrite in JS, drop CoffeeScript
|
||||
|
||||
### 1.9.1 - 2019-07-03
|
19
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/LICENSE
generated
vendored
Executable file
19
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/LICENSE
generated
vendored
Executable file
|
@ -0,0 +1,19 @@
|
|||
Copyright (C) 2011-2017 whitequark <whitequark@whitequark.org>
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
228
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/README.md
generated
vendored
Executable file
228
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/README.md
generated
vendored
Executable file
|
@ -0,0 +1,228 @@
|
|||
# ipaddr.js — an IPv6 and IPv4 address manipulation library
|
||||
|
||||
[](https://github.com/whitequark/ipaddr.js/actions?query=workflow%3A%22CI+Tests%22)
|
||||
|
||||
ipaddr.js is a small (1.9K minified and gzipped) library for manipulating
|
||||
IP addresses in JavaScript environments. It runs on both CommonJS runtimes
|
||||
(e.g. [nodejs]) and in a web browser.
|
||||
|
||||
ipaddr.js allows you to verify and parse string representation of an IP
|
||||
address, match it against a CIDR range or range list, determine if it falls
|
||||
into some reserved ranges (examples include loopback and private ranges),
|
||||
and convert between IPv4 and IPv4-mapped IPv6 addresses.
|
||||
|
||||
[nodejs]: http://nodejs.org
|
||||
|
||||
## Installation
|
||||
|
||||
`npm install ipaddr.js`
|
||||
|
||||
or
|
||||
|
||||
`bower install ipaddr.js`
|
||||
|
||||
## Older Node support
|
||||
|
||||
Use 2.x release for nodejs versions 10+.
|
||||
Use the 1.x release for versions of nodejs older than 10.
|
||||
|
||||
## API
|
||||
|
||||
ipaddr.js defines one object in the global scope: `ipaddr`. In CommonJS,
|
||||
it is exported from the module:
|
||||
|
||||
```js
|
||||
const ipaddr = require('ipaddr.js');
|
||||
```
|
||||
|
||||
The API consists of several global methods and two classes: ipaddr.IPv6 and ipaddr.IPv4.
|
||||
|
||||
### Global methods
|
||||
|
||||
There are three global methods defined: `ipaddr.isValid`, `ipaddr.parse` and
|
||||
`ipaddr.process`. All of them receive a string as a single parameter.
|
||||
|
||||
The `ipaddr.isValid` method returns `true` if the address is a valid IPv4 or
|
||||
IPv6 address, and `false` otherwise. It does not throw any exceptions.
|
||||
|
||||
The `ipaddr.parse` method returns an object representing the IP address,
|
||||
or throws an `Error` if the passed string is not a valid representation of an
|
||||
IP address.
|
||||
|
||||
The `ipaddr.process` method works just like the `ipaddr.parse` one, but it
|
||||
automatically converts IPv4-mapped IPv6 addresses to their IPv4 counterparts
|
||||
before returning. It is useful when you have a Node.js instance listening
|
||||
on an IPv6 socket, and the `net.ivp6.bindv6only` sysctl parameter (or its
|
||||
equivalent on non-Linux OS) is set to 0. In this case, you can accept IPv4
|
||||
connections on your IPv6-only socket, but the remote address will be mangled.
|
||||
Use `ipaddr.process` method to automatically demangle it.
|
||||
|
||||
### Object representation
|
||||
|
||||
Parsing methods return an object which descends from `ipaddr.IPv6` or
|
||||
`ipaddr.IPv4`. These objects share some properties, but most of them differ.
|
||||
|
||||
#### Shared properties
|
||||
|
||||
One can determine the type of address by calling `addr.kind()`. It will return
|
||||
either `"ipv6"` or `"ipv4"`.
|
||||
|
||||
An address can be converted back to its string representation with `addr.toString()`.
|
||||
Note that this method:
|
||||
* does not return the original string used to create the object (in fact, there is
|
||||
no way of getting that string)
|
||||
* returns a compact representation (when it is applicable)
|
||||
|
||||
A `match(range, bits)` method can be used to check if the address falls into a
|
||||
certain CIDR range. Note that an address can be (obviously) matched only against an address of the same type.
|
||||
|
||||
For example:
|
||||
|
||||
```js
|
||||
const addr = ipaddr.parse('2001:db8:1234::1');
|
||||
const range = ipaddr.parse('2001:db8::');
|
||||
|
||||
addr.match(range, 32); // => true
|
||||
```
|
||||
|
||||
Alternatively, `match` can also be called as `match([range, bits])`. In this way, it can be used together with the `parseCIDR(string)` method, which parses an IP address together with a CIDR range.
|
||||
|
||||
For example:
|
||||
|
||||
```js
|
||||
const addr = ipaddr.parse('2001:db8:1234::1');
|
||||
|
||||
addr.match(ipaddr.parseCIDR('2001:db8::/32')); // => true
|
||||
```
|
||||
|
||||
A `range()` method returns one of predefined names for several special ranges defined by IP protocols. The exact names (and their respective CIDR ranges) can be looked up in the source: [IPv6 ranges] and [IPv4 ranges]. Some common ones include `"unicast"` (the default one) and `"reserved"`.
|
||||
|
||||
You can match against your own range list by using
|
||||
`ipaddr.subnetMatch(address, rangeList, defaultName)` method. It can work with a mix of IPv6 or IPv4 addresses, and accepts a name-to-subnet map as the range list. For example:
|
||||
|
||||
```js
|
||||
const rangeList = {
|
||||
documentationOnly: [ ipaddr.parse('2001:db8::'), 32 ],
|
||||
tunnelProviders: [
|
||||
[ ipaddr.parse('2001:470::'), 32 ], // he.net
|
||||
[ ipaddr.parse('2001:5c0::'), 32 ] // freenet6
|
||||
]
|
||||
};
|
||||
ipaddr.subnetMatch(ipaddr.parse('2001:470:8:66::1'), rangeList, 'unknown'); // => "tunnelProviders"
|
||||
```
|
||||
|
||||
The addresses can be converted to their byte representation with `toByteArray()`. (Actually, JavaScript mostly does not know about byte buffers. They are emulated with arrays of numbers, each in range of 0..255.)
|
||||
|
||||
```js
|
||||
const bytes = ipaddr.parse('2a00:1450:8007::68').toByteArray(); // ipv6.google.com
|
||||
bytes // => [42, 0x00, 0x14, 0x50, 0x80, 0x07, 0x00, <zeroes...>, 0x00, 0x68 ]
|
||||
```
|
||||
|
||||
The `ipaddr.IPv4` and `ipaddr.IPv6` objects have some methods defined, too. All of them have the same interface for both protocols, and are similar to global methods.
|
||||
|
||||
`ipaddr.IPvX.isValid(string)` can be used to check if the string is a valid address for particular protocol, and `ipaddr.IPvX.parse(string)` is the error-throwing parser.
|
||||
|
||||
`ipaddr.IPvX.isValid(string)` uses the same format for parsing as the POSIX `inet_ntoa` function, which accepts unusual formats like `0xc0.168.1.1` or `0x10000000`. The function `ipaddr.IPv4.isValidFourPartDecimal(string)` validates the IPv4 address and also ensures that it is written in four-part decimal format.
|
||||
|
||||
[IPv6 ranges]: https://github.com/whitequark/ipaddr.js/blob/master/lib/ipaddr.js#L530
|
||||
[IPv4 ranges]: https://github.com/whitequark/ipaddr.js/blob/master/lib/ipaddr.js#L182
|
||||
|
||||
#### IPv6 properties
|
||||
|
||||
Sometimes you will want to convert IPv6 not to a compact string representation (with the `::` substitution); the `toNormalizedString()` method will return an address where all zeroes are explicit.
|
||||
|
||||
For example:
|
||||
|
||||
```js
|
||||
const addr = ipaddr.parse('2001:0db8::0001');
|
||||
addr.toString(); // => '2001:db8::1'
|
||||
addr.toNormalizedString(); // => '2001:db8:0:0:0:0:0:1'
|
||||
```
|
||||
|
||||
The `isIPv4MappedAddress()` method will return `true` if this address is an IPv4-mapped
|
||||
one, and `toIPv4Address()` will return an IPv4 object address.
|
||||
|
||||
To access the underlying binary representation of the address, use `addr.parts`.
|
||||
|
||||
```js
|
||||
const addr = ipaddr.parse('2001:db8:10::1234:DEAD');
|
||||
addr.parts // => [0x2001, 0xdb8, 0x10, 0, 0, 0, 0x1234, 0xdead]
|
||||
```
|
||||
|
||||
A IPv6 zone index can be accessed via `addr.zoneId`:
|
||||
|
||||
```js
|
||||
const addr = ipaddr.parse('2001:db8::%eth0');
|
||||
addr.zoneId // => 'eth0'
|
||||
```
|
||||
|
||||
#### IPv4 properties
|
||||
|
||||
`toIPv4MappedAddress()` will return a corresponding IPv4-mapped IPv6 address.
|
||||
|
||||
To access the underlying representation of the address, use `addr.octets`.
|
||||
|
||||
```js
|
||||
const addr = ipaddr.parse('192.168.1.1');
|
||||
addr.octets // => [192, 168, 1, 1]
|
||||
```
|
||||
|
||||
`prefixLengthFromSubnetMask()` will return a CIDR prefix length for a valid IPv4 netmask or
|
||||
null if the netmask is not valid.
|
||||
|
||||
```js
|
||||
ipaddr.IPv4.parse('255.255.255.240').prefixLengthFromSubnetMask() == 28
|
||||
ipaddr.IPv4.parse('255.192.164.0').prefixLengthFromSubnetMask() == null
|
||||
```
|
||||
|
||||
`subnetMaskFromPrefixLength()` will return an IPv4 netmask for a valid CIDR prefix length.
|
||||
|
||||
```js
|
||||
ipaddr.IPv4.subnetMaskFromPrefixLength(24) == '255.255.255.0'
|
||||
ipaddr.IPv4.subnetMaskFromPrefixLength(29) == '255.255.255.248'
|
||||
```
|
||||
|
||||
`broadcastAddressFromCIDR()` will return the broadcast address for a given IPv4 interface and netmask in CIDR notation.
|
||||
```js
|
||||
ipaddr.IPv4.broadcastAddressFromCIDR('172.0.0.1/24') == '172.0.0.255'
|
||||
```
|
||||
`networkAddressFromCIDR()` will return the network address for a given IPv4 interface and netmask in CIDR notation.
|
||||
```js
|
||||
ipaddr.IPv4.networkAddressFromCIDR('172.0.0.1/24') == '172.0.0.0'
|
||||
```
|
||||
|
||||
#### Conversion
|
||||
|
||||
IPv4 and IPv6 can be converted bidirectionally to and from network byte order (MSB) byte arrays.
|
||||
|
||||
The `fromByteArray()` method will take an array and create an appropriate IPv4 or IPv6 object
|
||||
if the input satisfies the requirements. For IPv4 it has to be an array of four 8-bit values,
|
||||
while for IPv6 it has to be an array of sixteen 8-bit values.
|
||||
|
||||
For example:
|
||||
```js
|
||||
const addr = ipaddr.fromByteArray([0x7f, 0, 0, 1]);
|
||||
addr.toString(); // => '127.0.0.1'
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```js
|
||||
const addr = ipaddr.fromByteArray([0x20, 1, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1])
|
||||
addr.toString(); // => '2001:db8::1'
|
||||
```
|
||||
|
||||
Both objects also offer a `toByteArray()` method, which returns an array in network byte order (MSB).
|
||||
|
||||
For example:
|
||||
```js
|
||||
const addr = ipaddr.parse('127.0.0.1');
|
||||
addr.toByteArray(); // => [0x7f, 0, 0, 1]
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```js
|
||||
const addr = ipaddr.parse('2001:db8::1');
|
||||
addr.toByteArray(); // => [0x20, 1, 0xd, 0xb8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]
|
||||
```
|
1
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/ipaddr.min.js
generated
vendored
Executable file
1
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/ipaddr.min.js
generated
vendored
Executable file
File diff suppressed because one or more lines are too long
1000
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/lib/ipaddr.js
generated
vendored
Executable file
1000
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/lib/ipaddr.js
generated
vendored
Executable file
File diff suppressed because it is too large
Load diff
68
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/lib/ipaddr.js.d.ts
generated
vendored
Executable file
68
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/lib/ipaddr.js.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,68 @@
|
|||
declare module "ipaddr.js" {
|
||||
type IPvXRangeDefaults = 'unicast' | 'unspecified' | 'multicast' | 'linkLocal' | 'loopback' | 'reserved';
|
||||
type IPv4Range = IPvXRangeDefaults | 'broadcast' | 'carrierGradeNat' | 'private';
|
||||
type IPv6Range = IPvXRangeDefaults | 'uniqueLocal' | 'ipv4Mapped' | 'rfc6145' | 'rfc6052' | '6to4' | 'teredo';
|
||||
|
||||
interface RangeList<T> {
|
||||
[name: string]: [T, number] | [T, number][];
|
||||
}
|
||||
|
||||
// Common methods/properties for IPv4 and IPv6 classes.
|
||||
class IP {
|
||||
prefixLengthFromSubnetMask(): number | null;
|
||||
toByteArray(): number[];
|
||||
toNormalizedString(): string;
|
||||
toString(): string;
|
||||
}
|
||||
|
||||
namespace Address {
|
||||
export function fromByteArray(bytes: number[]): IPv4 | IPv6;
|
||||
export function isValid(addr: string): boolean;
|
||||
export function parse(addr: string): IPv4 | IPv6;
|
||||
export function parseCIDR(mask: string): [IPv4 | IPv6, number];
|
||||
export function process(addr: string): IPv4 | IPv6;
|
||||
export function subnetMatch(addr: IPv4 | IPv6, rangeList: RangeList<IPv4 | IPv6>, defaultName?: string): string;
|
||||
|
||||
export class IPv4 extends IP {
|
||||
static broadcastAddressFromCIDR(addr: string): IPv4;
|
||||
static isIPv4(addr: string): boolean;
|
||||
static isValidFourPartDecimal(addr: string): boolean;
|
||||
static isValid(addr: string): boolean;
|
||||
static networkAddressFromCIDR(addr: string): IPv4;
|
||||
static parse(addr: string): IPv4;
|
||||
static parseCIDR(addr: string): [IPv4, number];
|
||||
static subnetMaskFromPrefixLength(prefix: number): IPv4;
|
||||
constructor(octets: number[]);
|
||||
octets: number[]
|
||||
|
||||
kind(): 'ipv4';
|
||||
match(what: IPv4 | IPv6 | [IPv4 | IPv6, number], bits?: number): boolean;
|
||||
range(): IPv4Range;
|
||||
subnetMatch(rangeList: RangeList<IPv4>, defaultName?: string): string;
|
||||
toIPv4MappedAddress(): IPv6;
|
||||
}
|
||||
|
||||
export class IPv6 extends IP {
|
||||
static broadcastAddressFromCIDR(addr: string): IPv6;
|
||||
static isIPv6(addr: string): boolean;
|
||||
static isValid(addr: string): boolean;
|
||||
static networkAddressFromCIDR(addr: string): IPv6;
|
||||
static parse(addr: string): IPv6;
|
||||
static parseCIDR(addr: string): [IPv6, number];
|
||||
static subnetMaskFromPrefixLength(prefix: number): IPv6;
|
||||
constructor(parts: number[]);
|
||||
parts: number[]
|
||||
zoneId?: string
|
||||
|
||||
isIPv4MappedAddress(): boolean;
|
||||
kind(): 'ipv6';
|
||||
match(what: IPv4 | IPv6 | [IPv4 | IPv6, number], bits?: number): boolean;
|
||||
range(): IPv6Range;
|
||||
subnetMatch(rangeList: RangeList<IPv6>, defaultName?: string): string;
|
||||
toIPv4Address(): IPv4;
|
||||
toRFC5952String(): string;
|
||||
}
|
||||
}
|
||||
|
||||
export = Address;
|
||||
}
|
38
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/package.json
generated
vendored
Executable file
38
my-app/node_modules/webpack-dev-server/node_modules/ipaddr.js/package.json
generated
vendored
Executable file
|
@ -0,0 +1,38 @@
|
|||
{
|
||||
"name": "ipaddr.js",
|
||||
"description": "A library for manipulating IPv4 and IPv6 addresses in JavaScript.",
|
||||
"version": "2.1.0",
|
||||
"author": "whitequark <whitequark@whitequark.org>",
|
||||
"directories": {
|
||||
"lib": "./lib"
|
||||
},
|
||||
"dependencies": {},
|
||||
"devDependencies": {
|
||||
"eslint": "*",
|
||||
"mocha": "*",
|
||||
"uglify-es": "*"
|
||||
},
|
||||
"scripts": {
|
||||
"lint": "npx eslint lib test",
|
||||
"lintfix": "npx eslint --fix lib test",
|
||||
"build": "npx uglifyjs --compress --mangle --wrap=window -o ipaddr.min.js lib/ipaddr.js",
|
||||
"test": "npx _mocha"
|
||||
},
|
||||
"files": [
|
||||
"lib/",
|
||||
"LICENSE",
|
||||
"ipaddr.min.js"
|
||||
],
|
||||
"keywords": [
|
||||
"ip",
|
||||
"ipv4",
|
||||
"ipv6"
|
||||
],
|
||||
"repository": "git://github.com/whitequark/ipaddr.js",
|
||||
"main": "./lib/ipaddr.js",
|
||||
"engines": {
|
||||
"node": ">= 10"
|
||||
},
|
||||
"license": "MIT",
|
||||
"types": "./lib/ipaddr.js.d.ts"
|
||||
}
|
20
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/LICENSE
generated
vendored
Executable file
20
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/LICENSE
generated
vendored
Executable file
|
@ -0,0 +1,20 @@
|
|||
Copyright JS Foundation and other contributors
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining
|
||||
a copy of this software and associated documentation files (the
|
||||
'Software'), to deal in the Software without restriction, including
|
||||
without limitation the rights to use, copy, modify, merge, publish,
|
||||
distribute, sublicense, and/or sell copies of the Software, and to
|
||||
permit persons to whom the Software is furnished to do so, subject to
|
||||
the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be
|
||||
included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
542
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/README.md
generated
vendored
Executable file
542
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/README.md
generated
vendored
Executable file
|
@ -0,0 +1,542 @@
|
|||
<div align="center">
|
||||
<a href="https://github.com/webpack/webpack">
|
||||
<img width="200" height="200" src="https://webpack.js.org/assets/icon-square-big.svg">
|
||||
</a>
|
||||
</div>
|
||||
|
||||
[![npm][npm]][npm-url]
|
||||
[![node][node]][node-url]
|
||||
[![deps][deps]][deps-url]
|
||||
[![tests][tests]][tests-url]
|
||||
[![coverage][cover]][cover-url]
|
||||
[![chat][chat]][chat-url]
|
||||
[![size][size]][size-url]
|
||||
|
||||
# webpack-dev-middleware
|
||||
|
||||
An express-style development middleware for use with [webpack](https://webpack.js.org)
|
||||
bundles and allows for serving of the files emitted from webpack.
|
||||
This should be used for **development only**.
|
||||
|
||||
Some of the benefits of using this middleware include:
|
||||
|
||||
- No files are written to disk, rather it handles files in memory
|
||||
- If files changed in watch mode, the middleware delays requests until compiling
|
||||
has completed.
|
||||
- Supports hot module reload (HMR).
|
||||
|
||||
## Getting Started
|
||||
|
||||
First thing's first, install the module:
|
||||
|
||||
```console
|
||||
npm install webpack-dev-middleware --save-dev
|
||||
```
|
||||
|
||||
_Note: We do not recommend installing this module globally._
|
||||
|
||||
## Usage
|
||||
|
||||
```js
|
||||
const webpack = require("webpack");
|
||||
const middleware = require("webpack-dev-middleware");
|
||||
const compiler = webpack({
|
||||
// webpack options
|
||||
});
|
||||
const express = require("express");
|
||||
const app = express();
|
||||
|
||||
app.use(
|
||||
middleware(compiler, {
|
||||
// webpack-dev-middleware options
|
||||
})
|
||||
);
|
||||
|
||||
app.listen(3000, () => console.log("Example app listening on port 3000!"));
|
||||
```
|
||||
|
||||
See [below](#other-servers) for an example of use with fastify.
|
||||
|
||||
## Options
|
||||
|
||||
| Name | Type | Default | Description |
|
||||
| :-----------------------------------------: | :-----------------------: | :-------------------------------------------: | :------------------------------------------------------------------------------------------------------------------- |
|
||||
| **[`methods`](#methods)** | `Array` | `[ 'GET', 'HEAD' ]` | Allows to pass the list of HTTP request methods accepted by the middleware |
|
||||
| **[`headers`](#headers)** | `Array\|Object\|Function` | `undefined` | Allows to pass custom HTTP headers on each request. |
|
||||
| **[`index`](#index)** | `Boolean\|String` | `index.html` | If `false` (but not `undefined`), the server will not respond to requests to the root URL. |
|
||||
| **[`mimeTypes`](#mimetypes)** | `Object` | `undefined` | Allows to register custom mime types or extension mappings. |
|
||||
| **[`publicPath`](#publicpath)** | `String` | `output.publicPath` (from a configuration) | The public path that the middleware is bound to. |
|
||||
| **[`stats`](#stats)** | `Boolean\|String\|Object` | `stats` (from a configuration) | Stats options object or preset name. |
|
||||
| **[`serverSideRender`](#serversiderender)** | `Boolean` | `undefined` | Instructs the module to enable or disable the server-side rendering mode. |
|
||||
| **[`writeToDisk`](#writetodisk)** | `Boolean\|Function` | `false` | Instructs the module to write files to the configured location on disk as specified in your `webpack` configuration. |
|
||||
| **[`outputFileSystem`](#outputfilesystem)** | `Object` | [`memfs`](https://github.com/streamich/memfs) | Set the default file system which will be used by webpack as primary destination of generated files. |
|
||||
|
||||
The middleware accepts an `options` Object. The following is a property reference for the Object.
|
||||
|
||||
### methods
|
||||
|
||||
Type: `Array`
|
||||
Default: `[ 'GET', 'HEAD' ]`
|
||||
|
||||
This property allows a user to pass the list of HTTP request methods accepted by the middleware\*\*.
|
||||
|
||||
### headers
|
||||
|
||||
Type: `Array|Object|Function`
|
||||
Default: `undefined`
|
||||
|
||||
This property allows a user to pass custom HTTP headers on each request.
|
||||
eg. `{ "X-Custom-Header": "yes" }`
|
||||
|
||||
or
|
||||
|
||||
```js
|
||||
webpackDevMiddleware(compiler, {
|
||||
headers: () => {
|
||||
return {
|
||||
"Last-Modified": new Date(),
|
||||
};
|
||||
},
|
||||
});
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```js
|
||||
webpackDevMiddleware(compiler, {
|
||||
headers: (req, res, context) => {
|
||||
res.setHeader("Last-Modified", new Date());
|
||||
},
|
||||
});
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```js
|
||||
webpackDevMiddleware(compiler, {
|
||||
headers: [
|
||||
{
|
||||
key: "X-custom-header"
|
||||
value: "foo"
|
||||
},
|
||||
{
|
||||
key: "Y-custom-header",
|
||||
value: "bar"
|
||||
}
|
||||
]
|
||||
},
|
||||
});
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```js
|
||||
webpackDevMiddleware(compiler, {
|
||||
headers: () => [
|
||||
{
|
||||
key: "X-custom-header"
|
||||
value: "foo"
|
||||
},
|
||||
{
|
||||
key: "Y-custom-header",
|
||||
value: "bar"
|
||||
}
|
||||
]
|
||||
},
|
||||
});
|
||||
```
|
||||
|
||||
### index
|
||||
|
||||
Type: `Boolean|String`
|
||||
Default: `index.html`
|
||||
|
||||
If `false` (but not `undefined`), the server will not respond to requests to the root URL.
|
||||
|
||||
### mimeTypes
|
||||
|
||||
Type: `Object`
|
||||
Default: `undefined`
|
||||
|
||||
This property allows a user to register custom mime types or extension mappings.
|
||||
eg. `mimeTypes: { phtml: 'text/html' }`.
|
||||
|
||||
Please see the documentation for [`mime-types`](https://github.com/jshttp/mime-types) for more information.
|
||||
|
||||
### publicPath
|
||||
|
||||
Type: `String`
|
||||
Default: `output.publicPath` (from a configuration)
|
||||
|
||||
The public path that the middleware is bound to.
|
||||
|
||||
_Best Practice: use the same `publicPath` defined in your webpack config. For more information about `publicPath`, please see [the webpack documentation](https://webpack.js.org/guides/public-path)._
|
||||
|
||||
### stats
|
||||
|
||||
Type: `Boolean|String|Object`
|
||||
Default: `stats` (from a configuration)
|
||||
|
||||
Stats options object or preset name.
|
||||
|
||||
### serverSideRender
|
||||
|
||||
Type: `Boolean`
|
||||
Default: `undefined`
|
||||
|
||||
Instructs the module to enable or disable the server-side rendering mode.
|
||||
Please see [Server-Side Rendering](#server-side-rendering) for more information.
|
||||
|
||||
### writeToDisk
|
||||
|
||||
Type: `Boolean|Function`
|
||||
Default: `false`
|
||||
|
||||
If `true`, the option will instruct the module to write files to the configured location on disk as specified in your `webpack` config file.
|
||||
_Setting `writeToDisk: true` won't change the behavior of the `webpack-dev-middleware`, and bundle files accessed through the browser will still be served from memory._
|
||||
This option provides the same capabilities as the [`WriteFilePlugin`](https://github.com/gajus/write-file-webpack-plugin/pulls).
|
||||
|
||||
This option also accepts a `Function` value, which can be used to filter which files are written to disk.
|
||||
The function follows the same premise as [`Array#filter`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/filter) in which a return value of `false` _will not_ write the file, and a return value of `true` _will_ write the file to disk. eg.
|
||||
|
||||
```js
|
||||
const webpack = require("webpack");
|
||||
const configuration = {
|
||||
/* Webpack configuration */
|
||||
};
|
||||
const compiler = webpack(configuration);
|
||||
|
||||
middleware(compiler, {
|
||||
writeToDisk: (filePath) => {
|
||||
return /superman\.css$/.test(filePath);
|
||||
},
|
||||
});
|
||||
```
|
||||
|
||||
### outputFileSystem
|
||||
|
||||
Type: `Object`
|
||||
Default: [memfs](https://github.com/streamich/memfs)
|
||||
|
||||
Set the default file system which will be used by webpack as primary destination of generated files.
|
||||
This option isn't affected by the [writeToDisk](#writeToDisk) option.
|
||||
|
||||
You have to provide `.join()` and `mkdirp` method to the `outputFileSystem` instance manually for compatibility with `webpack@4`.
|
||||
|
||||
This can be done simply by using `path.join`:
|
||||
|
||||
```js
|
||||
const webpack = require("webpack");
|
||||
const path = require("path");
|
||||
const myOutputFileSystem = require("my-fs");
|
||||
const mkdirp = require("mkdirp");
|
||||
|
||||
myOutputFileSystem.join = path.join.bind(path); // no need to bind
|
||||
myOutputFileSystem.mkdirp = mkdirp.bind(mkdirp); // no need to bind
|
||||
|
||||
const compiler = webpack({
|
||||
/* Webpack configuration */
|
||||
});
|
||||
|
||||
middleware(compiler, { outputFileSystem: myOutputFileSystem });
|
||||
```
|
||||
|
||||
## API
|
||||
|
||||
`webpack-dev-middleware` also provides convenience methods that can be use to
|
||||
interact with the middleware at runtime:
|
||||
|
||||
### `close(callback)`
|
||||
|
||||
Instructs `webpack-dev-middleware` instance to stop watching for file changes.
|
||||
|
||||
#### Parameters
|
||||
|
||||
##### `callback`
|
||||
|
||||
Type: `Function`
|
||||
Required: `No`
|
||||
|
||||
A function executed once the middleware has stopped watching.
|
||||
|
||||
```js
|
||||
const express = require("express");
|
||||
const webpack = require("webpack");
|
||||
const compiler = webpack({
|
||||
/* Webpack configuration */
|
||||
});
|
||||
const middleware = require("webpack-dev-middleware");
|
||||
const instance = middleware(compiler);
|
||||
|
||||
const app = new express();
|
||||
|
||||
app.use(instance);
|
||||
|
||||
setTimeout(() => {
|
||||
// Says `webpack` to stop watch changes
|
||||
instance.close();
|
||||
}, 1000);
|
||||
```
|
||||
|
||||
### `invalidate(callback)`
|
||||
|
||||
Instructs `webpack-dev-middleware` instance to recompile the bundle, e.g. after a change to the configuration.
|
||||
|
||||
#### Parameters
|
||||
|
||||
##### `callback`
|
||||
|
||||
Type: `Function`
|
||||
Required: `No`
|
||||
|
||||
A function executed once the middleware has invalidated.
|
||||
|
||||
```js
|
||||
const express = require("express");
|
||||
const webpack = require("webpack");
|
||||
const compiler = webpack({
|
||||
/* Webpack configuration */
|
||||
});
|
||||
const middleware = require("webpack-dev-middleware");
|
||||
const instance = middleware(compiler);
|
||||
|
||||
const app = new express();
|
||||
|
||||
app.use(instance);
|
||||
|
||||
setTimeout(() => {
|
||||
// After a short delay the configuration is changed and a banner plugin is added to the config
|
||||
new webpack.BannerPlugin("A new banner").apply(compiler);
|
||||
|
||||
// Recompile the bundle with the banner plugin:
|
||||
instance.invalidate();
|
||||
}, 1000);
|
||||
```
|
||||
|
||||
### `waitUntilValid(callback)`
|
||||
|
||||
Executes a callback function when the compiler bundle is valid, typically after
|
||||
compilation.
|
||||
|
||||
#### Parameters
|
||||
|
||||
##### `callback`
|
||||
|
||||
Type: `Function`
|
||||
Required: `No`
|
||||
|
||||
A function executed when the bundle becomes valid.
|
||||
If the bundle is valid at the time of calling, the callback is executed immediately.
|
||||
|
||||
```js
|
||||
const express = require("express");
|
||||
const webpack = require("webpack");
|
||||
const compiler = webpack({
|
||||
/* Webpack configuration */
|
||||
});
|
||||
const middleware = require("webpack-dev-middleware");
|
||||
const instance = middleware(compiler);
|
||||
|
||||
const app = new express();
|
||||
|
||||
app.use(instance);
|
||||
|
||||
instance.waitUntilValid(() => {
|
||||
console.log("Package is in a valid state");
|
||||
});
|
||||
```
|
||||
|
||||
### `getFilenameFromUrl(url)`
|
||||
|
||||
Get filename from URL.
|
||||
|
||||
#### Parameters
|
||||
|
||||
##### `url`
|
||||
|
||||
Type: `String`
|
||||
Required: `Yes`
|
||||
|
||||
URL for the requested file.
|
||||
|
||||
```js
|
||||
const express = require("express");
|
||||
const webpack = require("webpack");
|
||||
const compiler = webpack({
|
||||
/* Webpack configuration */
|
||||
});
|
||||
const middleware = require("webpack-dev-middleware");
|
||||
const instance = middleware(compiler);
|
||||
|
||||
const app = new express();
|
||||
|
||||
app.use(instance);
|
||||
|
||||
instance.waitUntilValid(() => {
|
||||
const filename = instance.getFilenameFromUrl("/bundle.js");
|
||||
|
||||
console.log(`Filename is ${filename}`);
|
||||
});
|
||||
```
|
||||
|
||||
## Known Issues
|
||||
|
||||
### Multiple Successive Builds
|
||||
|
||||
Watching will frequently cause multiple compilations
|
||||
as the bundle changes during compilation. This is due in part to cross-platform
|
||||
differences in file watchers, so that webpack doesn't loose file changes when
|
||||
watched files change rapidly. If you run into this situation, please make use of
|
||||
the [`TimeFixPlugin`](https://github.com/egoist/time-fix-plugin).
|
||||
|
||||
## Server-Side Rendering
|
||||
|
||||
_Note: this feature is experimental and may be removed or changed completely in the future._
|
||||
|
||||
In order to develop an app using server-side rendering, we need access to the
|
||||
[`stats`](https://github.com/webpack/docs/wiki/node.js-api#stats), which is
|
||||
generated with each build.
|
||||
|
||||
With server-side rendering enabled, `webpack-dev-middleware` sets the `stats` to `res.locals.webpack.devMiddleware.context.stats`
|
||||
and the filesystem to `res.locals.webpack.devMiddleware.context.outputFileSystem` before invoking the next middleware,
|
||||
allowing a developer to render the page body and manage the response to clients.
|
||||
|
||||
_Note: Requests for bundle files will still be handled by
|
||||
`webpack-dev-middleware` and all requests will be pending until the build
|
||||
process is finished with server-side rendering enabled._
|
||||
|
||||
Example Implementation:
|
||||
|
||||
```js
|
||||
const express = require("express");
|
||||
const webpack = require("webpack");
|
||||
const compiler = webpack({
|
||||
/* Webpack configuration */
|
||||
});
|
||||
const isObject = require("is-object");
|
||||
const middleware = require("webpack-dev-middleware");
|
||||
|
||||
const app = new express();
|
||||
|
||||
// This function makes server rendering of asset references consistent with different webpack chunk/entry configurations
|
||||
function normalizeAssets(assets) {
|
||||
if (isObject(assets)) {
|
||||
return Object.values(assets);
|
||||
}
|
||||
|
||||
return Array.isArray(assets) ? assets : [assets];
|
||||
}
|
||||
|
||||
app.use(middleware(compiler, { serverSideRender: true }));
|
||||
|
||||
// The following middleware would not be invoked until the latest build is finished.
|
||||
app.use((req, res) => {
|
||||
const { devMiddleware } = res.locals.webpack;
|
||||
const outputFileSystem = devMiddleware.context.outputFileSystem;
|
||||
const jsonWebpackStats = devMiddleware.context.stats.toJson();
|
||||
const { assetsByChunkName, outputPath } = jsonWebpackStats;
|
||||
|
||||
// Then use `assetsByChunkName` for server-side rendering
|
||||
// For example, if you have only one main chunk:
|
||||
res.send(`
|
||||
<html>
|
||||
<head>
|
||||
<title>My App</title>
|
||||
<style>
|
||||
${normalizeAssets(assetsByChunkName.main)
|
||||
.filter((path) => path.endsWith(".css"))
|
||||
.map((path) => outputFileSystem.readFileSync(path.join(outputPath, path)))
|
||||
.join("\n")}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div id="root"></div>
|
||||
${normalizeAssets(assetsByChunkName.main)
|
||||
.filter((path) => path.endsWith(".js"))
|
||||
.map((path) => `<script src="${path}"></script>`)
|
||||
.join("\n")}
|
||||
</body>
|
||||
</html>
|
||||
`);
|
||||
});
|
||||
```
|
||||
|
||||
## Support
|
||||
|
||||
We do our best to keep Issues in the repository focused on bugs, features, and
|
||||
needed modifications to the code for the module. Because of that, we ask users
|
||||
with general support, "how-to", or "why isn't this working" questions to try one
|
||||
of the other support channels that are available.
|
||||
|
||||
Your first-stop-shop for support for webpack-dev-server should by the excellent
|
||||
[documentation][docs-url] for the module. If you see an opportunity for improvement
|
||||
of those docs, please head over to the [webpack.js.org repo][wjo-url] and open a
|
||||
pull request.
|
||||
|
||||
From there, we encourage users to visit the [webpack Gitter chat][chat-url] and
|
||||
talk to the fine folks there. If your quest for answers comes up dry in chat,
|
||||
head over to [StackOverflow][stack-url] and do a quick search or open a new
|
||||
question. Remember; It's always much easier to answer questions that include your
|
||||
`webpack.config.js` and relevant files!
|
||||
|
||||
If you're twitter-savvy you can tweet [#webpack][hash-url] with your question
|
||||
and someone should be able to reach out and lend a hand.
|
||||
|
||||
If you have discovered a :bug:, have a feature suggestion, or would like to see
|
||||
a modification, please feel free to create an issue on Github. _Note: The issue
|
||||
template isn't optional, so please be sure not to remove it, and please fill it
|
||||
out completely._
|
||||
|
||||
## Other servers
|
||||
|
||||
Examples of use with other servers will follow here.
|
||||
|
||||
### Fastify
|
||||
|
||||
Fastify interop will require the use of `fastify-express` instead of `middie` for providing middleware support. As the authors of `fastify-express` recommend, this should only be used as a stopgap while full Fastify support is worked on.
|
||||
|
||||
```js
|
||||
const fastify = require("fastify")();
|
||||
const webpack = require("webpack");
|
||||
const webpackConfig = require("./webpack.config.js");
|
||||
const devMiddleware = require("webpack-dev-middleware");
|
||||
|
||||
const compiler = webpack(webpackConfig);
|
||||
const { publicPath } = webpackConfig.output;
|
||||
|
||||
(async () => {
|
||||
await fastify.register(require("fastify-express"));
|
||||
await fastify.use(devMiddleware(compiler, { publicPath }));
|
||||
await fastify.listen(3000);
|
||||
})();
|
||||
```
|
||||
|
||||
## Contributing
|
||||
|
||||
Please take a moment to read our contributing guidelines if you haven't yet done so.
|
||||
|
||||
[CONTRIBUTING](./CONTRIBUTING.md)
|
||||
|
||||
## License
|
||||
|
||||
[MIT](./LICENSE)
|
||||
|
||||
[npm]: https://img.shields.io/npm/v/webpack-dev-middleware.svg
|
||||
[npm-url]: https://npmjs.com/package/webpack-dev-middleware
|
||||
[node]: https://img.shields.io/node/v/webpack-dev-middleware.svg
|
||||
[node-url]: https://nodejs.org
|
||||
[deps]: https://david-dm.org/webpack/webpack-dev-middleware.svg
|
||||
[deps-url]: https://david-dm.org/webpack/webpack-dev-middleware
|
||||
[tests]: https://github.com/webpack/webpack-dev-middleware/workflows/webpack-dev-middleware/badge.svg
|
||||
[tests-url]: https://github.com/webpack/webpack-dev-middleware/actions
|
||||
[cover]: https://codecov.io/gh/webpack/webpack-dev-middleware/branch/master/graph/badge.svg
|
||||
[cover-url]: https://codecov.io/gh/webpack/webpack-dev-middleware
|
||||
[chat]: https://badges.gitter.im/webpack/webpack.svg
|
||||
[chat-url]: https://gitter.im/webpack/webpack
|
||||
[size]: https://packagephobia.com/badge?p=webpack-dev-middleware
|
||||
[size-url]: https://packagephobia.com/result?p=webpack-dev-middleware
|
||||
[docs-url]: https://webpack.js.org/guides/development/#using-webpack-dev-middleware
|
||||
[hash-url]: https://twitter.com/search?q=webpack
|
||||
[middleware-url]: https://github.com/webpack/webpack-dev-middleware
|
||||
[stack-url]: https://stackoverflow.com/questions/tagged/webpack-dev-middleware
|
||||
[wjo-url]: https://github.com/webpack/webpack.js.org
|
305
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/index.js
generated
vendored
Executable file
305
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/index.js
generated
vendored
Executable file
|
@ -0,0 +1,305 @@
|
|||
"use strict";
|
||||
|
||||
const {
|
||||
validate
|
||||
} = require("schema-utils");
|
||||
|
||||
const mime = require("mime-types");
|
||||
|
||||
const middleware = require("./middleware");
|
||||
|
||||
const getFilenameFromUrl = require("./utils/getFilenameFromUrl");
|
||||
|
||||
const setupHooks = require("./utils/setupHooks");
|
||||
|
||||
const setupWriteToDisk = require("./utils/setupWriteToDisk");
|
||||
|
||||
const setupOutputFileSystem = require("./utils/setupOutputFileSystem");
|
||||
|
||||
const ready = require("./utils/ready");
|
||||
|
||||
const schema = require("./options.json");
|
||||
|
||||
const noop = () => {};
|
||||
/** @typedef {import("schema-utils/declarations/validate").Schema} Schema */
|
||||
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
|
||||
/** @typedef {import("webpack").Configuration} Configuration */
|
||||
|
||||
/** @typedef {import("webpack").Stats} Stats */
|
||||
|
||||
/** @typedef {import("webpack").MultiStats} MultiStats */
|
||||
|
||||
/**
|
||||
* @typedef {Object} ExtendedServerResponse
|
||||
* @property {{ webpack?: { devMiddleware?: Context<IncomingMessage, ServerResponse> } }} [locals]
|
||||
*/
|
||||
|
||||
/** @typedef {import("http").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("http").ServerResponse & ExtendedServerResponse} ServerResponse */
|
||||
|
||||
/**
|
||||
* @callback NextFunction
|
||||
* @param {any} [err]
|
||||
* @return {void}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {NonNullable<Configuration["watchOptions"]>} WatchOptions
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Compiler["watching"]} Watching
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {ReturnType<Compiler["watch"]>} MultiWatching
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Compiler["outputFileSystem"] & { createReadStream?: import("fs").createReadStream, statSync?: import("fs").statSync, lstat?: import("fs").lstat, readFileSync?: import("fs").readFileSync }} OutputFileSystem
|
||||
*/
|
||||
|
||||
/** @typedef {ReturnType<Compiler["getInfrastructureLogger"]>} Logger */
|
||||
|
||||
/**
|
||||
* @callback Callback
|
||||
* @param {Stats | MultiStats} [stats]
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Object} Context
|
||||
* @property {boolean} state
|
||||
* @property {Stats | MultiStats | undefined} stats
|
||||
* @property {Callback[]} callbacks
|
||||
* @property {Options<Request, Response>} options
|
||||
* @property {Compiler | MultiCompiler} compiler
|
||||
* @property {Watching | MultiWatching} watching
|
||||
* @property {Logger} logger
|
||||
* @property {OutputFileSystem} outputFileSystem
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Record<string, string | number> | Array<{ key: string, value: number | string }> | ((req: Request, res: Response, context: Context<Request, Response>) => void | undefined | Record<string, string | number>) | undefined} Headers
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Object} Options
|
||||
* @property {{[key: string]: string}} [mimeTypes]
|
||||
* @property {boolean | ((targetPath: string) => boolean)} [writeToDisk]
|
||||
* @property {string} [methods]
|
||||
* @property {Headers<Request, Response>} [headers]
|
||||
* @property {NonNullable<Configuration["output"]>["publicPath"]} [publicPath]
|
||||
* @property {Configuration["stats"]} [stats]
|
||||
* @property {boolean} [serverSideRender]
|
||||
* @property {OutputFileSystem} [outputFileSystem]
|
||||
* @property {boolean | string} [index]
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @callback Middleware
|
||||
* @param {Request} req
|
||||
* @param {Response} res
|
||||
* @param {NextFunction} next
|
||||
* @return {Promise<void>}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @callback GetFilenameFromUrl
|
||||
* @param {string} url
|
||||
* @returns {string | undefined}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @callback WaitUntilValid
|
||||
* @param {Callback} callback
|
||||
*/
|
||||
|
||||
/**
|
||||
* @callback Invalidate
|
||||
* @param {Callback} callback
|
||||
*/
|
||||
|
||||
/**
|
||||
* @callback Close
|
||||
* @param {(err: Error | null | undefined) => void} callback
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Object} AdditionalMethods
|
||||
* @property {GetFilenameFromUrl} getFilenameFromUrl
|
||||
* @property {WaitUntilValid} waitUntilValid
|
||||
* @property {Invalidate} invalidate
|
||||
* @property {Close} close
|
||||
* @property {Context<Request, Response>} context
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Middleware<Request, Response> & AdditionalMethods<Request, Response>} API
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Compiler | MultiCompiler} compiler
|
||||
* @param {Options<Request, Response>} [options]
|
||||
* @returns {API<Request, Response>}
|
||||
*/
|
||||
|
||||
|
||||
function wdm(compiler, options = {}) {
|
||||
validate(
|
||||
/** @type {Schema} */
|
||||
schema, options, {
|
||||
name: "Dev Middleware",
|
||||
baseDataPath: "options"
|
||||
});
|
||||
const {
|
||||
mimeTypes
|
||||
} = options;
|
||||
|
||||
if (mimeTypes) {
|
||||
const {
|
||||
types
|
||||
} = mime; // mimeTypes from user provided options should take priority
|
||||
// over existing, known types
|
||||
// @ts-ignore
|
||||
|
||||
mime.types = { ...types,
|
||||
...mimeTypes
|
||||
};
|
||||
}
|
||||
/**
|
||||
* @type {Context<Request, Response>}
|
||||
*/
|
||||
|
||||
|
||||
const context = {
|
||||
state: false,
|
||||
// eslint-disable-next-line no-undefined
|
||||
stats: undefined,
|
||||
callbacks: [],
|
||||
options,
|
||||
compiler,
|
||||
// @ts-ignore
|
||||
// eslint-disable-next-line no-undefined
|
||||
watching: undefined,
|
||||
logger: compiler.getInfrastructureLogger("webpack-dev-middleware"),
|
||||
// @ts-ignore
|
||||
// eslint-disable-next-line no-undefined
|
||||
outputFileSystem: undefined
|
||||
};
|
||||
setupHooks(context);
|
||||
|
||||
if (options.writeToDisk) {
|
||||
setupWriteToDisk(context);
|
||||
}
|
||||
|
||||
setupOutputFileSystem(context); // Start watching
|
||||
|
||||
if (
|
||||
/** @type {Compiler} */
|
||||
context.compiler.watching) {
|
||||
context.watching =
|
||||
/** @type {Compiler} */
|
||||
context.compiler.watching;
|
||||
} else {
|
||||
/**
|
||||
* @type {WatchOptions | WatchOptions[]}
|
||||
*/
|
||||
let watchOptions;
|
||||
/**
|
||||
* @param {Error | null | undefined} error
|
||||
*/
|
||||
|
||||
const errorHandler = error => {
|
||||
if (error) {
|
||||
// TODO: improve that in future
|
||||
// For example - `writeToDisk` can throw an error and right now it is ends watching.
|
||||
// We can improve that and keep watching active, but it is require API on webpack side.
|
||||
// Let's implement that in webpack@5 because it is rare case.
|
||||
context.logger.error(error);
|
||||
}
|
||||
};
|
||||
|
||||
if (Array.isArray(
|
||||
/** @type {MultiCompiler} */
|
||||
context.compiler.compilers)) {
|
||||
watchOptions =
|
||||
/** @type {MultiCompiler} */
|
||||
context.compiler.compilers.map(
|
||||
/**
|
||||
* @param {Compiler} childCompiler
|
||||
* @returns {WatchOptions}
|
||||
*/
|
||||
childCompiler => childCompiler.options.watchOptions || {});
|
||||
context.watching =
|
||||
/** @type {MultiWatching} */
|
||||
context.compiler.watch(
|
||||
/** @type {WatchOptions}} */
|
||||
watchOptions, errorHandler);
|
||||
} else {
|
||||
watchOptions =
|
||||
/** @type {Compiler} */
|
||||
context.compiler.options.watchOptions || {};
|
||||
context.watching =
|
||||
/** @type {Watching} */
|
||||
context.compiler.watch(watchOptions, errorHandler);
|
||||
}
|
||||
}
|
||||
|
||||
const instance =
|
||||
/** @type {API<Request, Response>} */
|
||||
middleware(context); // API
|
||||
|
||||
/** @type {API<Request, Response>} */
|
||||
|
||||
instance.getFilenameFromUrl =
|
||||
/**
|
||||
* @param {string} url
|
||||
* @returns {string|undefined}
|
||||
*/
|
||||
url => getFilenameFromUrl(context, url);
|
||||
/** @type {API<Request, Response>} */
|
||||
|
||||
|
||||
instance.waitUntilValid = (callback = noop) => {
|
||||
ready(context, callback);
|
||||
};
|
||||
/** @type {API<Request, Response>} */
|
||||
|
||||
|
||||
instance.invalidate = (callback = noop) => {
|
||||
ready(context, callback);
|
||||
context.watching.invalidate();
|
||||
};
|
||||
/** @type {API<Request, Response>} */
|
||||
|
||||
|
||||
instance.close = (callback = noop) => {
|
||||
context.watching.close(callback);
|
||||
};
|
||||
/** @type {API<Request, Response>} */
|
||||
|
||||
|
||||
instance.context = context;
|
||||
return instance;
|
||||
}
|
||||
|
||||
module.exports = wdm;
|
237
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/middleware.js
generated
vendored
Executable file
237
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/middleware.js
generated
vendored
Executable file
|
@ -0,0 +1,237 @@
|
|||
"use strict";
|
||||
|
||||
const path = require("path");
|
||||
|
||||
const mime = require("mime-types");
|
||||
|
||||
const parseRange = require("range-parser");
|
||||
|
||||
const getFilenameFromUrl = require("./utils/getFilenameFromUrl");
|
||||
|
||||
const {
|
||||
getHeaderNames,
|
||||
getHeaderFromRequest,
|
||||
getHeaderFromResponse,
|
||||
setHeaderForResponse,
|
||||
setStatusCode,
|
||||
send
|
||||
} = require("./utils/compatibleAPI");
|
||||
|
||||
const ready = require("./utils/ready");
|
||||
/** @typedef {import("./index.js").NextFunction} NextFunction */
|
||||
|
||||
/** @typedef {import("./index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("./index.js").ServerResponse} ServerResponse */
|
||||
|
||||
/**
|
||||
* @param {string} type
|
||||
* @param {number} size
|
||||
* @param {import("range-parser").Range} [range]
|
||||
* @returns {string}
|
||||
*/
|
||||
|
||||
|
||||
function getValueContentRangeHeader(type, size, range) {
|
||||
return `${type} ${range ? `${range.start}-${range.end}` : "*"}/${size}`;
|
||||
}
|
||||
/**
|
||||
* @param {string | number} title
|
||||
* @param {string} body
|
||||
* @returns {string}
|
||||
*/
|
||||
|
||||
|
||||
function createHtmlDocument(title, body) {
|
||||
return `${"<!DOCTYPE html>\n" + '<html lang="en">\n' + "<head>\n" + '<meta charset="utf-8">\n' + "<title>"}${title}</title>\n` + `</head>\n` + `<body>\n` + `<pre>${body}</pre>\n` + `</body>\n` + `</html>\n`;
|
||||
}
|
||||
|
||||
const BYTES_RANGE_REGEXP = /^ *bytes/i;
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("./index.js").Context<Request, Response>} context
|
||||
* @return {import("./index.js").Middleware<Request, Response>}
|
||||
*/
|
||||
|
||||
function wrapper(context) {
|
||||
return async function middleware(req, res, next) {
|
||||
const acceptedMethods = context.options.methods || ["GET", "HEAD"]; // fixes #282. credit @cexoso. in certain edge situations res.locals is undefined.
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
|
||||
res.locals = res.locals || {};
|
||||
|
||||
if (req.method && !acceptedMethods.includes(req.method)) {
|
||||
await goNext();
|
||||
return;
|
||||
}
|
||||
|
||||
ready(context, processRequest, req);
|
||||
|
||||
async function goNext() {
|
||||
if (!context.options.serverSideRender) {
|
||||
return next();
|
||||
}
|
||||
|
||||
return new Promise(resolve => {
|
||||
ready(context, () => {
|
||||
/** @type {any} */
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
res.locals.webpack = {
|
||||
devMiddleware: context
|
||||
};
|
||||
resolve(next());
|
||||
}, req);
|
||||
});
|
||||
}
|
||||
|
||||
async function processRequest() {
|
||||
const filename = getFilenameFromUrl(context,
|
||||
/** @type {string} */
|
||||
req.url);
|
||||
|
||||
if (!filename) {
|
||||
await goNext();
|
||||
return;
|
||||
}
|
||||
|
||||
let {
|
||||
headers
|
||||
} = context.options;
|
||||
|
||||
if (typeof headers === "function") {
|
||||
// @ts-ignore
|
||||
headers = headers(req, res, context);
|
||||
}
|
||||
/**
|
||||
* @type {{key: string, value: string | number}[]}
|
||||
*/
|
||||
|
||||
|
||||
const allHeaders = [];
|
||||
|
||||
if (typeof headers !== "undefined") {
|
||||
if (!Array.isArray(headers)) {
|
||||
// eslint-disable-next-line guard-for-in
|
||||
for (const name in headers) {
|
||||
// @ts-ignore
|
||||
allHeaders.push({
|
||||
key: name,
|
||||
value: headers[name]
|
||||
});
|
||||
}
|
||||
|
||||
headers = allHeaders;
|
||||
}
|
||||
|
||||
headers.forEach(
|
||||
/**
|
||||
* @param {{key: string, value: any}} header
|
||||
*/
|
||||
header => {
|
||||
setHeaderForResponse(res, header.key, header.value);
|
||||
});
|
||||
}
|
||||
|
||||
if (!getHeaderFromResponse(res, "Content-Type")) {
|
||||
// content-type name(like application/javascript; charset=utf-8) or false
|
||||
const contentType = mime.contentType(path.extname(filename)); // Only set content-type header if media type is known
|
||||
// https://tools.ietf.org/html/rfc7231#section-3.1.1.5
|
||||
|
||||
if (contentType) {
|
||||
setHeaderForResponse(res, "Content-Type", contentType);
|
||||
}
|
||||
}
|
||||
|
||||
if (!getHeaderFromResponse(res, "Accept-Ranges")) {
|
||||
setHeaderForResponse(res, "Accept-Ranges", "bytes");
|
||||
}
|
||||
|
||||
const rangeHeader = getHeaderFromRequest(req, "range");
|
||||
let start;
|
||||
let end;
|
||||
|
||||
if (rangeHeader && BYTES_RANGE_REGEXP.test(rangeHeader)) {
|
||||
const size = await new Promise(resolve => {
|
||||
/** @type {import("fs").lstat} */
|
||||
context.outputFileSystem.lstat(filename, (error, stats) => {
|
||||
if (error) {
|
||||
context.logger.error(error);
|
||||
return;
|
||||
}
|
||||
|
||||
resolve(stats.size);
|
||||
});
|
||||
});
|
||||
const parsedRanges = parseRange(size, rangeHeader, {
|
||||
combine: true
|
||||
});
|
||||
|
||||
if (parsedRanges === -1) {
|
||||
const message = "Unsatisfiable range for 'Range' header.";
|
||||
context.logger.error(message);
|
||||
const existingHeaders = getHeaderNames(res);
|
||||
|
||||
for (let i = 0; i < existingHeaders.length; i++) {
|
||||
res.removeHeader(existingHeaders[i]);
|
||||
}
|
||||
|
||||
setStatusCode(res, 416);
|
||||
setHeaderForResponse(res, "Content-Range", getValueContentRangeHeader("bytes", size));
|
||||
setHeaderForResponse(res, "Content-Type", "text/html; charset=utf-8");
|
||||
const document = createHtmlDocument(416, `Error: ${message}`);
|
||||
const byteLength = Buffer.byteLength(document);
|
||||
setHeaderForResponse(res, "Content-Length", Buffer.byteLength(document));
|
||||
send(req, res, document, byteLength);
|
||||
return;
|
||||
} else if (parsedRanges === -2) {
|
||||
context.logger.error("A malformed 'Range' header was provided. A regular response will be sent for this request.");
|
||||
} else if (parsedRanges.length > 1) {
|
||||
context.logger.error("A 'Range' header with multiple ranges was provided. Multiple ranges are not supported, so a regular response will be sent for this request.");
|
||||
}
|
||||
|
||||
if (parsedRanges !== -2 && parsedRanges.length === 1) {
|
||||
// Content-Range
|
||||
setStatusCode(res, 206);
|
||||
setHeaderForResponse(res, "Content-Range", getValueContentRangeHeader("bytes", size,
|
||||
/** @type {import("range-parser").Ranges} */
|
||||
parsedRanges[0]));
|
||||
[{
|
||||
start,
|
||||
end
|
||||
}] = parsedRanges;
|
||||
}
|
||||
}
|
||||
|
||||
const isFsSupportsStream = typeof context.outputFileSystem.createReadStream === "function";
|
||||
let bufferOtStream;
|
||||
let byteLength;
|
||||
|
||||
try {
|
||||
if (typeof start !== "undefined" && typeof end !== "undefined" && isFsSupportsStream) {
|
||||
bufferOtStream =
|
||||
/** @type {import("fs").createReadStream} */
|
||||
context.outputFileSystem.createReadStream(filename, {
|
||||
start,
|
||||
end
|
||||
});
|
||||
byteLength = end - start + 1;
|
||||
} else {
|
||||
bufferOtStream =
|
||||
/** @type {import("fs").readFileSync} */
|
||||
context.outputFileSystem.readFileSync(filename);
|
||||
({
|
||||
byteLength
|
||||
} = bufferOtStream);
|
||||
}
|
||||
} catch (_ignoreError) {
|
||||
await goNext();
|
||||
return;
|
||||
}
|
||||
|
||||
send(req, res, bufferOtStream, byteLength);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
module.exports = wrapper;
|
125
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/options.json
generated
vendored
Executable file
125
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/options.json
generated
vendored
Executable file
|
@ -0,0 +1,125 @@
|
|||
{
|
||||
"type": "object",
|
||||
"properties": {
|
||||
"mimeTypes": {
|
||||
"description": "Allows a user to register custom mime types or extension mappings.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#mimetypes",
|
||||
"type": "object"
|
||||
},
|
||||
"writeToDisk": {
|
||||
"description": "Allows to write generated files on disk.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#writetodisk",
|
||||
"anyOf": [
|
||||
{
|
||||
"type": "boolean"
|
||||
},
|
||||
{
|
||||
"instanceof": "Function"
|
||||
}
|
||||
]
|
||||
},
|
||||
"methods": {
|
||||
"description": "Allows to pass the list of HTTP request methods accepted by the middleware.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#methods",
|
||||
"type": "array",
|
||||
"items": {
|
||||
"type": "string",
|
||||
"minlength": "1"
|
||||
}
|
||||
},
|
||||
"headers": {
|
||||
"anyOf": [
|
||||
{
|
||||
"type": "array",
|
||||
"items": {
|
||||
"type": "object",
|
||||
"additionalProperties": false,
|
||||
"properties": {
|
||||
"key": {
|
||||
"description": "key of header.",
|
||||
"type": "string"
|
||||
},
|
||||
"value": {
|
||||
"description": "value of header.",
|
||||
"type": "string"
|
||||
}
|
||||
}
|
||||
},
|
||||
"minItems": 1
|
||||
},
|
||||
{
|
||||
"type": "object"
|
||||
},
|
||||
{
|
||||
"instanceof": "Function"
|
||||
}
|
||||
],
|
||||
"description": "Allows to pass custom HTTP headers on each request",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#headers"
|
||||
},
|
||||
"publicPath": {
|
||||
"description": "The `publicPath` specifies the public URL address of the output files when referenced in a browser.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#publicpath",
|
||||
"anyOf": [
|
||||
{
|
||||
"enum": ["auto"]
|
||||
},
|
||||
{
|
||||
"type": "string"
|
||||
},
|
||||
{
|
||||
"instanceof": "Function"
|
||||
}
|
||||
]
|
||||
},
|
||||
"stats": {
|
||||
"description": "Stats options object or preset name.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#stats",
|
||||
"anyOf": [
|
||||
{
|
||||
"enum": [
|
||||
"none",
|
||||
"summary",
|
||||
"errors-only",
|
||||
"errors-warnings",
|
||||
"minimal",
|
||||
"normal",
|
||||
"detailed",
|
||||
"verbose"
|
||||
]
|
||||
},
|
||||
{
|
||||
"type": "boolean"
|
||||
},
|
||||
{
|
||||
"type": "object",
|
||||
"additionalProperties": true
|
||||
}
|
||||
]
|
||||
},
|
||||
"serverSideRender": {
|
||||
"description": "Instructs the module to enable or disable the server-side rendering mode.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#serversiderender",
|
||||
"type": "boolean"
|
||||
},
|
||||
"outputFileSystem": {
|
||||
"description": "Set the default file system which will be used by webpack as primary destination of generated files.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#outputfilesystem",
|
||||
"type": "object"
|
||||
},
|
||||
"index": {
|
||||
"description": "Allows to serve an index of the directory.",
|
||||
"link": "https://github.com/webpack/webpack-dev-middleware#index",
|
||||
"anyOf": [
|
||||
{
|
||||
"type": "boolean"
|
||||
},
|
||||
{
|
||||
"type": "string",
|
||||
"minlength": "1"
|
||||
}
|
||||
]
|
||||
}
|
||||
},
|
||||
"additionalProperties": false
|
||||
}
|
172
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/compatibleAPI.js
generated
vendored
Executable file
172
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/compatibleAPI.js
generated
vendored
Executable file
|
@ -0,0 +1,172 @@
|
|||
"use strict";
|
||||
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
|
||||
/**
|
||||
* @typedef {Object} ExpectedRequest
|
||||
* @property {(name: string) => string | undefined} get
|
||||
*/
|
||||
|
||||
/**
|
||||
* @typedef {Object} ExpectedResponse
|
||||
* @property {(name: string) => string | string[] | undefined} get
|
||||
* @property {(name: string, value: number | string | string[]) => void} set
|
||||
* @property {(status: number) => void} status
|
||||
* @property {(data: any) => void} send
|
||||
*/
|
||||
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @returns {string[]}
|
||||
*/
|
||||
function getHeaderNames(res) {
|
||||
if (typeof res.getHeaderNames !== "function") {
|
||||
// @ts-ignore
|
||||
// eslint-disable-next-line no-underscore-dangle
|
||||
return Object.keys(res._headers || {});
|
||||
}
|
||||
|
||||
return res.getHeaderNames();
|
||||
}
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @param {Request} req
|
||||
* @param {string} name
|
||||
* @returns {string | undefined}
|
||||
*/
|
||||
|
||||
|
||||
function getHeaderFromRequest(req, name) {
|
||||
// Express API
|
||||
if (typeof
|
||||
/** @type {Request & ExpectedRequest} */
|
||||
req.get === "function") {
|
||||
return (
|
||||
/** @type {Request & ExpectedRequest} */
|
||||
req.get(name)
|
||||
);
|
||||
} // Node.js API
|
||||
// @ts-ignore
|
||||
|
||||
|
||||
return req.headers[name];
|
||||
}
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @param {string} name
|
||||
* @returns {number | string | string[] | undefined}
|
||||
*/
|
||||
|
||||
|
||||
function getHeaderFromResponse(res, name) {
|
||||
// Express API
|
||||
if (typeof
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.get === "function") {
|
||||
return (
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.get(name)
|
||||
);
|
||||
} // Node.js API
|
||||
|
||||
|
||||
return res.getHeader(name);
|
||||
}
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @param {string} name
|
||||
* @param {number | string | string[]} value
|
||||
* @returns {void}
|
||||
*/
|
||||
|
||||
|
||||
function setHeaderForResponse(res, name, value) {
|
||||
// Express API
|
||||
if (typeof
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.set === "function") {
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.set(name, typeof value === "number" ? String(value) : value);
|
||||
return;
|
||||
} // Node.js API
|
||||
|
||||
|
||||
res.setHeader(name, value);
|
||||
}
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @param {number} code
|
||||
*/
|
||||
|
||||
|
||||
function setStatusCode(res, code) {
|
||||
if (typeof
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.status === "function") {
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.status(code);
|
||||
return;
|
||||
} // eslint-disable-next-line no-param-reassign
|
||||
|
||||
|
||||
res.statusCode = code;
|
||||
}
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Request} req
|
||||
* @param {Response} res
|
||||
* @param {string | Buffer | import("fs").ReadStream} bufferOtStream
|
||||
* @param {number} byteLength
|
||||
*/
|
||||
|
||||
|
||||
function send(req, res, bufferOtStream, byteLength) {
|
||||
if (typeof
|
||||
/** @type {import("fs").ReadStream} */
|
||||
bufferOtStream.pipe === "function") {
|
||||
setHeaderForResponse(res, "Content-Length", byteLength);
|
||||
|
||||
if (req.method === "HEAD") {
|
||||
res.end();
|
||||
return;
|
||||
}
|
||||
/** @type {import("fs").ReadStream} */
|
||||
|
||||
|
||||
bufferOtStream.pipe(res);
|
||||
return;
|
||||
}
|
||||
|
||||
if (typeof
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.send === "function") {
|
||||
/** @type {Response & ExpectedResponse} */
|
||||
res.send(bufferOtStream);
|
||||
return;
|
||||
} // Only Node.js API used
|
||||
|
||||
|
||||
res.setHeader("Content-Length", byteLength);
|
||||
|
||||
if (req.method === "HEAD") {
|
||||
res.end();
|
||||
} else {
|
||||
res.end(bufferOtStream);
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
getHeaderNames,
|
||||
getHeaderFromRequest,
|
||||
getHeaderFromResponse,
|
||||
setHeaderForResponse,
|
||||
setStatusCode,
|
||||
send
|
||||
};
|
137
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/getFilenameFromUrl.js
generated
vendored
Executable file
137
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/getFilenameFromUrl.js
generated
vendored
Executable file
|
@ -0,0 +1,137 @@
|
|||
"use strict";
|
||||
|
||||
const path = require("path");
|
||||
|
||||
const {
|
||||
parse
|
||||
} = require("url");
|
||||
|
||||
const querystring = require("querystring");
|
||||
|
||||
const getPaths = require("./getPaths");
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
|
||||
|
||||
const cacheStore = new WeakMap();
|
||||
/**
|
||||
* @param {Function} fn
|
||||
* @param {{ cache?: Map<any, any> }} [cache]
|
||||
* @returns {any}
|
||||
*/
|
||||
|
||||
const mem = (fn, {
|
||||
cache = new Map()
|
||||
} = {}) => {
|
||||
/**
|
||||
* @param {any} arguments_
|
||||
* @return {any}
|
||||
*/
|
||||
const memoized = (...arguments_) => {
|
||||
const [key] = arguments_;
|
||||
const cacheItem = cache.get(key);
|
||||
|
||||
if (cacheItem) {
|
||||
return cacheItem.data;
|
||||
}
|
||||
|
||||
const result = fn.apply(void 0, arguments_);
|
||||
cache.set(key, {
|
||||
data: result
|
||||
});
|
||||
return result;
|
||||
};
|
||||
|
||||
cacheStore.set(memoized, cache);
|
||||
return memoized;
|
||||
};
|
||||
|
||||
const memoizedParse = mem(parse);
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
* @param {string} url
|
||||
* @returns {string | undefined}
|
||||
*/
|
||||
|
||||
function getFilenameFromUrl(context, url) {
|
||||
const {
|
||||
options
|
||||
} = context;
|
||||
const paths = getPaths(context);
|
||||
let foundFilename;
|
||||
let urlObject;
|
||||
|
||||
try {
|
||||
// The `url` property of the `request` is contains only `pathname`, `search` and `hash`
|
||||
urlObject = memoizedParse(url, false, true);
|
||||
} catch (_ignoreError) {
|
||||
return;
|
||||
}
|
||||
|
||||
for (const {
|
||||
publicPath,
|
||||
outputPath
|
||||
} of paths) {
|
||||
let filename;
|
||||
let publicPathObject;
|
||||
|
||||
try {
|
||||
publicPathObject = memoizedParse(publicPath !== "auto" && publicPath ? publicPath : "/", false, true);
|
||||
} catch (_ignoreError) {
|
||||
// eslint-disable-next-line no-continue
|
||||
continue;
|
||||
}
|
||||
|
||||
if (urlObject.pathname && urlObject.pathname.startsWith(publicPathObject.pathname)) {
|
||||
filename = outputPath; // Strip the `pathname` property from the `publicPath` option from the start of requested url
|
||||
// `/complex/foo.js` => `foo.js`
|
||||
|
||||
const pathname = urlObject.pathname.slice(publicPathObject.pathname.length);
|
||||
|
||||
if (pathname) {
|
||||
filename = path.join(outputPath, querystring.unescape(pathname));
|
||||
}
|
||||
|
||||
let fsStats;
|
||||
|
||||
try {
|
||||
fsStats =
|
||||
/** @type {import("fs").statSync} */
|
||||
context.outputFileSystem.statSync(filename);
|
||||
} catch (_ignoreError) {
|
||||
// eslint-disable-next-line no-continue
|
||||
continue;
|
||||
}
|
||||
|
||||
if (fsStats.isFile()) {
|
||||
foundFilename = filename;
|
||||
break;
|
||||
} else if (fsStats.isDirectory() && (typeof options.index === "undefined" || options.index)) {
|
||||
const indexValue = typeof options.index === "undefined" || typeof options.index === "boolean" ? "index.html" : options.index;
|
||||
filename = path.join(filename, indexValue);
|
||||
|
||||
try {
|
||||
fsStats =
|
||||
/** @type {import("fs").statSync} */
|
||||
context.outputFileSystem.statSync(filename);
|
||||
} catch (__ignoreError) {
|
||||
// eslint-disable-next-line no-continue
|
||||
continue;
|
||||
}
|
||||
|
||||
if (fsStats.isFile()) {
|
||||
foundFilename = filename;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
} // eslint-disable-next-line consistent-return
|
||||
|
||||
|
||||
return foundFilename;
|
||||
}
|
||||
|
||||
module.exports = getFilenameFromUrl;
|
49
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/getPaths.js
generated
vendored
Executable file
49
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/getPaths.js
generated
vendored
Executable file
|
@ -0,0 +1,49 @@
|
|||
"use strict";
|
||||
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
|
||||
/** @typedef {import("webpack").Stats} Stats */
|
||||
|
||||
/** @typedef {import("webpack").MultiStats} MultiStats */
|
||||
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
function getPaths(context) {
|
||||
const {
|
||||
stats,
|
||||
options
|
||||
} = context;
|
||||
/** @type {Stats[]} */
|
||||
|
||||
const childStats =
|
||||
/** @type {MultiStats} */
|
||||
stats.stats ?
|
||||
/** @type {MultiStats} */
|
||||
stats.stats : [
|
||||
/** @type {Stats} */
|
||||
stats];
|
||||
const publicPaths = [];
|
||||
|
||||
for (const {
|
||||
compilation
|
||||
} of childStats) {
|
||||
// The `output.path` is always present and always absolute
|
||||
const outputPath = compilation.getPath(compilation.outputOptions.path || "");
|
||||
const publicPath = options.publicPath ? compilation.getPath(options.publicPath) : compilation.outputOptions.publicPath ? compilation.getPath(compilation.outputOptions.publicPath) : "";
|
||||
publicPaths.push({
|
||||
outputPath,
|
||||
publicPath
|
||||
});
|
||||
}
|
||||
|
||||
return publicPaths;
|
||||
}
|
||||
|
||||
module.exports = getPaths;
|
26
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/ready.js
generated
vendored
Executable file
26
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/ready.js
generated
vendored
Executable file
|
@ -0,0 +1,26 @@
|
|||
"use strict";
|
||||
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
* @param {(...args: any[]) => any} callback
|
||||
* @param {Request} [req]
|
||||
* @returns {void}
|
||||
*/
|
||||
function ready(context, callback, req) {
|
||||
if (context.state) {
|
||||
callback(context.stats);
|
||||
return;
|
||||
}
|
||||
|
||||
const name = req && req.url || callback.name;
|
||||
context.logger.info(`wait until bundle finished${name ? `: ${name}` : ""}`);
|
||||
context.callbacks.push(callback);
|
||||
}
|
||||
|
||||
module.exports = ready;
|
216
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/setupHooks.js
generated
vendored
Executable file
216
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/setupHooks.js
generated
vendored
Executable file
|
@ -0,0 +1,216 @@
|
|||
"use strict";
|
||||
|
||||
const webpack = require("webpack");
|
||||
|
||||
const {
|
||||
isColorSupported
|
||||
} = require("colorette");
|
||||
/** @typedef {import("webpack").Configuration} Configuration */
|
||||
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
|
||||
/** @typedef {import("webpack").Stats} Stats */
|
||||
|
||||
/** @typedef {import("webpack").MultiStats} MultiStats */
|
||||
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
|
||||
/** @typedef {Configuration["stats"]} StatsOptions */
|
||||
|
||||
/** @typedef {{ children: Configuration["stats"][] }} MultiStatsOptions */
|
||||
|
||||
/** @typedef {Exclude<Configuration["stats"], boolean | string | undefined>} NormalizedStatsOptions */
|
||||
// TODO remove `color` after dropping webpack v4
|
||||
|
||||
/** @typedef {{ children: StatsOptions[], colors?: any }} MultiNormalizedStatsOptions */
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
|
||||
|
||||
function setupHooks(context) {
|
||||
function invalid() {
|
||||
if (context.state) {
|
||||
context.logger.log("Compilation starting...");
|
||||
} // We are now in invalid state
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
|
||||
|
||||
context.state = false; // eslint-disable-next-line no-param-reassign, no-undefined
|
||||
|
||||
context.stats = undefined;
|
||||
} // @ts-ignore
|
||||
|
||||
|
||||
const statsForWebpack4 = webpack.Stats && webpack.Stats.presetToOptions;
|
||||
/**
|
||||
* @param {Configuration["stats"]} statsOptions
|
||||
* @returns {NormalizedStatsOptions}
|
||||
*/
|
||||
|
||||
function normalizeStatsOptions(statsOptions) {
|
||||
if (statsForWebpack4) {
|
||||
if (typeof statsOptions === "undefined") {
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
statsOptions = {};
|
||||
} else if (typeof statsOptions === "boolean" || typeof statsOptions === "string") {
|
||||
// @ts-ignore
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
statsOptions = webpack.Stats.presetToOptions(statsOptions);
|
||||
} // @ts-ignore
|
||||
|
||||
|
||||
return statsOptions;
|
||||
}
|
||||
|
||||
if (typeof statsOptions === "undefined") {
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
statsOptions = {
|
||||
preset: "normal"
|
||||
};
|
||||
} else if (typeof statsOptions === "boolean") {
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
statsOptions = statsOptions ? {
|
||||
preset: "normal"
|
||||
} : {
|
||||
preset: "none"
|
||||
};
|
||||
} else if (typeof statsOptions === "string") {
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
statsOptions = {
|
||||
preset: statsOptions
|
||||
};
|
||||
}
|
||||
|
||||
return statsOptions;
|
||||
}
|
||||
/**
|
||||
* @param {Stats | MultiStats} stats
|
||||
*/
|
||||
|
||||
|
||||
function done(stats) {
|
||||
// We are now on valid state
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
context.state = true; // eslint-disable-next-line no-param-reassign
|
||||
|
||||
context.stats = stats; // Do the stuff in nextTick, because bundle may be invalidated if a change happened while compiling
|
||||
|
||||
process.nextTick(() => {
|
||||
const {
|
||||
compiler,
|
||||
logger,
|
||||
options,
|
||||
state,
|
||||
callbacks
|
||||
} = context; // Check if still in valid state
|
||||
|
||||
if (!state) {
|
||||
return;
|
||||
}
|
||||
|
||||
logger.log("Compilation finished");
|
||||
const isMultiCompilerMode = Boolean(
|
||||
/** @type {MultiCompiler} */
|
||||
compiler.compilers);
|
||||
/**
|
||||
* @type {StatsOptions | MultiStatsOptions | NormalizedStatsOptions | MultiNormalizedStatsOptions}
|
||||
*/
|
||||
|
||||
let statsOptions;
|
||||
|
||||
if (typeof options.stats !== "undefined") {
|
||||
statsOptions = isMultiCompilerMode ? {
|
||||
children:
|
||||
/** @type {MultiCompiler} */
|
||||
compiler.compilers.map(() => options.stats)
|
||||
} : options.stats;
|
||||
} else {
|
||||
statsOptions = isMultiCompilerMode ? {
|
||||
children:
|
||||
/** @type {MultiCompiler} */
|
||||
compiler.compilers.map(child => child.options.stats)
|
||||
} :
|
||||
/** @type {Compiler} */
|
||||
compiler.options.stats;
|
||||
}
|
||||
|
||||
if (isMultiCompilerMode) {
|
||||
/** @type {MultiNormalizedStatsOptions} */
|
||||
statsOptions.children =
|
||||
/** @type {MultiStatsOptions} */
|
||||
statsOptions.children.map(
|
||||
/**
|
||||
* @param {StatsOptions} childStatsOptions
|
||||
* @return {NormalizedStatsOptions}
|
||||
*/
|
||||
childStatsOptions => {
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
childStatsOptions = normalizeStatsOptions(childStatsOptions);
|
||||
|
||||
if (typeof childStatsOptions.colors === "undefined") {
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
childStatsOptions.colors = isColorSupported;
|
||||
}
|
||||
|
||||
return childStatsOptions;
|
||||
});
|
||||
} else {
|
||||
/** @type {NormalizedStatsOptions} */
|
||||
statsOptions = normalizeStatsOptions(
|
||||
/** @type {StatsOptions} */
|
||||
statsOptions);
|
||||
|
||||
if (typeof statsOptions.colors === "undefined") {
|
||||
statsOptions.colors = isColorSupported;
|
||||
}
|
||||
} // TODO webpack@4 doesn't support `{ children: [{ colors: true }, { colors: true }] }` for stats
|
||||
|
||||
|
||||
if (
|
||||
/** @type {MultiCompiler} */
|
||||
compiler.compilers && statsForWebpack4) {
|
||||
/** @type {MultiNormalizedStatsOptions} */
|
||||
statsOptions.colors =
|
||||
/** @type {MultiNormalizedStatsOptions} */
|
||||
statsOptions.children.some(
|
||||
/**
|
||||
* @param {StatsOptions} child
|
||||
*/
|
||||
// @ts-ignore
|
||||
child => child.colors);
|
||||
}
|
||||
|
||||
const printedStats = stats.toString(statsOptions); // Avoid extra empty line when `stats: 'none'`
|
||||
|
||||
if (printedStats) {
|
||||
// eslint-disable-next-line no-console
|
||||
console.log(printedStats);
|
||||
} // eslint-disable-next-line no-param-reassign
|
||||
|
||||
|
||||
context.callbacks = []; // Execute callback that are delayed
|
||||
|
||||
callbacks.forEach(
|
||||
/**
|
||||
* @param {(...args: any[]) => Stats | MultiStats} callback
|
||||
*/
|
||||
callback => {
|
||||
callback(stats);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
context.compiler.hooks.watchRun.tap("webpack-dev-middleware", invalid);
|
||||
context.compiler.hooks.invalid.tap("webpack-dev-middleware", invalid);
|
||||
context.compiler.hooks.done.tap("webpack-dev-middleware", done);
|
||||
}
|
||||
|
||||
module.exports = setupHooks;
|
58
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/setupOutputFileSystem.js
generated
vendored
Executable file
58
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/setupOutputFileSystem.js
generated
vendored
Executable file
|
@ -0,0 +1,58 @@
|
|||
"use strict";
|
||||
|
||||
const path = require("path");
|
||||
|
||||
const memfs = require("memfs");
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
|
||||
|
||||
function setupOutputFileSystem(context) {
|
||||
let outputFileSystem;
|
||||
|
||||
if (context.options.outputFileSystem) {
|
||||
const {
|
||||
outputFileSystem: outputFileSystemFromOptions
|
||||
} = context.options; // Todo remove when we drop webpack@4 support
|
||||
|
||||
if (typeof outputFileSystemFromOptions.join !== "function") {
|
||||
throw new Error("Invalid options: options.outputFileSystem.join() method is expected");
|
||||
} // Todo remove when we drop webpack@4 support
|
||||
// @ts-ignore
|
||||
|
||||
|
||||
if (typeof outputFileSystemFromOptions.mkdirp !== "function") {
|
||||
throw new Error("Invalid options: options.outputFileSystem.mkdirp() method is expected");
|
||||
}
|
||||
|
||||
outputFileSystem = outputFileSystemFromOptions;
|
||||
} else {
|
||||
outputFileSystem = memfs.createFsFromVolume(new memfs.Volume()); // TODO: remove when we drop webpack@4 support
|
||||
// @ts-ignore
|
||||
|
||||
outputFileSystem.join = path.join.bind(path);
|
||||
}
|
||||
|
||||
const compilers =
|
||||
/** @type {MultiCompiler} */
|
||||
context.compiler.compilers || [context.compiler];
|
||||
|
||||
for (const compiler of compilers) {
|
||||
compiler.outputFileSystem = outputFileSystem;
|
||||
} // @ts-ignore
|
||||
// eslint-disable-next-line no-param-reassign
|
||||
|
||||
|
||||
context.outputFileSystem = outputFileSystem;
|
||||
}
|
||||
|
||||
module.exports = setupOutputFileSystem;
|
111
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/setupWriteToDisk.js
generated
vendored
Executable file
111
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/dist/utils/setupWriteToDisk.js
generated
vendored
Executable file
|
@ -0,0 +1,111 @@
|
|||
"use strict";
|
||||
|
||||
const fs = require("fs");
|
||||
|
||||
const path = require("path");
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
|
||||
/** @typedef {import("webpack").Compilation} Compilation */
|
||||
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
|
||||
|
||||
function setupWriteToDisk(context) {
|
||||
/**
|
||||
* @type {Compiler[]}
|
||||
*/
|
||||
const compilers =
|
||||
/** @type {MultiCompiler} */
|
||||
context.compiler.compilers || [context.compiler];
|
||||
|
||||
for (const compiler of compilers) {
|
||||
compiler.hooks.emit.tap("DevMiddleware",
|
||||
/**
|
||||
* @param {Compilation} compilation
|
||||
*/
|
||||
compilation => {
|
||||
// @ts-ignore
|
||||
if (compiler.hasWebpackDevMiddlewareAssetEmittedCallback) {
|
||||
return;
|
||||
}
|
||||
|
||||
compiler.hooks.assetEmitted.tapAsync("DevMiddleware", (file, info, callback) => {
|
||||
/**
|
||||
* @type {string}
|
||||
*/
|
||||
let targetPath;
|
||||
/**
|
||||
* @type {Buffer}
|
||||
*/
|
||||
|
||||
let content; // webpack@5
|
||||
|
||||
if (info.compilation) {
|
||||
({
|
||||
targetPath,
|
||||
content
|
||||
} = info);
|
||||
} else {
|
||||
let targetFile = file;
|
||||
const queryStringIdx = targetFile.indexOf("?");
|
||||
|
||||
if (queryStringIdx >= 0) {
|
||||
targetFile = targetFile.slice(0, queryStringIdx);
|
||||
}
|
||||
|
||||
let {
|
||||
outputPath
|
||||
} = compiler;
|
||||
outputPath = compilation.getPath(outputPath, {}); // @ts-ignore
|
||||
|
||||
content = info;
|
||||
targetPath = path.join(outputPath, targetFile);
|
||||
}
|
||||
|
||||
const {
|
||||
writeToDisk: filter
|
||||
} = context.options;
|
||||
const allowWrite = filter && typeof filter === "function" ? filter(targetPath) : true;
|
||||
|
||||
if (!allowWrite) {
|
||||
return callback();
|
||||
}
|
||||
|
||||
const dir = path.dirname(targetPath);
|
||||
const name = compiler.options.name ? `Child "${compiler.options.name}": ` : "";
|
||||
return fs.mkdir(dir, {
|
||||
recursive: true
|
||||
}, mkdirError => {
|
||||
if (mkdirError) {
|
||||
context.logger.error(`${name}Unable to write "${dir}" directory to disk:\n${mkdirError}`);
|
||||
return callback(mkdirError);
|
||||
}
|
||||
|
||||
return fs.writeFile(targetPath, content, writeFileError => {
|
||||
if (writeFileError) {
|
||||
context.logger.error(`${name}Unable to write "${targetPath}" asset to disk:\n${writeFileError}`);
|
||||
return callback(writeFileError);
|
||||
}
|
||||
|
||||
context.logger.log(`${name}Asset written to disk: "${targetPath}"`);
|
||||
return callback();
|
||||
});
|
||||
});
|
||||
}); // @ts-ignore
|
||||
|
||||
compiler.hasWebpackDevMiddlewareAssetEmittedCallback = true;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = setupWriteToDisk;
|
96
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/package.json
generated
vendored
Executable file
96
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/package.json
generated
vendored
Executable file
|
@ -0,0 +1,96 @@
|
|||
{
|
||||
"name": "webpack-dev-middleware",
|
||||
"version": "5.3.3",
|
||||
"description": "A development middleware for webpack",
|
||||
"license": "MIT",
|
||||
"repository": "webpack/webpack-dev-middleware",
|
||||
"author": "Tobias Koppers @sokra",
|
||||
"homepage": "https://github.com/webpack/webpack-dev-middleware",
|
||||
"bugs": "https://github.com/webpack/webpack-dev-middleware/issues",
|
||||
"funding": {
|
||||
"type": "opencollective",
|
||||
"url": "https://opencollective.com/webpack"
|
||||
},
|
||||
"main": "dist/index.js",
|
||||
"types": "types/index.d.ts",
|
||||
"engines": {
|
||||
"node": ">= 12.13.0"
|
||||
},
|
||||
"scripts": {
|
||||
"commitlint": "commitlint --from=master",
|
||||
"security": "npm audit --production",
|
||||
"fmt:check": "prettier \"{**/*,*}.{js,json,md,yml,css}\" --list-different",
|
||||
"lint:js": "eslint --cache src test",
|
||||
"lint:types": "tsc --pretty --noEmit",
|
||||
"lint": "npm-run-all lint:js fmt:check",
|
||||
"fmt": "npm run fmt:check -- --write",
|
||||
"fix:js": "npm run lint:js -- --fix",
|
||||
"fix": "npm-run-all fix:js fmt",
|
||||
"clean": "del-cli dist types",
|
||||
"prebuild": "npm run clean",
|
||||
"build:types": "tsc --declaration --emitDeclarationOnly --outDir types && prettier \"types/**/*.ts\" --write",
|
||||
"build:code": "cross-env NODE_ENV=production babel src -d dist --copy-files",
|
||||
"build": "npm-run-all -p \"build:**\"",
|
||||
"test:only": "cross-env NODE_ENV=test jest",
|
||||
"test:watch": "npm run test:only -- --watch",
|
||||
"test:coverage": "npm run test:only -- --collectCoverageFrom=\"src/**/*.js\" --coverage",
|
||||
"pretest": "npm run lint",
|
||||
"test": "npm run test:coverage",
|
||||
"prepare": "husky install && npm run build",
|
||||
"release": "standard-version"
|
||||
},
|
||||
"files": [
|
||||
"dist",
|
||||
"types"
|
||||
],
|
||||
"peerDependencies": {
|
||||
"webpack": "^4.0.0 || ^5.0.0"
|
||||
},
|
||||
"dependencies": {
|
||||
"colorette": "^2.0.10",
|
||||
"memfs": "^3.4.3",
|
||||
"mime-types": "^2.1.31",
|
||||
"range-parser": "^1.2.1",
|
||||
"schema-utils": "^4.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/cli": "^7.16.7",
|
||||
"@babel/core": "^7.16.7",
|
||||
"@babel/preset-env": "^7.16.7",
|
||||
"@commitlint/cli": "^17.0.0",
|
||||
"@commitlint/config-conventional": "^17.0.0",
|
||||
"@types/connect": "^3.4.35",
|
||||
"@types/express": "^4.17.13",
|
||||
"@types/mime-types": "^2.1.1",
|
||||
"@types/node": "^12.20.43",
|
||||
"@webpack-contrib/eslint-config-webpack": "^3.0.0",
|
||||
"babel-jest": "^28.1.0",
|
||||
"chokidar": "^3.5.1",
|
||||
"connect": "^3.7.0",
|
||||
"cross-env": "^7.0.3",
|
||||
"deepmerge": "^4.2.2",
|
||||
"del": "^6.0.0",
|
||||
"del-cli": "^4.0.0",
|
||||
"eslint": "^8.6.0",
|
||||
"eslint-config-prettier": "^8.3.0",
|
||||
"eslint-plugin-import": "^2.25.4",
|
||||
"execa": "^5.1.1",
|
||||
"express": "^4.17.1",
|
||||
"file-loader": "^6.2.0",
|
||||
"husky": "^7.0.0",
|
||||
"jest": "^28.1.0",
|
||||
"lint-staged": "^12.1.7",
|
||||
"npm-run-all": "^4.1.5",
|
||||
"prettier": "^2.5.0",
|
||||
"standard-version": "^9.3.0",
|
||||
"strip-ansi": "^6.0.0",
|
||||
"supertest": "^6.1.3",
|
||||
"typescript": "4.5.5",
|
||||
"webpack": "^5.68.0"
|
||||
},
|
||||
"keywords": [
|
||||
"webpack",
|
||||
"middleware",
|
||||
"development"
|
||||
]
|
||||
}
|
257
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/index.d.ts
generated
vendored
Executable file
257
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/index.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,257 @@
|
|||
/// <reference types="node" />
|
||||
export = wdm;
|
||||
/** @typedef {import("schema-utils/declarations/validate").Schema} Schema */
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
/** @typedef {import("webpack").Configuration} Configuration */
|
||||
/** @typedef {import("webpack").Stats} Stats */
|
||||
/** @typedef {import("webpack").MultiStats} MultiStats */
|
||||
/**
|
||||
* @typedef {Object} ExtendedServerResponse
|
||||
* @property {{ webpack?: { devMiddleware?: Context<IncomingMessage, ServerResponse> } }} [locals]
|
||||
*/
|
||||
/** @typedef {import("http").IncomingMessage} IncomingMessage */
|
||||
/** @typedef {import("http").ServerResponse & ExtendedServerResponse} ServerResponse */
|
||||
/**
|
||||
* @callback NextFunction
|
||||
* @param {any} [err]
|
||||
* @return {void}
|
||||
*/
|
||||
/**
|
||||
* @typedef {NonNullable<Configuration["watchOptions"]>} WatchOptions
|
||||
*/
|
||||
/**
|
||||
* @typedef {Compiler["watching"]} Watching
|
||||
*/
|
||||
/**
|
||||
* @typedef {ReturnType<Compiler["watch"]>} MultiWatching
|
||||
*/
|
||||
/**
|
||||
* @typedef {Compiler["outputFileSystem"] & { createReadStream?: import("fs").createReadStream, statSync?: import("fs").statSync, lstat?: import("fs").lstat, readFileSync?: import("fs").readFileSync }} OutputFileSystem
|
||||
*/
|
||||
/** @typedef {ReturnType<Compiler["getInfrastructureLogger"]>} Logger */
|
||||
/**
|
||||
* @callback Callback
|
||||
* @param {Stats | MultiStats} [stats]
|
||||
*/
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Object} Context
|
||||
* @property {boolean} state
|
||||
* @property {Stats | MultiStats | undefined} stats
|
||||
* @property {Callback[]} callbacks
|
||||
* @property {Options<Request, Response>} options
|
||||
* @property {Compiler | MultiCompiler} compiler
|
||||
* @property {Watching | MultiWatching} watching
|
||||
* @property {Logger} logger
|
||||
* @property {OutputFileSystem} outputFileSystem
|
||||
*/
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Record<string, string | number> | Array<{ key: string, value: number | string }> | ((req: Request, res: Response, context: Context<Request, Response>) => void | undefined | Record<string, string | number>) | undefined} Headers
|
||||
*/
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Object} Options
|
||||
* @property {{[key: string]: string}} [mimeTypes]
|
||||
* @property {boolean | ((targetPath: string) => boolean)} [writeToDisk]
|
||||
* @property {string} [methods]
|
||||
* @property {Headers<Request, Response>} [headers]
|
||||
* @property {NonNullable<Configuration["output"]>["publicPath"]} [publicPath]
|
||||
* @property {Configuration["stats"]} [stats]
|
||||
* @property {boolean} [serverSideRender]
|
||||
* @property {OutputFileSystem} [outputFileSystem]
|
||||
* @property {boolean | string} [index]
|
||||
*/
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @callback Middleware
|
||||
* @param {Request} req
|
||||
* @param {Response} res
|
||||
* @param {NextFunction} next
|
||||
* @return {Promise<void>}
|
||||
*/
|
||||
/**
|
||||
* @callback GetFilenameFromUrl
|
||||
* @param {string} url
|
||||
* @returns {string | undefined}
|
||||
*/
|
||||
/**
|
||||
* @callback WaitUntilValid
|
||||
* @param {Callback} callback
|
||||
*/
|
||||
/**
|
||||
* @callback Invalidate
|
||||
* @param {Callback} callback
|
||||
*/
|
||||
/**
|
||||
* @callback Close
|
||||
* @param {(err: Error | null | undefined) => void} callback
|
||||
*/
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Object} AdditionalMethods
|
||||
* @property {GetFilenameFromUrl} getFilenameFromUrl
|
||||
* @property {WaitUntilValid} waitUntilValid
|
||||
* @property {Invalidate} invalidate
|
||||
* @property {Close} close
|
||||
* @property {Context<Request, Response>} context
|
||||
*/
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @typedef {Middleware<Request, Response> & AdditionalMethods<Request, Response>} API
|
||||
*/
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Compiler | MultiCompiler} compiler
|
||||
* @param {Options<Request, Response>} [options]
|
||||
* @returns {API<Request, Response>}
|
||||
*/
|
||||
declare function wdm<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends ServerResponse
|
||||
>(
|
||||
compiler: Compiler | MultiCompiler,
|
||||
options?: Options<Request_1, Response_1> | undefined
|
||||
): API<Request_1, Response_1>;
|
||||
declare namespace wdm {
|
||||
export {
|
||||
Schema,
|
||||
Compiler,
|
||||
MultiCompiler,
|
||||
Configuration,
|
||||
Stats,
|
||||
MultiStats,
|
||||
ExtendedServerResponse,
|
||||
IncomingMessage,
|
||||
ServerResponse,
|
||||
NextFunction,
|
||||
WatchOptions,
|
||||
Watching,
|
||||
MultiWatching,
|
||||
OutputFileSystem,
|
||||
Logger,
|
||||
Callback,
|
||||
Context,
|
||||
Headers,
|
||||
Options,
|
||||
Middleware,
|
||||
GetFilenameFromUrl,
|
||||
WaitUntilValid,
|
||||
Invalidate,
|
||||
Close,
|
||||
AdditionalMethods,
|
||||
API,
|
||||
};
|
||||
}
|
||||
type ServerResponse = import("http").ServerResponse & ExtendedServerResponse;
|
||||
type Compiler = import("webpack").Compiler;
|
||||
type MultiCompiler = import("webpack").MultiCompiler;
|
||||
type Options<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends ServerResponse
|
||||
> = {
|
||||
mimeTypes?:
|
||||
| {
|
||||
[key: string]: string;
|
||||
}
|
||||
| undefined;
|
||||
writeToDisk?: boolean | ((targetPath: string) => boolean) | undefined;
|
||||
methods?: string | undefined;
|
||||
headers?: Headers<Request_1, Response_1>;
|
||||
publicPath?: NonNullable<Configuration["output"]>["publicPath"];
|
||||
stats?: Configuration["stats"];
|
||||
serverSideRender?: boolean | undefined;
|
||||
outputFileSystem?: OutputFileSystem | undefined;
|
||||
index?: string | boolean | undefined;
|
||||
};
|
||||
type API<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends ServerResponse
|
||||
> = Middleware<Request_1, Response_1> &
|
||||
AdditionalMethods<Request_1, Response_1>;
|
||||
type Schema = import("schema-utils/declarations/validate").Schema;
|
||||
type Configuration = import("webpack").Configuration;
|
||||
type Stats = import("webpack").Stats;
|
||||
type MultiStats = import("webpack").MultiStats;
|
||||
type ExtendedServerResponse = {
|
||||
locals?:
|
||||
| {
|
||||
webpack?:
|
||||
| {
|
||||
devMiddleware?:
|
||||
| Context<import("http").IncomingMessage, ServerResponse>
|
||||
| undefined;
|
||||
}
|
||||
| undefined;
|
||||
}
|
||||
| undefined;
|
||||
};
|
||||
type IncomingMessage = import("http").IncomingMessage;
|
||||
type NextFunction = (err?: any) => void;
|
||||
type WatchOptions = NonNullable<Configuration["watchOptions"]>;
|
||||
type Watching = Compiler["watching"];
|
||||
type MultiWatching = ReturnType<Compiler["watch"]>;
|
||||
type OutputFileSystem = Compiler["outputFileSystem"] & {
|
||||
createReadStream?: typeof import("fs").createReadStream;
|
||||
statSync?: typeof import("fs").statSync;
|
||||
lstat?: typeof import("fs").lstat;
|
||||
readFileSync?: typeof import("fs").readFileSync;
|
||||
};
|
||||
type Logger = ReturnType<Compiler["getInfrastructureLogger"]>;
|
||||
type Callback = (
|
||||
stats?: import("webpack").Stats | import("webpack").MultiStats | undefined
|
||||
) => any;
|
||||
type Context<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends ServerResponse
|
||||
> = {
|
||||
state: boolean;
|
||||
stats: Stats | MultiStats | undefined;
|
||||
callbacks: Callback[];
|
||||
options: Options<Request_1, Response_1>;
|
||||
compiler: Compiler | MultiCompiler;
|
||||
watching: Watching | MultiWatching;
|
||||
logger: Logger;
|
||||
outputFileSystem: OutputFileSystem;
|
||||
};
|
||||
type Headers<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends ServerResponse
|
||||
> =
|
||||
| Record<string, string | number>
|
||||
| {
|
||||
key: string;
|
||||
value: number | string;
|
||||
}[]
|
||||
| ((
|
||||
req: Request_1,
|
||||
res: Response_1,
|
||||
context: Context<Request_1, Response_1>
|
||||
) => void | undefined | Record<string, string | number>)
|
||||
| undefined;
|
||||
type Middleware<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends ServerResponse
|
||||
> = (req: Request_1, res: Response_1, next: NextFunction) => Promise<void>;
|
||||
type GetFilenameFromUrl = (url: string) => string | undefined;
|
||||
type WaitUntilValid = (callback: Callback) => any;
|
||||
type Invalidate = (callback: Callback) => any;
|
||||
type Close = (callback: (err: Error | null | undefined) => void) => any;
|
||||
type AdditionalMethods<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends ServerResponse
|
||||
> = {
|
||||
getFilenameFromUrl: GetFilenameFromUrl;
|
||||
waitUntilValid: WaitUntilValid;
|
||||
invalidate: Invalidate;
|
||||
close: Close;
|
||||
context: Context<Request_1, Response_1>;
|
||||
};
|
20
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/middleware.d.ts
generated
vendored
Executable file
20
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/middleware.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,20 @@
|
|||
/// <reference types="node" />
|
||||
export = wrapper;
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("./index.js").Context<Request, Response>} context
|
||||
* @return {import("./index.js").Middleware<Request, Response>}
|
||||
*/
|
||||
declare function wrapper<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("./index.js").ServerResponse
|
||||
>(
|
||||
context: import("./index.js").Context<Request_1, Response_1>
|
||||
): import("./index.js").Middleware<Request_1, Response_1>;
|
||||
declare namespace wrapper {
|
||||
export { NextFunction, IncomingMessage, ServerResponse };
|
||||
}
|
||||
type NextFunction = import("./index.js").NextFunction;
|
||||
type IncomingMessage = import("./index.js").IncomingMessage;
|
||||
type ServerResponse = import("./index.js").ServerResponse;
|
86
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/compatibleAPI.d.ts
generated
vendored
Executable file
86
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/compatibleAPI.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,86 @@
|
|||
/// <reference types="node" />
|
||||
export type IncomingMessage = import("../index.js").IncomingMessage;
|
||||
export type ServerResponse = import("../index.js").ServerResponse;
|
||||
export type ExpectedRequest = {
|
||||
get: (name: string) => string | undefined;
|
||||
};
|
||||
export type ExpectedResponse = {
|
||||
get: (name: string) => string | string[] | undefined;
|
||||
set: (name: string, value: number | string | string[]) => void;
|
||||
status: (status: number) => void;
|
||||
send: (data: any) => void;
|
||||
};
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
/**
|
||||
* @typedef {Object} ExpectedRequest
|
||||
* @property {(name: string) => string | undefined} get
|
||||
*/
|
||||
/**
|
||||
* @typedef {Object} ExpectedResponse
|
||||
* @property {(name: string) => string | string[] | undefined} get
|
||||
* @property {(name: string, value: number | string | string[]) => void} set
|
||||
* @property {(status: number) => void} status
|
||||
* @property {(data: any) => void} send
|
||||
*/
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @returns {string[]}
|
||||
*/
|
||||
export function getHeaderNames<
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(res: Response_1): string[];
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @param {Request} req
|
||||
* @param {string} name
|
||||
* @returns {string | undefined}
|
||||
*/
|
||||
export function getHeaderFromRequest<
|
||||
Request_1 extends import("http").IncomingMessage
|
||||
>(req: Request_1, name: string): string | undefined;
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @param {string} name
|
||||
* @returns {number | string | string[] | undefined}
|
||||
*/
|
||||
export function getHeaderFromResponse<
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(res: Response_1, name: string): number | string | string[] | undefined;
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @param {string} name
|
||||
* @param {number | string | string[]} value
|
||||
* @returns {void}
|
||||
*/
|
||||
export function setHeaderForResponse<
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(res: Response_1, name: string, value: number | string | string[]): void;
|
||||
/**
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Response} res
|
||||
* @param {number} code
|
||||
*/
|
||||
export function setStatusCode<
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(res: Response_1, code: number): void;
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {Request} req
|
||||
* @param {Response} res
|
||||
* @param {string | Buffer | import("fs").ReadStream} bufferOtStream
|
||||
* @param {number} byteLength
|
||||
*/
|
||||
export function send<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(
|
||||
req: Request_1,
|
||||
res: Response_1,
|
||||
bufferOtStream: string | Buffer | import("fs").ReadStream,
|
||||
byteLength: number
|
||||
): void;
|
21
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/getFilenameFromUrl.d.ts
generated
vendored
Executable file
21
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/getFilenameFromUrl.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,21 @@
|
|||
/// <reference types="node" />
|
||||
export = getFilenameFromUrl;
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
* @param {string} url
|
||||
* @returns {string | undefined}
|
||||
*/
|
||||
declare function getFilenameFromUrl<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(
|
||||
context: import("../index.js").Context<Request_1, Response_1>,
|
||||
url: string
|
||||
): string | undefined;
|
||||
declare namespace getFilenameFromUrl {
|
||||
export { IncomingMessage, ServerResponse };
|
||||
}
|
||||
type IncomingMessage = import("../index.js").IncomingMessage;
|
||||
type ServerResponse = import("../index.js").ServerResponse;
|
29
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/getPaths.d.ts
generated
vendored
Executable file
29
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/getPaths.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,29 @@
|
|||
/// <reference types="node" />
|
||||
export = getPaths;
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
/** @typedef {import("webpack").Stats} Stats */
|
||||
/** @typedef {import("webpack").MultiStats} MultiStats */
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
declare function getPaths<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(
|
||||
context: import("../index.js").Context<Request_1, Response_1>
|
||||
): {
|
||||
outputPath: string;
|
||||
publicPath: string;
|
||||
}[];
|
||||
declare namespace getPaths {
|
||||
export { Compiler, Stats, MultiStats, IncomingMessage, ServerResponse };
|
||||
}
|
||||
type Compiler = import("webpack").Compiler;
|
||||
type Stats = import("webpack").Stats;
|
||||
type MultiStats = import("webpack").MultiStats;
|
||||
type IncomingMessage = import("../index.js").IncomingMessage;
|
||||
type ServerResponse = import("../index.js").ServerResponse;
|
25
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/ready.d.ts
generated
vendored
Executable file
25
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/ready.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,25 @@
|
|||
/// <reference types="node" />
|
||||
export = ready;
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
* @param {(...args: any[]) => any} callback
|
||||
* @param {Request} [req]
|
||||
* @returns {void}
|
||||
*/
|
||||
declare function ready<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(
|
||||
context: import("../index.js").Context<Request_1, Response_1>,
|
||||
callback: (...args: any[]) => any,
|
||||
req?: Request_1 | undefined
|
||||
): void;
|
||||
declare namespace ready {
|
||||
export { IncomingMessage, ServerResponse };
|
||||
}
|
||||
type IncomingMessage = import("../index.js").IncomingMessage;
|
||||
type ServerResponse = import("../index.js").ServerResponse;
|
56
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/setupHooks.d.ts
generated
vendored
Executable file
56
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/setupHooks.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,56 @@
|
|||
/// <reference types="node" />
|
||||
export = setupHooks;
|
||||
/** @typedef {import("webpack").Configuration} Configuration */
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
/** @typedef {import("webpack").Stats} Stats */
|
||||
/** @typedef {import("webpack").MultiStats} MultiStats */
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
/** @typedef {Configuration["stats"]} StatsOptions */
|
||||
/** @typedef {{ children: Configuration["stats"][] }} MultiStatsOptions */
|
||||
/** @typedef {Exclude<Configuration["stats"], boolean | string | undefined>} NormalizedStatsOptions */
|
||||
/** @typedef {{ children: StatsOptions[], colors?: any }} MultiNormalizedStatsOptions */
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
declare function setupHooks<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(context: import("../index.js").Context<Request_1, Response_1>): void;
|
||||
declare namespace setupHooks {
|
||||
export {
|
||||
Configuration,
|
||||
Compiler,
|
||||
MultiCompiler,
|
||||
Stats,
|
||||
MultiStats,
|
||||
IncomingMessage,
|
||||
ServerResponse,
|
||||
StatsOptions,
|
||||
MultiStatsOptions,
|
||||
NormalizedStatsOptions,
|
||||
MultiNormalizedStatsOptions,
|
||||
};
|
||||
}
|
||||
type Configuration = import("webpack").Configuration;
|
||||
type Compiler = import("webpack").Compiler;
|
||||
type MultiCompiler = import("webpack").MultiCompiler;
|
||||
type Stats = import("webpack").Stats;
|
||||
type MultiStats = import("webpack").MultiStats;
|
||||
type IncomingMessage = import("../index.js").IncomingMessage;
|
||||
type ServerResponse = import("../index.js").ServerResponse;
|
||||
type StatsOptions = Configuration["stats"];
|
||||
type MultiStatsOptions = {
|
||||
children: Configuration["stats"][];
|
||||
};
|
||||
type NormalizedStatsOptions = Exclude<
|
||||
Configuration["stats"],
|
||||
boolean | string | undefined
|
||||
>;
|
||||
type MultiNormalizedStatsOptions = {
|
||||
children: StatsOptions[];
|
||||
colors?: any;
|
||||
};
|
20
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/setupOutputFileSystem.d.ts
generated
vendored
Executable file
20
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/setupOutputFileSystem.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,20 @@
|
|||
/// <reference types="node" />
|
||||
export = setupOutputFileSystem;
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
declare function setupOutputFileSystem<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(context: import("../index.js").Context<Request_1, Response_1>): void;
|
||||
declare namespace setupOutputFileSystem {
|
||||
export { MultiCompiler, IncomingMessage, ServerResponse };
|
||||
}
|
||||
type MultiCompiler = import("webpack").MultiCompiler;
|
||||
type IncomingMessage = import("../index.js").IncomingMessage;
|
||||
type ServerResponse = import("../index.js").ServerResponse;
|
30
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/setupWriteToDisk.d.ts
generated
vendored
Executable file
30
my-app/node_modules/webpack-dev-server/node_modules/webpack-dev-middleware/types/utils/setupWriteToDisk.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,30 @@
|
|||
/// <reference types="node" />
|
||||
export = setupWriteToDisk;
|
||||
/** @typedef {import("webpack").Compiler} Compiler */
|
||||
/** @typedef {import("webpack").MultiCompiler} MultiCompiler */
|
||||
/** @typedef {import("webpack").Compilation} Compilation */
|
||||
/** @typedef {import("../index.js").IncomingMessage} IncomingMessage */
|
||||
/** @typedef {import("../index.js").ServerResponse} ServerResponse */
|
||||
/**
|
||||
* @template {IncomingMessage} Request
|
||||
* @template {ServerResponse} Response
|
||||
* @param {import("../index.js").Context<Request, Response>} context
|
||||
*/
|
||||
declare function setupWriteToDisk<
|
||||
Request_1 extends import("http").IncomingMessage,
|
||||
Response_1 extends import("../index.js").ServerResponse
|
||||
>(context: import("../index.js").Context<Request_1, Response_1>): void;
|
||||
declare namespace setupWriteToDisk {
|
||||
export {
|
||||
Compiler,
|
||||
MultiCompiler,
|
||||
Compilation,
|
||||
IncomingMessage,
|
||||
ServerResponse,
|
||||
};
|
||||
}
|
||||
type Compiler = import("webpack").Compiler;
|
||||
type MultiCompiler = import("webpack").MultiCompiler;
|
||||
type Compilation = import("webpack").Compilation;
|
||||
type IncomingMessage = import("../index.js").IncomingMessage;
|
||||
type ServerResponse = import("../index.js").ServerResponse;
|
20
my-app/node_modules/webpack-dev-server/node_modules/ws/LICENSE
generated
vendored
Executable file
20
my-app/node_modules/webpack-dev-server/node_modules/ws/LICENSE
generated
vendored
Executable file
|
@ -0,0 +1,20 @@
|
|||
Copyright (c) 2011 Einar Otto Stangvik <einaros@gmail.com>
|
||||
Copyright (c) 2013 Arnout Kazemier and contributors
|
||||
Copyright (c) 2016 Luigi Pinca and contributors
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
this software and associated documentation files (the "Software"), to deal in
|
||||
the Software without restriction, including without limitation the rights to
|
||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
549
my-app/node_modules/webpack-dev-server/node_modules/ws/README.md
generated
vendored
Executable file
549
my-app/node_modules/webpack-dev-server/node_modules/ws/README.md
generated
vendored
Executable file
|
@ -0,0 +1,549 @@
|
|||
# ws: a Node.js WebSocket library
|
||||
|
||||
[](https://www.npmjs.com/package/ws)
|
||||
[](https://github.com/websockets/ws/actions?query=workflow%3ACI+branch%3Amaster)
|
||||
[](https://coveralls.io/github/websockets/ws)
|
||||
|
||||
ws is a simple to use, blazing fast, and thoroughly tested WebSocket client and
|
||||
server implementation.
|
||||
|
||||
Passes the quite extensive Autobahn test suite: [server][server-report],
|
||||
[client][client-report].
|
||||
|
||||
**Note**: This module does not work in the browser. The client in the docs is a
|
||||
reference to a back end with the role of a client in the WebSocket
|
||||
communication. Browser clients must use the native
|
||||
[`WebSocket`](https://developer.mozilla.org/en-US/docs/Web/API/WebSocket)
|
||||
object. To make the same code work seamlessly on Node.js and the browser, you
|
||||
can use one of the many wrappers available on npm, like
|
||||
[isomorphic-ws](https://github.com/heineiuo/isomorphic-ws).
|
||||
|
||||
## Table of Contents
|
||||
|
||||
- [Protocol support](#protocol-support)
|
||||
- [Installing](#installing)
|
||||
- [Opt-in for performance](#opt-in-for-performance)
|
||||
- [Legacy opt-in for performance](#legacy-opt-in-for-performance)
|
||||
- [API docs](#api-docs)
|
||||
- [WebSocket compression](#websocket-compression)
|
||||
- [Usage examples](#usage-examples)
|
||||
- [Sending and receiving text data](#sending-and-receiving-text-data)
|
||||
- [Sending binary data](#sending-binary-data)
|
||||
- [Simple server](#simple-server)
|
||||
- [External HTTP/S server](#external-https-server)
|
||||
- [Multiple servers sharing a single HTTP/S server](#multiple-servers-sharing-a-single-https-server)
|
||||
- [Client authentication](#client-authentication)
|
||||
- [Server broadcast](#server-broadcast)
|
||||
- [Round-trip time](#round-trip-time)
|
||||
- [Use the Node.js streams API](#use-the-nodejs-streams-api)
|
||||
- [Other examples](#other-examples)
|
||||
- [FAQ](#faq)
|
||||
- [How to get the IP address of the client?](#how-to-get-the-ip-address-of-the-client)
|
||||
- [How to detect and close broken connections?](#how-to-detect-and-close-broken-connections)
|
||||
- [How to connect via a proxy?](#how-to-connect-via-a-proxy)
|
||||
- [Changelog](#changelog)
|
||||
- [License](#license)
|
||||
|
||||
## Protocol support
|
||||
|
||||
- **HyBi drafts 07-12** (Use the option `protocolVersion: 8`)
|
||||
- **HyBi drafts 13-17** (Current default, alternatively option
|
||||
`protocolVersion: 13`)
|
||||
|
||||
## Installing
|
||||
|
||||
```
|
||||
npm install ws
|
||||
```
|
||||
|
||||
### Opt-in for performance
|
||||
|
||||
[bufferutil][] is an optional module that can be installed alongside the ws
|
||||
module:
|
||||
|
||||
```
|
||||
npm install --save-optional bufferutil
|
||||
```
|
||||
|
||||
This is a binary addon that improves the performance of certain operations such
|
||||
as masking and unmasking the data payload of the WebSocket frames. Prebuilt
|
||||
binaries are available for the most popular platforms, so you don't necessarily
|
||||
need to have a C++ compiler installed on your machine.
|
||||
|
||||
To force ws to not use bufferutil, use the
|
||||
[`WS_NO_BUFFER_UTIL`](./doc/ws.md#ws_no_buffer_util) environment variable. This
|
||||
can be useful to enhance security in systems where a user can put a package in
|
||||
the package search path of an application of another user, due to how the
|
||||
Node.js resolver algorithm works.
|
||||
|
||||
#### Legacy opt-in for performance
|
||||
|
||||
If you are running on an old version of Node.js (prior to v18.14.0), ws also
|
||||
supports the [utf-8-validate][] module:
|
||||
|
||||
```
|
||||
npm install --save-optional utf-8-validate
|
||||
```
|
||||
|
||||
This contains a binary polyfill for [`buffer.isUtf8()`][].
|
||||
|
||||
To force ws to not use utf-8-validate, use the
|
||||
[`WS_NO_UTF_8_VALIDATE`](./doc/ws.md#ws_no_utf_8_validate) environment variable.
|
||||
|
||||
## API docs
|
||||
|
||||
See [`/doc/ws.md`](./doc/ws.md) for Node.js-like documentation of ws classes and
|
||||
utility functions.
|
||||
|
||||
## WebSocket compression
|
||||
|
||||
ws supports the [permessage-deflate extension][permessage-deflate] which enables
|
||||
the client and server to negotiate a compression algorithm and its parameters,
|
||||
and then selectively apply it to the data payloads of each WebSocket message.
|
||||
|
||||
The extension is disabled by default on the server and enabled by default on the
|
||||
client. It adds a significant overhead in terms of performance and memory
|
||||
consumption so we suggest to enable it only if it is really needed.
|
||||
|
||||
Note that Node.js has a variety of issues with high-performance compression,
|
||||
where increased concurrency, especially on Linux, can lead to [catastrophic
|
||||
memory fragmentation][node-zlib-bug] and slow performance. If you intend to use
|
||||
permessage-deflate in production, it is worthwhile to set up a test
|
||||
representative of your workload and ensure Node.js/zlib will handle it with
|
||||
acceptable performance and memory usage.
|
||||
|
||||
Tuning of permessage-deflate can be done via the options defined below. You can
|
||||
also use `zlibDeflateOptions` and `zlibInflateOptions`, which is passed directly
|
||||
into the creation of [raw deflate/inflate streams][node-zlib-deflaterawdocs].
|
||||
|
||||
See [the docs][ws-server-options] for more options.
|
||||
|
||||
```js
|
||||
import WebSocket, { WebSocketServer } from 'ws';
|
||||
|
||||
const wss = new WebSocketServer({
|
||||
port: 8080,
|
||||
perMessageDeflate: {
|
||||
zlibDeflateOptions: {
|
||||
// See zlib defaults.
|
||||
chunkSize: 1024,
|
||||
memLevel: 7,
|
||||
level: 3
|
||||
},
|
||||
zlibInflateOptions: {
|
||||
chunkSize: 10 * 1024
|
||||
},
|
||||
// Other options settable:
|
||||
clientNoContextTakeover: true, // Defaults to negotiated value.
|
||||
serverNoContextTakeover: true, // Defaults to negotiated value.
|
||||
serverMaxWindowBits: 10, // Defaults to negotiated value.
|
||||
// Below options specified as default values.
|
||||
concurrencyLimit: 10, // Limits zlib concurrency for perf.
|
||||
threshold: 1024 // Size (in bytes) below which messages
|
||||
// should not be compressed if context takeover is disabled.
|
||||
}
|
||||
});
|
||||
```
|
||||
|
||||
The client will only use the extension if it is supported and enabled on the
|
||||
server. To always disable the extension on the client set the
|
||||
`perMessageDeflate` option to `false`.
|
||||
|
||||
```js
|
||||
import WebSocket from 'ws';
|
||||
|
||||
const ws = new WebSocket('ws://www.host.com/path', {
|
||||
perMessageDeflate: false
|
||||
});
|
||||
```
|
||||
|
||||
## Usage examples
|
||||
|
||||
### Sending and receiving text data
|
||||
|
||||
```js
|
||||
import WebSocket from 'ws';
|
||||
|
||||
const ws = new WebSocket('ws://www.host.com/path');
|
||||
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('open', function open() {
|
||||
ws.send('something');
|
||||
});
|
||||
|
||||
ws.on('message', function message(data) {
|
||||
console.log('received: %s', data);
|
||||
});
|
||||
```
|
||||
|
||||
### Sending binary data
|
||||
|
||||
```js
|
||||
import WebSocket from 'ws';
|
||||
|
||||
const ws = new WebSocket('ws://www.host.com/path');
|
||||
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('open', function open() {
|
||||
const array = new Float32Array(5);
|
||||
|
||||
for (var i = 0; i < array.length; ++i) {
|
||||
array[i] = i / 2;
|
||||
}
|
||||
|
||||
ws.send(array);
|
||||
});
|
||||
```
|
||||
|
||||
### Simple server
|
||||
|
||||
```js
|
||||
import { WebSocketServer } from 'ws';
|
||||
|
||||
const wss = new WebSocketServer({ port: 8080 });
|
||||
|
||||
wss.on('connection', function connection(ws) {
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('message', function message(data) {
|
||||
console.log('received: %s', data);
|
||||
});
|
||||
|
||||
ws.send('something');
|
||||
});
|
||||
```
|
||||
|
||||
### External HTTP/S server
|
||||
|
||||
```js
|
||||
import { createServer } from 'https';
|
||||
import { readFileSync } from 'fs';
|
||||
import { WebSocketServer } from 'ws';
|
||||
|
||||
const server = createServer({
|
||||
cert: readFileSync('/path/to/cert.pem'),
|
||||
key: readFileSync('/path/to/key.pem')
|
||||
});
|
||||
const wss = new WebSocketServer({ server });
|
||||
|
||||
wss.on('connection', function connection(ws) {
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('message', function message(data) {
|
||||
console.log('received: %s', data);
|
||||
});
|
||||
|
||||
ws.send('something');
|
||||
});
|
||||
|
||||
server.listen(8080);
|
||||
```
|
||||
|
||||
### Multiple servers sharing a single HTTP/S server
|
||||
|
||||
```js
|
||||
import { createServer } from 'http';
|
||||
import { parse } from 'url';
|
||||
import { WebSocketServer } from 'ws';
|
||||
|
||||
const server = createServer();
|
||||
const wss1 = new WebSocketServer({ noServer: true });
|
||||
const wss2 = new WebSocketServer({ noServer: true });
|
||||
|
||||
wss1.on('connection', function connection(ws) {
|
||||
ws.on('error', console.error);
|
||||
|
||||
// ...
|
||||
});
|
||||
|
||||
wss2.on('connection', function connection(ws) {
|
||||
ws.on('error', console.error);
|
||||
|
||||
// ...
|
||||
});
|
||||
|
||||
server.on('upgrade', function upgrade(request, socket, head) {
|
||||
const { pathname } = parse(request.url);
|
||||
|
||||
if (pathname === '/foo') {
|
||||
wss1.handleUpgrade(request, socket, head, function done(ws) {
|
||||
wss1.emit('connection', ws, request);
|
||||
});
|
||||
} else if (pathname === '/bar') {
|
||||
wss2.handleUpgrade(request, socket, head, function done(ws) {
|
||||
wss2.emit('connection', ws, request);
|
||||
});
|
||||
} else {
|
||||
socket.destroy();
|
||||
}
|
||||
});
|
||||
|
||||
server.listen(8080);
|
||||
```
|
||||
|
||||
### Client authentication
|
||||
|
||||
```js
|
||||
import { createServer } from 'http';
|
||||
import { WebSocketServer } from 'ws';
|
||||
|
||||
function onSocketError(err) {
|
||||
console.error(err);
|
||||
}
|
||||
|
||||
const server = createServer();
|
||||
const wss = new WebSocketServer({ noServer: true });
|
||||
|
||||
wss.on('connection', function connection(ws, request, client) {
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('message', function message(data) {
|
||||
console.log(`Received message ${data} from user ${client}`);
|
||||
});
|
||||
});
|
||||
|
||||
server.on('upgrade', function upgrade(request, socket, head) {
|
||||
socket.on('error', onSocketError);
|
||||
|
||||
// This function is not defined on purpose. Implement it with your own logic.
|
||||
authenticate(request, function next(err, client) {
|
||||
if (err || !client) {
|
||||
socket.write('HTTP/1.1 401 Unauthorized\r\n\r\n');
|
||||
socket.destroy();
|
||||
return;
|
||||
}
|
||||
|
||||
socket.removeListener('error', onSocketError);
|
||||
|
||||
wss.handleUpgrade(request, socket, head, function done(ws) {
|
||||
wss.emit('connection', ws, request, client);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
server.listen(8080);
|
||||
```
|
||||
|
||||
Also see the provided [example][session-parse-example] using `express-session`.
|
||||
|
||||
### Server broadcast
|
||||
|
||||
A client WebSocket broadcasting to all connected WebSocket clients, including
|
||||
itself.
|
||||
|
||||
```js
|
||||
import WebSocket, { WebSocketServer } from 'ws';
|
||||
|
||||
const wss = new WebSocketServer({ port: 8080 });
|
||||
|
||||
wss.on('connection', function connection(ws) {
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('message', function message(data, isBinary) {
|
||||
wss.clients.forEach(function each(client) {
|
||||
if (client.readyState === WebSocket.OPEN) {
|
||||
client.send(data, { binary: isBinary });
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
```
|
||||
|
||||
A client WebSocket broadcasting to every other connected WebSocket clients,
|
||||
excluding itself.
|
||||
|
||||
```js
|
||||
import WebSocket, { WebSocketServer } from 'ws';
|
||||
|
||||
const wss = new WebSocketServer({ port: 8080 });
|
||||
|
||||
wss.on('connection', function connection(ws) {
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('message', function message(data, isBinary) {
|
||||
wss.clients.forEach(function each(client) {
|
||||
if (client !== ws && client.readyState === WebSocket.OPEN) {
|
||||
client.send(data, { binary: isBinary });
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
```
|
||||
|
||||
### Round-trip time
|
||||
|
||||
```js
|
||||
import WebSocket from 'ws';
|
||||
|
||||
const ws = new WebSocket('wss://websocket-echo.com/');
|
||||
|
||||
ws.on('error', console.error);
|
||||
|
||||
ws.on('open', function open() {
|
||||
console.log('connected');
|
||||
ws.send(Date.now());
|
||||
});
|
||||
|
||||
ws.on('close', function close() {
|
||||
console.log('disconnected');
|
||||
});
|
||||
|
||||
ws.on('message', function message(data) {
|
||||
console.log(`Round-trip time: ${Date.now() - data} ms`);
|
||||
|
||||
setTimeout(function timeout() {
|
||||
ws.send(Date.now());
|
||||
}, 500);
|
||||
});
|
||||
```
|
||||
|
||||
### Use the Node.js streams API
|
||||
|
||||
```js
|
||||
import WebSocket, { createWebSocketStream } from 'ws';
|
||||
|
||||
const ws = new WebSocket('wss://websocket-echo.com/');
|
||||
|
||||
const duplex = createWebSocketStream(ws, { encoding: 'utf8' });
|
||||
|
||||
duplex.on('error', console.error);
|
||||
|
||||
duplex.pipe(process.stdout);
|
||||
process.stdin.pipe(duplex);
|
||||
```
|
||||
|
||||
### Other examples
|
||||
|
||||
For a full example with a browser client communicating with a ws server, see the
|
||||
examples folder.
|
||||
|
||||
Otherwise, see the test cases.
|
||||
|
||||
## FAQ
|
||||
|
||||
### How to get the IP address of the client?
|
||||
|
||||
The remote IP address can be obtained from the raw socket.
|
||||
|
||||
```js
|
||||
import { WebSocketServer } from 'ws';
|
||||
|
||||
const wss = new WebSocketServer({ port: 8080 });
|
||||
|
||||
wss.on('connection', function connection(ws, req) {
|
||||
const ip = req.socket.remoteAddress;
|
||||
|
||||
ws.on('error', console.error);
|
||||
});
|
||||
```
|
||||
|
||||
When the server runs behind a proxy like NGINX, the de-facto standard is to use
|
||||
the `X-Forwarded-For` header.
|
||||
|
||||
```js
|
||||
wss.on('connection', function connection(ws, req) {
|
||||
const ip = req.headers['x-forwarded-for'].split(',')[0].trim();
|
||||
|
||||
ws.on('error', console.error);
|
||||
});
|
||||
```
|
||||
|
||||
### How to detect and close broken connections?
|
||||
|
||||
Sometimes the link between the server and the client can be interrupted in a way
|
||||
that keeps both the server and the client unaware of the broken state of the
|
||||
connection (e.g. when pulling the cord).
|
||||
|
||||
In these cases ping messages can be used as a means to verify that the remote
|
||||
endpoint is still responsive.
|
||||
|
||||
```js
|
||||
import { WebSocketServer } from 'ws';
|
||||
|
||||
function heartbeat() {
|
||||
this.isAlive = true;
|
||||
}
|
||||
|
||||
const wss = new WebSocketServer({ port: 8080 });
|
||||
|
||||
wss.on('connection', function connection(ws) {
|
||||
ws.isAlive = true;
|
||||
ws.on('error', console.error);
|
||||
ws.on('pong', heartbeat);
|
||||
});
|
||||
|
||||
const interval = setInterval(function ping() {
|
||||
wss.clients.forEach(function each(ws) {
|
||||
if (ws.isAlive === false) return ws.terminate();
|
||||
|
||||
ws.isAlive = false;
|
||||
ws.ping();
|
||||
});
|
||||
}, 30000);
|
||||
|
||||
wss.on('close', function close() {
|
||||
clearInterval(interval);
|
||||
});
|
||||
```
|
||||
|
||||
Pong messages are automatically sent in response to ping messages as required by
|
||||
the spec.
|
||||
|
||||
Just like the server example above your clients might as well lose connection
|
||||
without knowing it. You might want to add a ping listener on your clients to
|
||||
prevent that. A simple implementation would be:
|
||||
|
||||
```js
|
||||
import WebSocket from 'ws';
|
||||
|
||||
function heartbeat() {
|
||||
clearTimeout(this.pingTimeout);
|
||||
|
||||
// Use `WebSocket#terminate()`, which immediately destroys the connection,
|
||||
// instead of `WebSocket#close()`, which waits for the close timer.
|
||||
// Delay should be equal to the interval at which your server
|
||||
// sends out pings plus a conservative assumption of the latency.
|
||||
this.pingTimeout = setTimeout(() => {
|
||||
this.terminate();
|
||||
}, 30000 + 1000);
|
||||
}
|
||||
|
||||
const client = new WebSocket('wss://websocket-echo.com/');
|
||||
|
||||
client.on('error', console.error);
|
||||
client.on('open', heartbeat);
|
||||
client.on('ping', heartbeat);
|
||||
client.on('close', function clear() {
|
||||
clearTimeout(this.pingTimeout);
|
||||
});
|
||||
```
|
||||
|
||||
### How to connect via a proxy?
|
||||
|
||||
Use a custom `http.Agent` implementation like [https-proxy-agent][] or
|
||||
[socks-proxy-agent][].
|
||||
|
||||
## Changelog
|
||||
|
||||
We're using the GitHub [releases][changelog] for changelog entries.
|
||||
|
||||
## License
|
||||
|
||||
[MIT](LICENSE)
|
||||
|
||||
[`buffer.isutf8()`]: https://nodejs.org/api/buffer.html#bufferisutf8input
|
||||
[bufferutil]: https://github.com/websockets/bufferutil
|
||||
[changelog]: https://github.com/websockets/ws/releases
|
||||
[client-report]: http://websockets.github.io/ws/autobahn/clients/
|
||||
[https-proxy-agent]: https://github.com/TooTallNate/node-https-proxy-agent
|
||||
[node-zlib-bug]: https://github.com/nodejs/node/issues/8871
|
||||
[node-zlib-deflaterawdocs]:
|
||||
https://nodejs.org/api/zlib.html#zlib_zlib_createdeflateraw_options
|
||||
[permessage-deflate]: https://tools.ietf.org/html/rfc7692
|
||||
[server-report]: http://websockets.github.io/ws/autobahn/servers/
|
||||
[session-parse-example]: ./examples/express-session-parse
|
||||
[socks-proxy-agent]: https://github.com/TooTallNate/node-socks-proxy-agent
|
||||
[utf-8-validate]: https://github.com/websockets/utf-8-validate
|
||||
[ws-server-options]: ./doc/ws.md#new-websocketserveroptions-callback
|
8
my-app/node_modules/webpack-dev-server/node_modules/ws/browser.js
generated
vendored
Executable file
8
my-app/node_modules/webpack-dev-server/node_modules/ws/browser.js
generated
vendored
Executable file
|
@ -0,0 +1,8 @@
|
|||
'use strict';
|
||||
|
||||
module.exports = function () {
|
||||
throw new Error(
|
||||
'ws does not work in the browser. Browser clients must use the native ' +
|
||||
'WebSocket object'
|
||||
);
|
||||
};
|
13
my-app/node_modules/webpack-dev-server/node_modules/ws/index.js
generated
vendored
Executable file
13
my-app/node_modules/webpack-dev-server/node_modules/ws/index.js
generated
vendored
Executable file
|
@ -0,0 +1,13 @@
|
|||
'use strict';
|
||||
|
||||
const WebSocket = require('./lib/websocket');
|
||||
|
||||
WebSocket.createWebSocketStream = require('./lib/stream');
|
||||
WebSocket.Server = require('./lib/websocket-server');
|
||||
WebSocket.Receiver = require('./lib/receiver');
|
||||
WebSocket.Sender = require('./lib/sender');
|
||||
|
||||
WebSocket.WebSocket = WebSocket;
|
||||
WebSocket.WebSocketServer = WebSocket.Server;
|
||||
|
||||
module.exports = WebSocket;
|
131
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/buffer-util.js
generated
vendored
Executable file
131
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/buffer-util.js
generated
vendored
Executable file
|
@ -0,0 +1,131 @@
|
|||
'use strict';
|
||||
|
||||
const { EMPTY_BUFFER } = require('./constants');
|
||||
|
||||
const FastBuffer = Buffer[Symbol.species];
|
||||
|
||||
/**
|
||||
* Merges an array of buffers into a new buffer.
|
||||
*
|
||||
* @param {Buffer[]} list The array of buffers to concat
|
||||
* @param {Number} totalLength The total length of buffers in the list
|
||||
* @return {Buffer} The resulting buffer
|
||||
* @public
|
||||
*/
|
||||
function concat(list, totalLength) {
|
||||
if (list.length === 0) return EMPTY_BUFFER;
|
||||
if (list.length === 1) return list[0];
|
||||
|
||||
const target = Buffer.allocUnsafe(totalLength);
|
||||
let offset = 0;
|
||||
|
||||
for (let i = 0; i < list.length; i++) {
|
||||
const buf = list[i];
|
||||
target.set(buf, offset);
|
||||
offset += buf.length;
|
||||
}
|
||||
|
||||
if (offset < totalLength) {
|
||||
return new FastBuffer(target.buffer, target.byteOffset, offset);
|
||||
}
|
||||
|
||||
return target;
|
||||
}
|
||||
|
||||
/**
|
||||
* Masks a buffer using the given mask.
|
||||
*
|
||||
* @param {Buffer} source The buffer to mask
|
||||
* @param {Buffer} mask The mask to use
|
||||
* @param {Buffer} output The buffer where to store the result
|
||||
* @param {Number} offset The offset at which to start writing
|
||||
* @param {Number} length The number of bytes to mask.
|
||||
* @public
|
||||
*/
|
||||
function _mask(source, mask, output, offset, length) {
|
||||
for (let i = 0; i < length; i++) {
|
||||
output[offset + i] = source[i] ^ mask[i & 3];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Unmasks a buffer using the given mask.
|
||||
*
|
||||
* @param {Buffer} buffer The buffer to unmask
|
||||
* @param {Buffer} mask The mask to use
|
||||
* @public
|
||||
*/
|
||||
function _unmask(buffer, mask) {
|
||||
for (let i = 0; i < buffer.length; i++) {
|
||||
buffer[i] ^= mask[i & 3];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Converts a buffer to an `ArrayBuffer`.
|
||||
*
|
||||
* @param {Buffer} buf The buffer to convert
|
||||
* @return {ArrayBuffer} Converted buffer
|
||||
* @public
|
||||
*/
|
||||
function toArrayBuffer(buf) {
|
||||
if (buf.length === buf.buffer.byteLength) {
|
||||
return buf.buffer;
|
||||
}
|
||||
|
||||
return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.length);
|
||||
}
|
||||
|
||||
/**
|
||||
* Converts `data` to a `Buffer`.
|
||||
*
|
||||
* @param {*} data The data to convert
|
||||
* @return {Buffer} The buffer
|
||||
* @throws {TypeError}
|
||||
* @public
|
||||
*/
|
||||
function toBuffer(data) {
|
||||
toBuffer.readOnly = true;
|
||||
|
||||
if (Buffer.isBuffer(data)) return data;
|
||||
|
||||
let buf;
|
||||
|
||||
if (data instanceof ArrayBuffer) {
|
||||
buf = new FastBuffer(data);
|
||||
} else if (ArrayBuffer.isView(data)) {
|
||||
buf = new FastBuffer(data.buffer, data.byteOffset, data.byteLength);
|
||||
} else {
|
||||
buf = Buffer.from(data);
|
||||
toBuffer.readOnly = false;
|
||||
}
|
||||
|
||||
return buf;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
concat,
|
||||
mask: _mask,
|
||||
toArrayBuffer,
|
||||
toBuffer,
|
||||
unmask: _unmask
|
||||
};
|
||||
|
||||
/* istanbul ignore else */
|
||||
if (!process.env.WS_NO_BUFFER_UTIL) {
|
||||
try {
|
||||
const bufferUtil = require('bufferutil');
|
||||
|
||||
module.exports.mask = function (source, mask, output, offset, length) {
|
||||
if (length < 48) _mask(source, mask, output, offset, length);
|
||||
else bufferUtil.mask(source, mask, output, offset, length);
|
||||
};
|
||||
|
||||
module.exports.unmask = function (buffer, mask) {
|
||||
if (buffer.length < 32) _unmask(buffer, mask);
|
||||
else bufferUtil.unmask(buffer, mask);
|
||||
};
|
||||
} catch (e) {
|
||||
// Continue regardless of the error.
|
||||
}
|
||||
}
|
12
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/constants.js
generated
vendored
Executable file
12
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/constants.js
generated
vendored
Executable file
|
@ -0,0 +1,12 @@
|
|||
'use strict';
|
||||
|
||||
module.exports = {
|
||||
BINARY_TYPES: ['nodebuffer', 'arraybuffer', 'fragments'],
|
||||
EMPTY_BUFFER: Buffer.alloc(0),
|
||||
GUID: '258EAFA5-E914-47DA-95CA-C5AB0DC85B11',
|
||||
kForOnEventAttribute: Symbol('kIsForOnEventAttribute'),
|
||||
kListener: Symbol('kListener'),
|
||||
kStatusCode: Symbol('status-code'),
|
||||
kWebSocket: Symbol('websocket'),
|
||||
NOOP: () => {}
|
||||
};
|
292
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/event-target.js
generated
vendored
Executable file
292
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/event-target.js
generated
vendored
Executable file
|
@ -0,0 +1,292 @@
|
|||
'use strict';
|
||||
|
||||
const { kForOnEventAttribute, kListener } = require('./constants');
|
||||
|
||||
const kCode = Symbol('kCode');
|
||||
const kData = Symbol('kData');
|
||||
const kError = Symbol('kError');
|
||||
const kMessage = Symbol('kMessage');
|
||||
const kReason = Symbol('kReason');
|
||||
const kTarget = Symbol('kTarget');
|
||||
const kType = Symbol('kType');
|
||||
const kWasClean = Symbol('kWasClean');
|
||||
|
||||
/**
|
||||
* Class representing an event.
|
||||
*/
|
||||
class Event {
|
||||
/**
|
||||
* Create a new `Event`.
|
||||
*
|
||||
* @param {String} type The name of the event
|
||||
* @throws {TypeError} If the `type` argument is not specified
|
||||
*/
|
||||
constructor(type) {
|
||||
this[kTarget] = null;
|
||||
this[kType] = type;
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {*}
|
||||
*/
|
||||
get target() {
|
||||
return this[kTarget];
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {String}
|
||||
*/
|
||||
get type() {
|
||||
return this[kType];
|
||||
}
|
||||
}
|
||||
|
||||
Object.defineProperty(Event.prototype, 'target', { enumerable: true });
|
||||
Object.defineProperty(Event.prototype, 'type', { enumerable: true });
|
||||
|
||||
/**
|
||||
* Class representing a close event.
|
||||
*
|
||||
* @extends Event
|
||||
*/
|
||||
class CloseEvent extends Event {
|
||||
/**
|
||||
* Create a new `CloseEvent`.
|
||||
*
|
||||
* @param {String} type The name of the event
|
||||
* @param {Object} [options] A dictionary object that allows for setting
|
||||
* attributes via object members of the same name
|
||||
* @param {Number} [options.code=0] The status code explaining why the
|
||||
* connection was closed
|
||||
* @param {String} [options.reason=''] A human-readable string explaining why
|
||||
* the connection was closed
|
||||
* @param {Boolean} [options.wasClean=false] Indicates whether or not the
|
||||
* connection was cleanly closed
|
||||
*/
|
||||
constructor(type, options = {}) {
|
||||
super(type);
|
||||
|
||||
this[kCode] = options.code === undefined ? 0 : options.code;
|
||||
this[kReason] = options.reason === undefined ? '' : options.reason;
|
||||
this[kWasClean] = options.wasClean === undefined ? false : options.wasClean;
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {Number}
|
||||
*/
|
||||
get code() {
|
||||
return this[kCode];
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {String}
|
||||
*/
|
||||
get reason() {
|
||||
return this[kReason];
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {Boolean}
|
||||
*/
|
||||
get wasClean() {
|
||||
return this[kWasClean];
|
||||
}
|
||||
}
|
||||
|
||||
Object.defineProperty(CloseEvent.prototype, 'code', { enumerable: true });
|
||||
Object.defineProperty(CloseEvent.prototype, 'reason', { enumerable: true });
|
||||
Object.defineProperty(CloseEvent.prototype, 'wasClean', { enumerable: true });
|
||||
|
||||
/**
|
||||
* Class representing an error event.
|
||||
*
|
||||
* @extends Event
|
||||
*/
|
||||
class ErrorEvent extends Event {
|
||||
/**
|
||||
* Create a new `ErrorEvent`.
|
||||
*
|
||||
* @param {String} type The name of the event
|
||||
* @param {Object} [options] A dictionary object that allows for setting
|
||||
* attributes via object members of the same name
|
||||
* @param {*} [options.error=null] The error that generated this event
|
||||
* @param {String} [options.message=''] The error message
|
||||
*/
|
||||
constructor(type, options = {}) {
|
||||
super(type);
|
||||
|
||||
this[kError] = options.error === undefined ? null : options.error;
|
||||
this[kMessage] = options.message === undefined ? '' : options.message;
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {*}
|
||||
*/
|
||||
get error() {
|
||||
return this[kError];
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {String}
|
||||
*/
|
||||
get message() {
|
||||
return this[kMessage];
|
||||
}
|
||||
}
|
||||
|
||||
Object.defineProperty(ErrorEvent.prototype, 'error', { enumerable: true });
|
||||
Object.defineProperty(ErrorEvent.prototype, 'message', { enumerable: true });
|
||||
|
||||
/**
|
||||
* Class representing a message event.
|
||||
*
|
||||
* @extends Event
|
||||
*/
|
||||
class MessageEvent extends Event {
|
||||
/**
|
||||
* Create a new `MessageEvent`.
|
||||
*
|
||||
* @param {String} type The name of the event
|
||||
* @param {Object} [options] A dictionary object that allows for setting
|
||||
* attributes via object members of the same name
|
||||
* @param {*} [options.data=null] The message content
|
||||
*/
|
||||
constructor(type, options = {}) {
|
||||
super(type);
|
||||
|
||||
this[kData] = options.data === undefined ? null : options.data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {*}
|
||||
*/
|
||||
get data() {
|
||||
return this[kData];
|
||||
}
|
||||
}
|
||||
|
||||
Object.defineProperty(MessageEvent.prototype, 'data', { enumerable: true });
|
||||
|
||||
/**
|
||||
* This provides methods for emulating the `EventTarget` interface. It's not
|
||||
* meant to be used directly.
|
||||
*
|
||||
* @mixin
|
||||
*/
|
||||
const EventTarget = {
|
||||
/**
|
||||
* Register an event listener.
|
||||
*
|
||||
* @param {String} type A string representing the event type to listen for
|
||||
* @param {(Function|Object)} handler The listener to add
|
||||
* @param {Object} [options] An options object specifies characteristics about
|
||||
* the event listener
|
||||
* @param {Boolean} [options.once=false] A `Boolean` indicating that the
|
||||
* listener should be invoked at most once after being added. If `true`,
|
||||
* the listener would be automatically removed when invoked.
|
||||
* @public
|
||||
*/
|
||||
addEventListener(type, handler, options = {}) {
|
||||
for (const listener of this.listeners(type)) {
|
||||
if (
|
||||
!options[kForOnEventAttribute] &&
|
||||
listener[kListener] === handler &&
|
||||
!listener[kForOnEventAttribute]
|
||||
) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
let wrapper;
|
||||
|
||||
if (type === 'message') {
|
||||
wrapper = function onMessage(data, isBinary) {
|
||||
const event = new MessageEvent('message', {
|
||||
data: isBinary ? data : data.toString()
|
||||
});
|
||||
|
||||
event[kTarget] = this;
|
||||
callListener(handler, this, event);
|
||||
};
|
||||
} else if (type === 'close') {
|
||||
wrapper = function onClose(code, message) {
|
||||
const event = new CloseEvent('close', {
|
||||
code,
|
||||
reason: message.toString(),
|
||||
wasClean: this._closeFrameReceived && this._closeFrameSent
|
||||
});
|
||||
|
||||
event[kTarget] = this;
|
||||
callListener(handler, this, event);
|
||||
};
|
||||
} else if (type === 'error') {
|
||||
wrapper = function onError(error) {
|
||||
const event = new ErrorEvent('error', {
|
||||
error,
|
||||
message: error.message
|
||||
});
|
||||
|
||||
event[kTarget] = this;
|
||||
callListener(handler, this, event);
|
||||
};
|
||||
} else if (type === 'open') {
|
||||
wrapper = function onOpen() {
|
||||
const event = new Event('open');
|
||||
|
||||
event[kTarget] = this;
|
||||
callListener(handler, this, event);
|
||||
};
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
|
||||
wrapper[kForOnEventAttribute] = !!options[kForOnEventAttribute];
|
||||
wrapper[kListener] = handler;
|
||||
|
||||
if (options.once) {
|
||||
this.once(type, wrapper);
|
||||
} else {
|
||||
this.on(type, wrapper);
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Remove an event listener.
|
||||
*
|
||||
* @param {String} type A string representing the event type to remove
|
||||
* @param {(Function|Object)} handler The listener to remove
|
||||
* @public
|
||||
*/
|
||||
removeEventListener(type, handler) {
|
||||
for (const listener of this.listeners(type)) {
|
||||
if (listener[kListener] === handler && !listener[kForOnEventAttribute]) {
|
||||
this.removeListener(type, listener);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
module.exports = {
|
||||
CloseEvent,
|
||||
ErrorEvent,
|
||||
Event,
|
||||
EventTarget,
|
||||
MessageEvent
|
||||
};
|
||||
|
||||
/**
|
||||
* Call an event listener
|
||||
*
|
||||
* @param {(Function|Object)} listener The listener to call
|
||||
* @param {*} thisArg The value to use as `this`` when calling the listener
|
||||
* @param {Event} event The event to pass to the listener
|
||||
* @private
|
||||
*/
|
||||
function callListener(listener, thisArg, event) {
|
||||
if (typeof listener === 'object' && listener.handleEvent) {
|
||||
listener.handleEvent.call(listener, event);
|
||||
} else {
|
||||
listener.call(thisArg, event);
|
||||
}
|
||||
}
|
203
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/extension.js
generated
vendored
Executable file
203
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/extension.js
generated
vendored
Executable file
|
@ -0,0 +1,203 @@
|
|||
'use strict';
|
||||
|
||||
const { tokenChars } = require('./validation');
|
||||
|
||||
/**
|
||||
* Adds an offer to the map of extension offers or a parameter to the map of
|
||||
* parameters.
|
||||
*
|
||||
* @param {Object} dest The map of extension offers or parameters
|
||||
* @param {String} name The extension or parameter name
|
||||
* @param {(Object|Boolean|String)} elem The extension parameters or the
|
||||
* parameter value
|
||||
* @private
|
||||
*/
|
||||
function push(dest, name, elem) {
|
||||
if (dest[name] === undefined) dest[name] = [elem];
|
||||
else dest[name].push(elem);
|
||||
}
|
||||
|
||||
/**
|
||||
* Parses the `Sec-WebSocket-Extensions` header into an object.
|
||||
*
|
||||
* @param {String} header The field value of the header
|
||||
* @return {Object} The parsed object
|
||||
* @public
|
||||
*/
|
||||
function parse(header) {
|
||||
const offers = Object.create(null);
|
||||
let params = Object.create(null);
|
||||
let mustUnescape = false;
|
||||
let isEscaping = false;
|
||||
let inQuotes = false;
|
||||
let extensionName;
|
||||
let paramName;
|
||||
let start = -1;
|
||||
let code = -1;
|
||||
let end = -1;
|
||||
let i = 0;
|
||||
|
||||
for (; i < header.length; i++) {
|
||||
code = header.charCodeAt(i);
|
||||
|
||||
if (extensionName === undefined) {
|
||||
if (end === -1 && tokenChars[code] === 1) {
|
||||
if (start === -1) start = i;
|
||||
} else if (
|
||||
i !== 0 &&
|
||||
(code === 0x20 /* ' ' */ || code === 0x09) /* '\t' */
|
||||
) {
|
||||
if (end === -1 && start !== -1) end = i;
|
||||
} else if (code === 0x3b /* ';' */ || code === 0x2c /* ',' */) {
|
||||
if (start === -1) {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
|
||||
if (end === -1) end = i;
|
||||
const name = header.slice(start, end);
|
||||
if (code === 0x2c) {
|
||||
push(offers, name, params);
|
||||
params = Object.create(null);
|
||||
} else {
|
||||
extensionName = name;
|
||||
}
|
||||
|
||||
start = end = -1;
|
||||
} else {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
} else if (paramName === undefined) {
|
||||
if (end === -1 && tokenChars[code] === 1) {
|
||||
if (start === -1) start = i;
|
||||
} else if (code === 0x20 || code === 0x09) {
|
||||
if (end === -1 && start !== -1) end = i;
|
||||
} else if (code === 0x3b || code === 0x2c) {
|
||||
if (start === -1) {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
|
||||
if (end === -1) end = i;
|
||||
push(params, header.slice(start, end), true);
|
||||
if (code === 0x2c) {
|
||||
push(offers, extensionName, params);
|
||||
params = Object.create(null);
|
||||
extensionName = undefined;
|
||||
}
|
||||
|
||||
start = end = -1;
|
||||
} else if (code === 0x3d /* '=' */ && start !== -1 && end === -1) {
|
||||
paramName = header.slice(start, i);
|
||||
start = end = -1;
|
||||
} else {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
} else {
|
||||
//
|
||||
// The value of a quoted-string after unescaping must conform to the
|
||||
// token ABNF, so only token characters are valid.
|
||||
// Ref: https://tools.ietf.org/html/rfc6455#section-9.1
|
||||
//
|
||||
if (isEscaping) {
|
||||
if (tokenChars[code] !== 1) {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
if (start === -1) start = i;
|
||||
else if (!mustUnescape) mustUnescape = true;
|
||||
isEscaping = false;
|
||||
} else if (inQuotes) {
|
||||
if (tokenChars[code] === 1) {
|
||||
if (start === -1) start = i;
|
||||
} else if (code === 0x22 /* '"' */ && start !== -1) {
|
||||
inQuotes = false;
|
||||
end = i;
|
||||
} else if (code === 0x5c /* '\' */) {
|
||||
isEscaping = true;
|
||||
} else {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
} else if (code === 0x22 && header.charCodeAt(i - 1) === 0x3d) {
|
||||
inQuotes = true;
|
||||
} else if (end === -1 && tokenChars[code] === 1) {
|
||||
if (start === -1) start = i;
|
||||
} else if (start !== -1 && (code === 0x20 || code === 0x09)) {
|
||||
if (end === -1) end = i;
|
||||
} else if (code === 0x3b || code === 0x2c) {
|
||||
if (start === -1) {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
|
||||
if (end === -1) end = i;
|
||||
let value = header.slice(start, end);
|
||||
if (mustUnescape) {
|
||||
value = value.replace(/\\/g, '');
|
||||
mustUnescape = false;
|
||||
}
|
||||
push(params, paramName, value);
|
||||
if (code === 0x2c) {
|
||||
push(offers, extensionName, params);
|
||||
params = Object.create(null);
|
||||
extensionName = undefined;
|
||||
}
|
||||
|
||||
paramName = undefined;
|
||||
start = end = -1;
|
||||
} else {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (start === -1 || inQuotes || code === 0x20 || code === 0x09) {
|
||||
throw new SyntaxError('Unexpected end of input');
|
||||
}
|
||||
|
||||
if (end === -1) end = i;
|
||||
const token = header.slice(start, end);
|
||||
if (extensionName === undefined) {
|
||||
push(offers, token, params);
|
||||
} else {
|
||||
if (paramName === undefined) {
|
||||
push(params, token, true);
|
||||
} else if (mustUnescape) {
|
||||
push(params, paramName, token.replace(/\\/g, ''));
|
||||
} else {
|
||||
push(params, paramName, token);
|
||||
}
|
||||
push(offers, extensionName, params);
|
||||
}
|
||||
|
||||
return offers;
|
||||
}
|
||||
|
||||
/**
|
||||
* Builds the `Sec-WebSocket-Extensions` header field value.
|
||||
*
|
||||
* @param {Object} extensions The map of extensions and parameters to format
|
||||
* @return {String} A string representing the given object
|
||||
* @public
|
||||
*/
|
||||
function format(extensions) {
|
||||
return Object.keys(extensions)
|
||||
.map((extension) => {
|
||||
let configurations = extensions[extension];
|
||||
if (!Array.isArray(configurations)) configurations = [configurations];
|
||||
return configurations
|
||||
.map((params) => {
|
||||
return [extension]
|
||||
.concat(
|
||||
Object.keys(params).map((k) => {
|
||||
let values = params[k];
|
||||
if (!Array.isArray(values)) values = [values];
|
||||
return values
|
||||
.map((v) => (v === true ? k : `${k}=${v}`))
|
||||
.join('; ');
|
||||
})
|
||||
)
|
||||
.join('; ');
|
||||
})
|
||||
.join(', ');
|
||||
})
|
||||
.join(', ');
|
||||
}
|
||||
|
||||
module.exports = { format, parse };
|
55
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/limiter.js
generated
vendored
Executable file
55
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/limiter.js
generated
vendored
Executable file
|
@ -0,0 +1,55 @@
|
|||
'use strict';
|
||||
|
||||
const kDone = Symbol('kDone');
|
||||
const kRun = Symbol('kRun');
|
||||
|
||||
/**
|
||||
* A very simple job queue with adjustable concurrency. Adapted from
|
||||
* https://github.com/STRML/async-limiter
|
||||
*/
|
||||
class Limiter {
|
||||
/**
|
||||
* Creates a new `Limiter`.
|
||||
*
|
||||
* @param {Number} [concurrency=Infinity] The maximum number of jobs allowed
|
||||
* to run concurrently
|
||||
*/
|
||||
constructor(concurrency) {
|
||||
this[kDone] = () => {
|
||||
this.pending--;
|
||||
this[kRun]();
|
||||
};
|
||||
this.concurrency = concurrency || Infinity;
|
||||
this.jobs = [];
|
||||
this.pending = 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a job to the queue.
|
||||
*
|
||||
* @param {Function} job The job to run
|
||||
* @public
|
||||
*/
|
||||
add(job) {
|
||||
this.jobs.push(job);
|
||||
this[kRun]();
|
||||
}
|
||||
|
||||
/**
|
||||
* Removes a job from the queue and runs it if possible.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
[kRun]() {
|
||||
if (this.pending === this.concurrency) return;
|
||||
|
||||
if (this.jobs.length) {
|
||||
const job = this.jobs.shift();
|
||||
|
||||
this.pending++;
|
||||
job(this[kDone]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = Limiter;
|
514
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/permessage-deflate.js
generated
vendored
Executable file
514
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/permessage-deflate.js
generated
vendored
Executable file
|
@ -0,0 +1,514 @@
|
|||
'use strict';
|
||||
|
||||
const zlib = require('zlib');
|
||||
|
||||
const bufferUtil = require('./buffer-util');
|
||||
const Limiter = require('./limiter');
|
||||
const { kStatusCode } = require('./constants');
|
||||
|
||||
const FastBuffer = Buffer[Symbol.species];
|
||||
const TRAILER = Buffer.from([0x00, 0x00, 0xff, 0xff]);
|
||||
const kPerMessageDeflate = Symbol('permessage-deflate');
|
||||
const kTotalLength = Symbol('total-length');
|
||||
const kCallback = Symbol('callback');
|
||||
const kBuffers = Symbol('buffers');
|
||||
const kError = Symbol('error');
|
||||
|
||||
//
|
||||
// We limit zlib concurrency, which prevents severe memory fragmentation
|
||||
// as documented in https://github.com/nodejs/node/issues/8871#issuecomment-250915913
|
||||
// and https://github.com/websockets/ws/issues/1202
|
||||
//
|
||||
// Intentionally global; it's the global thread pool that's an issue.
|
||||
//
|
||||
let zlibLimiter;
|
||||
|
||||
/**
|
||||
* permessage-deflate implementation.
|
||||
*/
|
||||
class PerMessageDeflate {
|
||||
/**
|
||||
* Creates a PerMessageDeflate instance.
|
||||
*
|
||||
* @param {Object} [options] Configuration options
|
||||
* @param {(Boolean|Number)} [options.clientMaxWindowBits] Advertise support
|
||||
* for, or request, a custom client window size
|
||||
* @param {Boolean} [options.clientNoContextTakeover=false] Advertise/
|
||||
* acknowledge disabling of client context takeover
|
||||
* @param {Number} [options.concurrencyLimit=10] The number of concurrent
|
||||
* calls to zlib
|
||||
* @param {(Boolean|Number)} [options.serverMaxWindowBits] Request/confirm the
|
||||
* use of a custom server window size
|
||||
* @param {Boolean} [options.serverNoContextTakeover=false] Request/accept
|
||||
* disabling of server context takeover
|
||||
* @param {Number} [options.threshold=1024] Size (in bytes) below which
|
||||
* messages should not be compressed if context takeover is disabled
|
||||
* @param {Object} [options.zlibDeflateOptions] Options to pass to zlib on
|
||||
* deflate
|
||||
* @param {Object} [options.zlibInflateOptions] Options to pass to zlib on
|
||||
* inflate
|
||||
* @param {Boolean} [isServer=false] Create the instance in either server or
|
||||
* client mode
|
||||
* @param {Number} [maxPayload=0] The maximum allowed message length
|
||||
*/
|
||||
constructor(options, isServer, maxPayload) {
|
||||
this._maxPayload = maxPayload | 0;
|
||||
this._options = options || {};
|
||||
this._threshold =
|
||||
this._options.threshold !== undefined ? this._options.threshold : 1024;
|
||||
this._isServer = !!isServer;
|
||||
this._deflate = null;
|
||||
this._inflate = null;
|
||||
|
||||
this.params = null;
|
||||
|
||||
if (!zlibLimiter) {
|
||||
const concurrency =
|
||||
this._options.concurrencyLimit !== undefined
|
||||
? this._options.concurrencyLimit
|
||||
: 10;
|
||||
zlibLimiter = new Limiter(concurrency);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @type {String}
|
||||
*/
|
||||
static get extensionName() {
|
||||
return 'permessage-deflate';
|
||||
}
|
||||
|
||||
/**
|
||||
* Create an extension negotiation offer.
|
||||
*
|
||||
* @return {Object} Extension parameters
|
||||
* @public
|
||||
*/
|
||||
offer() {
|
||||
const params = {};
|
||||
|
||||
if (this._options.serverNoContextTakeover) {
|
||||
params.server_no_context_takeover = true;
|
||||
}
|
||||
if (this._options.clientNoContextTakeover) {
|
||||
params.client_no_context_takeover = true;
|
||||
}
|
||||
if (this._options.serverMaxWindowBits) {
|
||||
params.server_max_window_bits = this._options.serverMaxWindowBits;
|
||||
}
|
||||
if (this._options.clientMaxWindowBits) {
|
||||
params.client_max_window_bits = this._options.clientMaxWindowBits;
|
||||
} else if (this._options.clientMaxWindowBits == null) {
|
||||
params.client_max_window_bits = true;
|
||||
}
|
||||
|
||||
return params;
|
||||
}
|
||||
|
||||
/**
|
||||
* Accept an extension negotiation offer/response.
|
||||
*
|
||||
* @param {Array} configurations The extension negotiation offers/reponse
|
||||
* @return {Object} Accepted configuration
|
||||
* @public
|
||||
*/
|
||||
accept(configurations) {
|
||||
configurations = this.normalizeParams(configurations);
|
||||
|
||||
this.params = this._isServer
|
||||
? this.acceptAsServer(configurations)
|
||||
: this.acceptAsClient(configurations);
|
||||
|
||||
return this.params;
|
||||
}
|
||||
|
||||
/**
|
||||
* Releases all resources used by the extension.
|
||||
*
|
||||
* @public
|
||||
*/
|
||||
cleanup() {
|
||||
if (this._inflate) {
|
||||
this._inflate.close();
|
||||
this._inflate = null;
|
||||
}
|
||||
|
||||
if (this._deflate) {
|
||||
const callback = this._deflate[kCallback];
|
||||
|
||||
this._deflate.close();
|
||||
this._deflate = null;
|
||||
|
||||
if (callback) {
|
||||
callback(
|
||||
new Error(
|
||||
'The deflate stream was closed while data was being processed'
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Accept an extension negotiation offer.
|
||||
*
|
||||
* @param {Array} offers The extension negotiation offers
|
||||
* @return {Object} Accepted configuration
|
||||
* @private
|
||||
*/
|
||||
acceptAsServer(offers) {
|
||||
const opts = this._options;
|
||||
const accepted = offers.find((params) => {
|
||||
if (
|
||||
(opts.serverNoContextTakeover === false &&
|
||||
params.server_no_context_takeover) ||
|
||||
(params.server_max_window_bits &&
|
||||
(opts.serverMaxWindowBits === false ||
|
||||
(typeof opts.serverMaxWindowBits === 'number' &&
|
||||
opts.serverMaxWindowBits > params.server_max_window_bits))) ||
|
||||
(typeof opts.clientMaxWindowBits === 'number' &&
|
||||
!params.client_max_window_bits)
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
});
|
||||
|
||||
if (!accepted) {
|
||||
throw new Error('None of the extension offers can be accepted');
|
||||
}
|
||||
|
||||
if (opts.serverNoContextTakeover) {
|
||||
accepted.server_no_context_takeover = true;
|
||||
}
|
||||
if (opts.clientNoContextTakeover) {
|
||||
accepted.client_no_context_takeover = true;
|
||||
}
|
||||
if (typeof opts.serverMaxWindowBits === 'number') {
|
||||
accepted.server_max_window_bits = opts.serverMaxWindowBits;
|
||||
}
|
||||
if (typeof opts.clientMaxWindowBits === 'number') {
|
||||
accepted.client_max_window_bits = opts.clientMaxWindowBits;
|
||||
} else if (
|
||||
accepted.client_max_window_bits === true ||
|
||||
opts.clientMaxWindowBits === false
|
||||
) {
|
||||
delete accepted.client_max_window_bits;
|
||||
}
|
||||
|
||||
return accepted;
|
||||
}
|
||||
|
||||
/**
|
||||
* Accept the extension negotiation response.
|
||||
*
|
||||
* @param {Array} response The extension negotiation response
|
||||
* @return {Object} Accepted configuration
|
||||
* @private
|
||||
*/
|
||||
acceptAsClient(response) {
|
||||
const params = response[0];
|
||||
|
||||
if (
|
||||
this._options.clientNoContextTakeover === false &&
|
||||
params.client_no_context_takeover
|
||||
) {
|
||||
throw new Error('Unexpected parameter "client_no_context_takeover"');
|
||||
}
|
||||
|
||||
if (!params.client_max_window_bits) {
|
||||
if (typeof this._options.clientMaxWindowBits === 'number') {
|
||||
params.client_max_window_bits = this._options.clientMaxWindowBits;
|
||||
}
|
||||
} else if (
|
||||
this._options.clientMaxWindowBits === false ||
|
||||
(typeof this._options.clientMaxWindowBits === 'number' &&
|
||||
params.client_max_window_bits > this._options.clientMaxWindowBits)
|
||||
) {
|
||||
throw new Error(
|
||||
'Unexpected or invalid parameter "client_max_window_bits"'
|
||||
);
|
||||
}
|
||||
|
||||
return params;
|
||||
}
|
||||
|
||||
/**
|
||||
* Normalize parameters.
|
||||
*
|
||||
* @param {Array} configurations The extension negotiation offers/reponse
|
||||
* @return {Array} The offers/response with normalized parameters
|
||||
* @private
|
||||
*/
|
||||
normalizeParams(configurations) {
|
||||
configurations.forEach((params) => {
|
||||
Object.keys(params).forEach((key) => {
|
||||
let value = params[key];
|
||||
|
||||
if (value.length > 1) {
|
||||
throw new Error(`Parameter "${key}" must have only a single value`);
|
||||
}
|
||||
|
||||
value = value[0];
|
||||
|
||||
if (key === 'client_max_window_bits') {
|
||||
if (value !== true) {
|
||||
const num = +value;
|
||||
if (!Number.isInteger(num) || num < 8 || num > 15) {
|
||||
throw new TypeError(
|
||||
`Invalid value for parameter "${key}": ${value}`
|
||||
);
|
||||
}
|
||||
value = num;
|
||||
} else if (!this._isServer) {
|
||||
throw new TypeError(
|
||||
`Invalid value for parameter "${key}": ${value}`
|
||||
);
|
||||
}
|
||||
} else if (key === 'server_max_window_bits') {
|
||||
const num = +value;
|
||||
if (!Number.isInteger(num) || num < 8 || num > 15) {
|
||||
throw new TypeError(
|
||||
`Invalid value for parameter "${key}": ${value}`
|
||||
);
|
||||
}
|
||||
value = num;
|
||||
} else if (
|
||||
key === 'client_no_context_takeover' ||
|
||||
key === 'server_no_context_takeover'
|
||||
) {
|
||||
if (value !== true) {
|
||||
throw new TypeError(
|
||||
`Invalid value for parameter "${key}": ${value}`
|
||||
);
|
||||
}
|
||||
} else {
|
||||
throw new Error(`Unknown parameter "${key}"`);
|
||||
}
|
||||
|
||||
params[key] = value;
|
||||
});
|
||||
});
|
||||
|
||||
return configurations;
|
||||
}
|
||||
|
||||
/**
|
||||
* Decompress data. Concurrency limited.
|
||||
*
|
||||
* @param {Buffer} data Compressed data
|
||||
* @param {Boolean} fin Specifies whether or not this is the last fragment
|
||||
* @param {Function} callback Callback
|
||||
* @public
|
||||
*/
|
||||
decompress(data, fin, callback) {
|
||||
zlibLimiter.add((done) => {
|
||||
this._decompress(data, fin, (err, result) => {
|
||||
done();
|
||||
callback(err, result);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Compress data. Concurrency limited.
|
||||
*
|
||||
* @param {(Buffer|String)} data Data to compress
|
||||
* @param {Boolean} fin Specifies whether or not this is the last fragment
|
||||
* @param {Function} callback Callback
|
||||
* @public
|
||||
*/
|
||||
compress(data, fin, callback) {
|
||||
zlibLimiter.add((done) => {
|
||||
this._compress(data, fin, (err, result) => {
|
||||
done();
|
||||
callback(err, result);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Decompress data.
|
||||
*
|
||||
* @param {Buffer} data Compressed data
|
||||
* @param {Boolean} fin Specifies whether or not this is the last fragment
|
||||
* @param {Function} callback Callback
|
||||
* @private
|
||||
*/
|
||||
_decompress(data, fin, callback) {
|
||||
const endpoint = this._isServer ? 'client' : 'server';
|
||||
|
||||
if (!this._inflate) {
|
||||
const key = `${endpoint}_max_window_bits`;
|
||||
const windowBits =
|
||||
typeof this.params[key] !== 'number'
|
||||
? zlib.Z_DEFAULT_WINDOWBITS
|
||||
: this.params[key];
|
||||
|
||||
this._inflate = zlib.createInflateRaw({
|
||||
...this._options.zlibInflateOptions,
|
||||
windowBits
|
||||
});
|
||||
this._inflate[kPerMessageDeflate] = this;
|
||||
this._inflate[kTotalLength] = 0;
|
||||
this._inflate[kBuffers] = [];
|
||||
this._inflate.on('error', inflateOnError);
|
||||
this._inflate.on('data', inflateOnData);
|
||||
}
|
||||
|
||||
this._inflate[kCallback] = callback;
|
||||
|
||||
this._inflate.write(data);
|
||||
if (fin) this._inflate.write(TRAILER);
|
||||
|
||||
this._inflate.flush(() => {
|
||||
const err = this._inflate[kError];
|
||||
|
||||
if (err) {
|
||||
this._inflate.close();
|
||||
this._inflate = null;
|
||||
callback(err);
|
||||
return;
|
||||
}
|
||||
|
||||
const data = bufferUtil.concat(
|
||||
this._inflate[kBuffers],
|
||||
this._inflate[kTotalLength]
|
||||
);
|
||||
|
||||
if (this._inflate._readableState.endEmitted) {
|
||||
this._inflate.close();
|
||||
this._inflate = null;
|
||||
} else {
|
||||
this._inflate[kTotalLength] = 0;
|
||||
this._inflate[kBuffers] = [];
|
||||
|
||||
if (fin && this.params[`${endpoint}_no_context_takeover`]) {
|
||||
this._inflate.reset();
|
||||
}
|
||||
}
|
||||
|
||||
callback(null, data);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Compress data.
|
||||
*
|
||||
* @param {(Buffer|String)} data Data to compress
|
||||
* @param {Boolean} fin Specifies whether or not this is the last fragment
|
||||
* @param {Function} callback Callback
|
||||
* @private
|
||||
*/
|
||||
_compress(data, fin, callback) {
|
||||
const endpoint = this._isServer ? 'server' : 'client';
|
||||
|
||||
if (!this._deflate) {
|
||||
const key = `${endpoint}_max_window_bits`;
|
||||
const windowBits =
|
||||
typeof this.params[key] !== 'number'
|
||||
? zlib.Z_DEFAULT_WINDOWBITS
|
||||
: this.params[key];
|
||||
|
||||
this._deflate = zlib.createDeflateRaw({
|
||||
...this._options.zlibDeflateOptions,
|
||||
windowBits
|
||||
});
|
||||
|
||||
this._deflate[kTotalLength] = 0;
|
||||
this._deflate[kBuffers] = [];
|
||||
|
||||
this._deflate.on('data', deflateOnData);
|
||||
}
|
||||
|
||||
this._deflate[kCallback] = callback;
|
||||
|
||||
this._deflate.write(data);
|
||||
this._deflate.flush(zlib.Z_SYNC_FLUSH, () => {
|
||||
if (!this._deflate) {
|
||||
//
|
||||
// The deflate stream was closed while data was being processed.
|
||||
//
|
||||
return;
|
||||
}
|
||||
|
||||
let data = bufferUtil.concat(
|
||||
this._deflate[kBuffers],
|
||||
this._deflate[kTotalLength]
|
||||
);
|
||||
|
||||
if (fin) {
|
||||
data = new FastBuffer(data.buffer, data.byteOffset, data.length - 4);
|
||||
}
|
||||
|
||||
//
|
||||
// Ensure that the callback will not be called again in
|
||||
// `PerMessageDeflate#cleanup()`.
|
||||
//
|
||||
this._deflate[kCallback] = null;
|
||||
|
||||
this._deflate[kTotalLength] = 0;
|
||||
this._deflate[kBuffers] = [];
|
||||
|
||||
if (fin && this.params[`${endpoint}_no_context_takeover`]) {
|
||||
this._deflate.reset();
|
||||
}
|
||||
|
||||
callback(null, data);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = PerMessageDeflate;
|
||||
|
||||
/**
|
||||
* The listener of the `zlib.DeflateRaw` stream `'data'` event.
|
||||
*
|
||||
* @param {Buffer} chunk A chunk of data
|
||||
* @private
|
||||
*/
|
||||
function deflateOnData(chunk) {
|
||||
this[kBuffers].push(chunk);
|
||||
this[kTotalLength] += chunk.length;
|
||||
}
|
||||
|
||||
/**
|
||||
* The listener of the `zlib.InflateRaw` stream `'data'` event.
|
||||
*
|
||||
* @param {Buffer} chunk A chunk of data
|
||||
* @private
|
||||
*/
|
||||
function inflateOnData(chunk) {
|
||||
this[kTotalLength] += chunk.length;
|
||||
|
||||
if (
|
||||
this[kPerMessageDeflate]._maxPayload < 1 ||
|
||||
this[kTotalLength] <= this[kPerMessageDeflate]._maxPayload
|
||||
) {
|
||||
this[kBuffers].push(chunk);
|
||||
return;
|
||||
}
|
||||
|
||||
this[kError] = new RangeError('Max payload size exceeded');
|
||||
this[kError].code = 'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH';
|
||||
this[kError][kStatusCode] = 1009;
|
||||
this.removeListener('data', inflateOnData);
|
||||
this.reset();
|
||||
}
|
||||
|
||||
/**
|
||||
* The listener of the `zlib.InflateRaw` stream `'error'` event.
|
||||
*
|
||||
* @param {Error} err The emitted error
|
||||
* @private
|
||||
*/
|
||||
function inflateOnError(err) {
|
||||
//
|
||||
// There is no need to call `Zlib#close()` as the handle is automatically
|
||||
// closed when an error is emitted.
|
||||
//
|
||||
this[kPerMessageDeflate]._inflate = null;
|
||||
err[kStatusCode] = 1007;
|
||||
this[kCallback](err);
|
||||
}
|
742
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/receiver.js
generated
vendored
Executable file
742
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/receiver.js
generated
vendored
Executable file
|
@ -0,0 +1,742 @@
|
|||
'use strict';
|
||||
|
||||
const { Writable } = require('stream');
|
||||
|
||||
const PerMessageDeflate = require('./permessage-deflate');
|
||||
const {
|
||||
BINARY_TYPES,
|
||||
EMPTY_BUFFER,
|
||||
kStatusCode,
|
||||
kWebSocket
|
||||
} = require('./constants');
|
||||
const { concat, toArrayBuffer, unmask } = require('./buffer-util');
|
||||
const { isValidStatusCode, isValidUTF8 } = require('./validation');
|
||||
|
||||
const FastBuffer = Buffer[Symbol.species];
|
||||
const promise = Promise.resolve();
|
||||
|
||||
//
|
||||
// `queueMicrotask()` is not available in Node.js < 11.
|
||||
//
|
||||
const queueTask =
|
||||
typeof queueMicrotask === 'function' ? queueMicrotask : queueMicrotaskShim;
|
||||
|
||||
const GET_INFO = 0;
|
||||
const GET_PAYLOAD_LENGTH_16 = 1;
|
||||
const GET_PAYLOAD_LENGTH_64 = 2;
|
||||
const GET_MASK = 3;
|
||||
const GET_DATA = 4;
|
||||
const INFLATING = 5;
|
||||
const DEFER_EVENT = 6;
|
||||
|
||||
/**
|
||||
* HyBi Receiver implementation.
|
||||
*
|
||||
* @extends Writable
|
||||
*/
|
||||
class Receiver extends Writable {
|
||||
/**
|
||||
* Creates a Receiver instance.
|
||||
*
|
||||
* @param {Object} [options] Options object
|
||||
* @param {Boolean} [options.allowSynchronousEvents=false] Specifies whether
|
||||
* any of the `'message'`, `'ping'`, and `'pong'` events can be emitted
|
||||
* multiple times in the same tick
|
||||
* @param {String} [options.binaryType=nodebuffer] The type for binary data
|
||||
* @param {Object} [options.extensions] An object containing the negotiated
|
||||
* extensions
|
||||
* @param {Boolean} [options.isServer=false] Specifies whether to operate in
|
||||
* client or server mode
|
||||
* @param {Number} [options.maxPayload=0] The maximum allowed message length
|
||||
* @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or
|
||||
* not to skip UTF-8 validation for text and close messages
|
||||
*/
|
||||
constructor(options = {}) {
|
||||
super();
|
||||
|
||||
this._allowSynchronousEvents = !!options.allowSynchronousEvents;
|
||||
this._binaryType = options.binaryType || BINARY_TYPES[0];
|
||||
this._extensions = options.extensions || {};
|
||||
this._isServer = !!options.isServer;
|
||||
this._maxPayload = options.maxPayload | 0;
|
||||
this._skipUTF8Validation = !!options.skipUTF8Validation;
|
||||
this[kWebSocket] = undefined;
|
||||
|
||||
this._bufferedBytes = 0;
|
||||
this._buffers = [];
|
||||
|
||||
this._compressed = false;
|
||||
this._payloadLength = 0;
|
||||
this._mask = undefined;
|
||||
this._fragmented = 0;
|
||||
this._masked = false;
|
||||
this._fin = false;
|
||||
this._opcode = 0;
|
||||
|
||||
this._totalPayloadLength = 0;
|
||||
this._messageLength = 0;
|
||||
this._fragments = [];
|
||||
|
||||
this._errored = false;
|
||||
this._loop = false;
|
||||
this._state = GET_INFO;
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements `Writable.prototype._write()`.
|
||||
*
|
||||
* @param {Buffer} chunk The chunk of data to write
|
||||
* @param {String} encoding The character encoding of `chunk`
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
_write(chunk, encoding, cb) {
|
||||
if (this._opcode === 0x08 && this._state == GET_INFO) return cb();
|
||||
|
||||
this._bufferedBytes += chunk.length;
|
||||
this._buffers.push(chunk);
|
||||
this.startLoop(cb);
|
||||
}
|
||||
|
||||
/**
|
||||
* Consumes `n` bytes from the buffered data.
|
||||
*
|
||||
* @param {Number} n The number of bytes to consume
|
||||
* @return {Buffer} The consumed bytes
|
||||
* @private
|
||||
*/
|
||||
consume(n) {
|
||||
this._bufferedBytes -= n;
|
||||
|
||||
if (n === this._buffers[0].length) return this._buffers.shift();
|
||||
|
||||
if (n < this._buffers[0].length) {
|
||||
const buf = this._buffers[0];
|
||||
this._buffers[0] = new FastBuffer(
|
||||
buf.buffer,
|
||||
buf.byteOffset + n,
|
||||
buf.length - n
|
||||
);
|
||||
|
||||
return new FastBuffer(buf.buffer, buf.byteOffset, n);
|
||||
}
|
||||
|
||||
const dst = Buffer.allocUnsafe(n);
|
||||
|
||||
do {
|
||||
const buf = this._buffers[0];
|
||||
const offset = dst.length - n;
|
||||
|
||||
if (n >= buf.length) {
|
||||
dst.set(this._buffers.shift(), offset);
|
||||
} else {
|
||||
dst.set(new Uint8Array(buf.buffer, buf.byteOffset, n), offset);
|
||||
this._buffers[0] = new FastBuffer(
|
||||
buf.buffer,
|
||||
buf.byteOffset + n,
|
||||
buf.length - n
|
||||
);
|
||||
}
|
||||
|
||||
n -= buf.length;
|
||||
} while (n > 0);
|
||||
|
||||
return dst;
|
||||
}
|
||||
|
||||
/**
|
||||
* Starts the parsing loop.
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
startLoop(cb) {
|
||||
this._loop = true;
|
||||
|
||||
do {
|
||||
switch (this._state) {
|
||||
case GET_INFO:
|
||||
this.getInfo(cb);
|
||||
break;
|
||||
case GET_PAYLOAD_LENGTH_16:
|
||||
this.getPayloadLength16(cb);
|
||||
break;
|
||||
case GET_PAYLOAD_LENGTH_64:
|
||||
this.getPayloadLength64(cb);
|
||||
break;
|
||||
case GET_MASK:
|
||||
this.getMask();
|
||||
break;
|
||||
case GET_DATA:
|
||||
this.getData(cb);
|
||||
break;
|
||||
case INFLATING:
|
||||
case DEFER_EVENT:
|
||||
this._loop = false;
|
||||
return;
|
||||
}
|
||||
} while (this._loop);
|
||||
|
||||
if (!this._errored) cb();
|
||||
}
|
||||
|
||||
/**
|
||||
* Reads the first two bytes of a frame.
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
getInfo(cb) {
|
||||
if (this._bufferedBytes < 2) {
|
||||
this._loop = false;
|
||||
return;
|
||||
}
|
||||
|
||||
const buf = this.consume(2);
|
||||
|
||||
if ((buf[0] & 0x30) !== 0x00) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'RSV2 and RSV3 must be clear',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_UNEXPECTED_RSV_2_3'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
const compressed = (buf[0] & 0x40) === 0x40;
|
||||
|
||||
if (compressed && !this._extensions[PerMessageDeflate.extensionName]) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'RSV1 must be clear',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_UNEXPECTED_RSV_1'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
this._fin = (buf[0] & 0x80) === 0x80;
|
||||
this._opcode = buf[0] & 0x0f;
|
||||
this._payloadLength = buf[1] & 0x7f;
|
||||
|
||||
if (this._opcode === 0x00) {
|
||||
if (compressed) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'RSV1 must be clear',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_UNEXPECTED_RSV_1'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!this._fragmented) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'invalid opcode 0',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_INVALID_OPCODE'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
this._opcode = this._fragmented;
|
||||
} else if (this._opcode === 0x01 || this._opcode === 0x02) {
|
||||
if (this._fragmented) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
`invalid opcode ${this._opcode}`,
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_INVALID_OPCODE'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
this._compressed = compressed;
|
||||
} else if (this._opcode > 0x07 && this._opcode < 0x0b) {
|
||||
if (!this._fin) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'FIN must be set',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_EXPECTED_FIN'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
if (compressed) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'RSV1 must be clear',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_UNEXPECTED_RSV_1'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
if (
|
||||
this._payloadLength > 0x7d ||
|
||||
(this._opcode === 0x08 && this._payloadLength === 1)
|
||||
) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
`invalid payload length ${this._payloadLength}`,
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
`invalid opcode ${this._opcode}`,
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_INVALID_OPCODE'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!this._fin && !this._fragmented) this._fragmented = this._opcode;
|
||||
this._masked = (buf[1] & 0x80) === 0x80;
|
||||
|
||||
if (this._isServer) {
|
||||
if (!this._masked) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'MASK must be set',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_EXPECTED_MASK'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
} else if (this._masked) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'MASK must be clear',
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_UNEXPECTED_MASK'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
if (this._payloadLength === 126) this._state = GET_PAYLOAD_LENGTH_16;
|
||||
else if (this._payloadLength === 127) this._state = GET_PAYLOAD_LENGTH_64;
|
||||
else this.haveLength(cb);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets extended payload length (7+16).
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
getPayloadLength16(cb) {
|
||||
if (this._bufferedBytes < 2) {
|
||||
this._loop = false;
|
||||
return;
|
||||
}
|
||||
|
||||
this._payloadLength = this.consume(2).readUInt16BE(0);
|
||||
this.haveLength(cb);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets extended payload length (7+64).
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
getPayloadLength64(cb) {
|
||||
if (this._bufferedBytes < 8) {
|
||||
this._loop = false;
|
||||
return;
|
||||
}
|
||||
|
||||
const buf = this.consume(8);
|
||||
const num = buf.readUInt32BE(0);
|
||||
|
||||
//
|
||||
// The maximum safe integer in JavaScript is 2^53 - 1. An error is returned
|
||||
// if payload length is greater than this number.
|
||||
//
|
||||
if (num > Math.pow(2, 53 - 32) - 1) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'Unsupported WebSocket frame: payload length > 2^53 - 1',
|
||||
false,
|
||||
1009,
|
||||
'WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
this._payloadLength = num * Math.pow(2, 32) + buf.readUInt32BE(4);
|
||||
this.haveLength(cb);
|
||||
}
|
||||
|
||||
/**
|
||||
* Payload length has been read.
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
haveLength(cb) {
|
||||
if (this._payloadLength && this._opcode < 0x08) {
|
||||
this._totalPayloadLength += this._payloadLength;
|
||||
if (this._totalPayloadLength > this._maxPayload && this._maxPayload > 0) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'Max payload size exceeded',
|
||||
false,
|
||||
1009,
|
||||
'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (this._masked) this._state = GET_MASK;
|
||||
else this._state = GET_DATA;
|
||||
}
|
||||
|
||||
/**
|
||||
* Reads mask bytes.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
getMask() {
|
||||
if (this._bufferedBytes < 4) {
|
||||
this._loop = false;
|
||||
return;
|
||||
}
|
||||
|
||||
this._mask = this.consume(4);
|
||||
this._state = GET_DATA;
|
||||
}
|
||||
|
||||
/**
|
||||
* Reads data bytes.
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
getData(cb) {
|
||||
let data = EMPTY_BUFFER;
|
||||
|
||||
if (this._payloadLength) {
|
||||
if (this._bufferedBytes < this._payloadLength) {
|
||||
this._loop = false;
|
||||
return;
|
||||
}
|
||||
|
||||
data = this.consume(this._payloadLength);
|
||||
|
||||
if (
|
||||
this._masked &&
|
||||
(this._mask[0] | this._mask[1] | this._mask[2] | this._mask[3]) !== 0
|
||||
) {
|
||||
unmask(data, this._mask);
|
||||
}
|
||||
}
|
||||
|
||||
if (this._opcode > 0x07) {
|
||||
this.controlMessage(data, cb);
|
||||
return;
|
||||
}
|
||||
|
||||
if (this._compressed) {
|
||||
this._state = INFLATING;
|
||||
this.decompress(data, cb);
|
||||
return;
|
||||
}
|
||||
|
||||
if (data.length) {
|
||||
//
|
||||
// This message is not compressed so its length is the sum of the payload
|
||||
// length of all fragments.
|
||||
//
|
||||
this._messageLength = this._totalPayloadLength;
|
||||
this._fragments.push(data);
|
||||
}
|
||||
|
||||
this.dataMessage(cb);
|
||||
}
|
||||
|
||||
/**
|
||||
* Decompresses data.
|
||||
*
|
||||
* @param {Buffer} data Compressed data
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
decompress(data, cb) {
|
||||
const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];
|
||||
|
||||
perMessageDeflate.decompress(data, this._fin, (err, buf) => {
|
||||
if (err) return cb(err);
|
||||
|
||||
if (buf.length) {
|
||||
this._messageLength += buf.length;
|
||||
if (this._messageLength > this._maxPayload && this._maxPayload > 0) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
'Max payload size exceeded',
|
||||
false,
|
||||
1009,
|
||||
'WS_ERR_UNSUPPORTED_MESSAGE_LENGTH'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
this._fragments.push(buf);
|
||||
}
|
||||
|
||||
this.dataMessage(cb);
|
||||
if (this._state === GET_INFO) this.startLoop(cb);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Handles a data message.
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
* @private
|
||||
*/
|
||||
dataMessage(cb) {
|
||||
if (!this._fin) {
|
||||
this._state = GET_INFO;
|
||||
return;
|
||||
}
|
||||
|
||||
const messageLength = this._messageLength;
|
||||
const fragments = this._fragments;
|
||||
|
||||
this._totalPayloadLength = 0;
|
||||
this._messageLength = 0;
|
||||
this._fragmented = 0;
|
||||
this._fragments = [];
|
||||
|
||||
if (this._opcode === 2) {
|
||||
let data;
|
||||
|
||||
if (this._binaryType === 'nodebuffer') {
|
||||
data = concat(fragments, messageLength);
|
||||
} else if (this._binaryType === 'arraybuffer') {
|
||||
data = toArrayBuffer(concat(fragments, messageLength));
|
||||
} else {
|
||||
data = fragments;
|
||||
}
|
||||
|
||||
//
|
||||
// If the state is `INFLATING`, it means that the frame data was
|
||||
// decompressed asynchronously, so there is no need to defer the event
|
||||
// as it will be emitted asynchronously anyway.
|
||||
//
|
||||
if (this._state === INFLATING || this._allowSynchronousEvents) {
|
||||
this.emit('message', data, true);
|
||||
this._state = GET_INFO;
|
||||
} else {
|
||||
this._state = DEFER_EVENT;
|
||||
queueTask(() => {
|
||||
this.emit('message', data, true);
|
||||
this._state = GET_INFO;
|
||||
this.startLoop(cb);
|
||||
});
|
||||
}
|
||||
} else {
|
||||
const buf = concat(fragments, messageLength);
|
||||
|
||||
if (!this._skipUTF8Validation && !isValidUTF8(buf)) {
|
||||
const error = this.createError(
|
||||
Error,
|
||||
'invalid UTF-8 sequence',
|
||||
true,
|
||||
1007,
|
||||
'WS_ERR_INVALID_UTF8'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
if (this._state === INFLATING || this._allowSynchronousEvents) {
|
||||
this.emit('message', buf, false);
|
||||
this._state = GET_INFO;
|
||||
} else {
|
||||
this._state = DEFER_EVENT;
|
||||
queueTask(() => {
|
||||
this.emit('message', buf, false);
|
||||
this._state = GET_INFO;
|
||||
this.startLoop(cb);
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Handles a control message.
|
||||
*
|
||||
* @param {Buffer} data Data to handle
|
||||
* @return {(Error|RangeError|undefined)} A possible error
|
||||
* @private
|
||||
*/
|
||||
controlMessage(data, cb) {
|
||||
if (this._opcode === 0x08) {
|
||||
if (data.length === 0) {
|
||||
this._loop = false;
|
||||
this.emit('conclude', 1005, EMPTY_BUFFER);
|
||||
this.end();
|
||||
} else {
|
||||
const code = data.readUInt16BE(0);
|
||||
|
||||
if (!isValidStatusCode(code)) {
|
||||
const error = this.createError(
|
||||
RangeError,
|
||||
`invalid status code ${code}`,
|
||||
true,
|
||||
1002,
|
||||
'WS_ERR_INVALID_CLOSE_CODE'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
const buf = new FastBuffer(
|
||||
data.buffer,
|
||||
data.byteOffset + 2,
|
||||
data.length - 2
|
||||
);
|
||||
|
||||
if (!this._skipUTF8Validation && !isValidUTF8(buf)) {
|
||||
const error = this.createError(
|
||||
Error,
|
||||
'invalid UTF-8 sequence',
|
||||
true,
|
||||
1007,
|
||||
'WS_ERR_INVALID_UTF8'
|
||||
);
|
||||
|
||||
cb(error);
|
||||
return;
|
||||
}
|
||||
|
||||
this._loop = false;
|
||||
this.emit('conclude', code, buf);
|
||||
this.end();
|
||||
}
|
||||
|
||||
this._state = GET_INFO;
|
||||
return;
|
||||
}
|
||||
|
||||
if (this._allowSynchronousEvents) {
|
||||
this.emit(this._opcode === 0x09 ? 'ping' : 'pong', data);
|
||||
this._state = GET_INFO;
|
||||
} else {
|
||||
this._state = DEFER_EVENT;
|
||||
queueTask(() => {
|
||||
this.emit(this._opcode === 0x09 ? 'ping' : 'pong', data);
|
||||
this._state = GET_INFO;
|
||||
this.startLoop(cb);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Builds an error object.
|
||||
*
|
||||
* @param {function(new:Error|RangeError)} ErrorCtor The error constructor
|
||||
* @param {String} message The error message
|
||||
* @param {Boolean} prefix Specifies whether or not to add a default prefix to
|
||||
* `message`
|
||||
* @param {Number} statusCode The status code
|
||||
* @param {String} errorCode The exposed error code
|
||||
* @return {(Error|RangeError)} The error
|
||||
* @private
|
||||
*/
|
||||
createError(ErrorCtor, message, prefix, statusCode, errorCode) {
|
||||
this._loop = false;
|
||||
this._errored = true;
|
||||
|
||||
const err = new ErrorCtor(
|
||||
prefix ? `Invalid WebSocket frame: ${message}` : message
|
||||
);
|
||||
|
||||
Error.captureStackTrace(err, this.createError);
|
||||
err.code = errorCode;
|
||||
err[kStatusCode] = statusCode;
|
||||
return err;
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = Receiver;
|
||||
|
||||
/**
|
||||
* A shim for `queueMicrotask()`.
|
||||
*
|
||||
* @param {Function} cb Callback
|
||||
*/
|
||||
function queueMicrotaskShim(cb) {
|
||||
promise.then(cb).catch(throwErrorNextTick);
|
||||
}
|
||||
|
||||
/**
|
||||
* Throws an error.
|
||||
*
|
||||
* @param {Error} err The error to throw
|
||||
* @private
|
||||
*/
|
||||
function throwError(err) {
|
||||
throw err;
|
||||
}
|
||||
|
||||
/**
|
||||
* Throws an error in the next tick.
|
||||
*
|
||||
* @param {Error} err The error to throw
|
||||
* @private
|
||||
*/
|
||||
function throwErrorNextTick(err) {
|
||||
process.nextTick(throwError, err);
|
||||
}
|
477
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/sender.js
generated
vendored
Executable file
477
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/sender.js
generated
vendored
Executable file
|
@ -0,0 +1,477 @@
|
|||
/* eslint no-unused-vars: ["error", { "varsIgnorePattern": "^Duplex" }] */
|
||||
|
||||
'use strict';
|
||||
|
||||
const { Duplex } = require('stream');
|
||||
const { randomFillSync } = require('crypto');
|
||||
|
||||
const PerMessageDeflate = require('./permessage-deflate');
|
||||
const { EMPTY_BUFFER } = require('./constants');
|
||||
const { isValidStatusCode } = require('./validation');
|
||||
const { mask: applyMask, toBuffer } = require('./buffer-util');
|
||||
|
||||
const kByteLength = Symbol('kByteLength');
|
||||
const maskBuffer = Buffer.alloc(4);
|
||||
|
||||
/**
|
||||
* HyBi Sender implementation.
|
||||
*/
|
||||
class Sender {
|
||||
/**
|
||||
* Creates a Sender instance.
|
||||
*
|
||||
* @param {Duplex} socket The connection socket
|
||||
* @param {Object} [extensions] An object containing the negotiated extensions
|
||||
* @param {Function} [generateMask] The function used to generate the masking
|
||||
* key
|
||||
*/
|
||||
constructor(socket, extensions, generateMask) {
|
||||
this._extensions = extensions || {};
|
||||
|
||||
if (generateMask) {
|
||||
this._generateMask = generateMask;
|
||||
this._maskBuffer = Buffer.alloc(4);
|
||||
}
|
||||
|
||||
this._socket = socket;
|
||||
|
||||
this._firstFragment = true;
|
||||
this._compress = false;
|
||||
|
||||
this._bufferedBytes = 0;
|
||||
this._deflating = false;
|
||||
this._queue = [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Frames a piece of data according to the HyBi WebSocket protocol.
|
||||
*
|
||||
* @param {(Buffer|String)} data The data to frame
|
||||
* @param {Object} options Options object
|
||||
* @param {Boolean} [options.fin=false] Specifies whether or not to set the
|
||||
* FIN bit
|
||||
* @param {Function} [options.generateMask] The function used to generate the
|
||||
* masking key
|
||||
* @param {Boolean} [options.mask=false] Specifies whether or not to mask
|
||||
* `data`
|
||||
* @param {Buffer} [options.maskBuffer] The buffer used to store the masking
|
||||
* key
|
||||
* @param {Number} options.opcode The opcode
|
||||
* @param {Boolean} [options.readOnly=false] Specifies whether `data` can be
|
||||
* modified
|
||||
* @param {Boolean} [options.rsv1=false] Specifies whether or not to set the
|
||||
* RSV1 bit
|
||||
* @return {(Buffer|String)[]} The framed data
|
||||
* @public
|
||||
*/
|
||||
static frame(data, options) {
|
||||
let mask;
|
||||
let merge = false;
|
||||
let offset = 2;
|
||||
let skipMasking = false;
|
||||
|
||||
if (options.mask) {
|
||||
mask = options.maskBuffer || maskBuffer;
|
||||
|
||||
if (options.generateMask) {
|
||||
options.generateMask(mask);
|
||||
} else {
|
||||
randomFillSync(mask, 0, 4);
|
||||
}
|
||||
|
||||
skipMasking = (mask[0] | mask[1] | mask[2] | mask[3]) === 0;
|
||||
offset = 6;
|
||||
}
|
||||
|
||||
let dataLength;
|
||||
|
||||
if (typeof data === 'string') {
|
||||
if (
|
||||
(!options.mask || skipMasking) &&
|
||||
options[kByteLength] !== undefined
|
||||
) {
|
||||
dataLength = options[kByteLength];
|
||||
} else {
|
||||
data = Buffer.from(data);
|
||||
dataLength = data.length;
|
||||
}
|
||||
} else {
|
||||
dataLength = data.length;
|
||||
merge = options.mask && options.readOnly && !skipMasking;
|
||||
}
|
||||
|
||||
let payloadLength = dataLength;
|
||||
|
||||
if (dataLength >= 65536) {
|
||||
offset += 8;
|
||||
payloadLength = 127;
|
||||
} else if (dataLength > 125) {
|
||||
offset += 2;
|
||||
payloadLength = 126;
|
||||
}
|
||||
|
||||
const target = Buffer.allocUnsafe(merge ? dataLength + offset : offset);
|
||||
|
||||
target[0] = options.fin ? options.opcode | 0x80 : options.opcode;
|
||||
if (options.rsv1) target[0] |= 0x40;
|
||||
|
||||
target[1] = payloadLength;
|
||||
|
||||
if (payloadLength === 126) {
|
||||
target.writeUInt16BE(dataLength, 2);
|
||||
} else if (payloadLength === 127) {
|
||||
target[2] = target[3] = 0;
|
||||
target.writeUIntBE(dataLength, 4, 6);
|
||||
}
|
||||
|
||||
if (!options.mask) return [target, data];
|
||||
|
||||
target[1] |= 0x80;
|
||||
target[offset - 4] = mask[0];
|
||||
target[offset - 3] = mask[1];
|
||||
target[offset - 2] = mask[2];
|
||||
target[offset - 1] = mask[3];
|
||||
|
||||
if (skipMasking) return [target, data];
|
||||
|
||||
if (merge) {
|
||||
applyMask(data, mask, target, offset, dataLength);
|
||||
return [target];
|
||||
}
|
||||
|
||||
applyMask(data, mask, data, 0, dataLength);
|
||||
return [target, data];
|
||||
}
|
||||
|
||||
/**
|
||||
* Sends a close message to the other peer.
|
||||
*
|
||||
* @param {Number} [code] The status code component of the body
|
||||
* @param {(String|Buffer)} [data] The message component of the body
|
||||
* @param {Boolean} [mask=false] Specifies whether or not to mask the message
|
||||
* @param {Function} [cb] Callback
|
||||
* @public
|
||||
*/
|
||||
close(code, data, mask, cb) {
|
||||
let buf;
|
||||
|
||||
if (code === undefined) {
|
||||
buf = EMPTY_BUFFER;
|
||||
} else if (typeof code !== 'number' || !isValidStatusCode(code)) {
|
||||
throw new TypeError('First argument must be a valid error code number');
|
||||
} else if (data === undefined || !data.length) {
|
||||
buf = Buffer.allocUnsafe(2);
|
||||
buf.writeUInt16BE(code, 0);
|
||||
} else {
|
||||
const length = Buffer.byteLength(data);
|
||||
|
||||
if (length > 123) {
|
||||
throw new RangeError('The message must not be greater than 123 bytes');
|
||||
}
|
||||
|
||||
buf = Buffer.allocUnsafe(2 + length);
|
||||
buf.writeUInt16BE(code, 0);
|
||||
|
||||
if (typeof data === 'string') {
|
||||
buf.write(data, 2);
|
||||
} else {
|
||||
buf.set(data, 2);
|
||||
}
|
||||
}
|
||||
|
||||
const options = {
|
||||
[kByteLength]: buf.length,
|
||||
fin: true,
|
||||
generateMask: this._generateMask,
|
||||
mask,
|
||||
maskBuffer: this._maskBuffer,
|
||||
opcode: 0x08,
|
||||
readOnly: false,
|
||||
rsv1: false
|
||||
};
|
||||
|
||||
if (this._deflating) {
|
||||
this.enqueue([this.dispatch, buf, false, options, cb]);
|
||||
} else {
|
||||
this.sendFrame(Sender.frame(buf, options), cb);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sends a ping message to the other peer.
|
||||
*
|
||||
* @param {*} data The message to send
|
||||
* @param {Boolean} [mask=false] Specifies whether or not to mask `data`
|
||||
* @param {Function} [cb] Callback
|
||||
* @public
|
||||
*/
|
||||
ping(data, mask, cb) {
|
||||
let byteLength;
|
||||
let readOnly;
|
||||
|
||||
if (typeof data === 'string') {
|
||||
byteLength = Buffer.byteLength(data);
|
||||
readOnly = false;
|
||||
} else {
|
||||
data = toBuffer(data);
|
||||
byteLength = data.length;
|
||||
readOnly = toBuffer.readOnly;
|
||||
}
|
||||
|
||||
if (byteLength > 125) {
|
||||
throw new RangeError('The data size must not be greater than 125 bytes');
|
||||
}
|
||||
|
||||
const options = {
|
||||
[kByteLength]: byteLength,
|
||||
fin: true,
|
||||
generateMask: this._generateMask,
|
||||
mask,
|
||||
maskBuffer: this._maskBuffer,
|
||||
opcode: 0x09,
|
||||
readOnly,
|
||||
rsv1: false
|
||||
};
|
||||
|
||||
if (this._deflating) {
|
||||
this.enqueue([this.dispatch, data, false, options, cb]);
|
||||
} else {
|
||||
this.sendFrame(Sender.frame(data, options), cb);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sends a pong message to the other peer.
|
||||
*
|
||||
* @param {*} data The message to send
|
||||
* @param {Boolean} [mask=false] Specifies whether or not to mask `data`
|
||||
* @param {Function} [cb] Callback
|
||||
* @public
|
||||
*/
|
||||
pong(data, mask, cb) {
|
||||
let byteLength;
|
||||
let readOnly;
|
||||
|
||||
if (typeof data === 'string') {
|
||||
byteLength = Buffer.byteLength(data);
|
||||
readOnly = false;
|
||||
} else {
|
||||
data = toBuffer(data);
|
||||
byteLength = data.length;
|
||||
readOnly = toBuffer.readOnly;
|
||||
}
|
||||
|
||||
if (byteLength > 125) {
|
||||
throw new RangeError('The data size must not be greater than 125 bytes');
|
||||
}
|
||||
|
||||
const options = {
|
||||
[kByteLength]: byteLength,
|
||||
fin: true,
|
||||
generateMask: this._generateMask,
|
||||
mask,
|
||||
maskBuffer: this._maskBuffer,
|
||||
opcode: 0x0a,
|
||||
readOnly,
|
||||
rsv1: false
|
||||
};
|
||||
|
||||
if (this._deflating) {
|
||||
this.enqueue([this.dispatch, data, false, options, cb]);
|
||||
} else {
|
||||
this.sendFrame(Sender.frame(data, options), cb);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sends a data message to the other peer.
|
||||
*
|
||||
* @param {*} data The message to send
|
||||
* @param {Object} options Options object
|
||||
* @param {Boolean} [options.binary=false] Specifies whether `data` is binary
|
||||
* or text
|
||||
* @param {Boolean} [options.compress=false] Specifies whether or not to
|
||||
* compress `data`
|
||||
* @param {Boolean} [options.fin=false] Specifies whether the fragment is the
|
||||
* last one
|
||||
* @param {Boolean} [options.mask=false] Specifies whether or not to mask
|
||||
* `data`
|
||||
* @param {Function} [cb] Callback
|
||||
* @public
|
||||
*/
|
||||
send(data, options, cb) {
|
||||
const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];
|
||||
let opcode = options.binary ? 2 : 1;
|
||||
let rsv1 = options.compress;
|
||||
|
||||
let byteLength;
|
||||
let readOnly;
|
||||
|
||||
if (typeof data === 'string') {
|
||||
byteLength = Buffer.byteLength(data);
|
||||
readOnly = false;
|
||||
} else {
|
||||
data = toBuffer(data);
|
||||
byteLength = data.length;
|
||||
readOnly = toBuffer.readOnly;
|
||||
}
|
||||
|
||||
if (this._firstFragment) {
|
||||
this._firstFragment = false;
|
||||
if (
|
||||
rsv1 &&
|
||||
perMessageDeflate &&
|
||||
perMessageDeflate.params[
|
||||
perMessageDeflate._isServer
|
||||
? 'server_no_context_takeover'
|
||||
: 'client_no_context_takeover'
|
||||
]
|
||||
) {
|
||||
rsv1 = byteLength >= perMessageDeflate._threshold;
|
||||
}
|
||||
this._compress = rsv1;
|
||||
} else {
|
||||
rsv1 = false;
|
||||
opcode = 0;
|
||||
}
|
||||
|
||||
if (options.fin) this._firstFragment = true;
|
||||
|
||||
if (perMessageDeflate) {
|
||||
const opts = {
|
||||
[kByteLength]: byteLength,
|
||||
fin: options.fin,
|
||||
generateMask: this._generateMask,
|
||||
mask: options.mask,
|
||||
maskBuffer: this._maskBuffer,
|
||||
opcode,
|
||||
readOnly,
|
||||
rsv1
|
||||
};
|
||||
|
||||
if (this._deflating) {
|
||||
this.enqueue([this.dispatch, data, this._compress, opts, cb]);
|
||||
} else {
|
||||
this.dispatch(data, this._compress, opts, cb);
|
||||
}
|
||||
} else {
|
||||
this.sendFrame(
|
||||
Sender.frame(data, {
|
||||
[kByteLength]: byteLength,
|
||||
fin: options.fin,
|
||||
generateMask: this._generateMask,
|
||||
mask: options.mask,
|
||||
maskBuffer: this._maskBuffer,
|
||||
opcode,
|
||||
readOnly,
|
||||
rsv1: false
|
||||
}),
|
||||
cb
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Dispatches a message.
|
||||
*
|
||||
* @param {(Buffer|String)} data The message to send
|
||||
* @param {Boolean} [compress=false] Specifies whether or not to compress
|
||||
* `data`
|
||||
* @param {Object} options Options object
|
||||
* @param {Boolean} [options.fin=false] Specifies whether or not to set the
|
||||
* FIN bit
|
||||
* @param {Function} [options.generateMask] The function used to generate the
|
||||
* masking key
|
||||
* @param {Boolean} [options.mask=false] Specifies whether or not to mask
|
||||
* `data`
|
||||
* @param {Buffer} [options.maskBuffer] The buffer used to store the masking
|
||||
* key
|
||||
* @param {Number} options.opcode The opcode
|
||||
* @param {Boolean} [options.readOnly=false] Specifies whether `data` can be
|
||||
* modified
|
||||
* @param {Boolean} [options.rsv1=false] Specifies whether or not to set the
|
||||
* RSV1 bit
|
||||
* @param {Function} [cb] Callback
|
||||
* @private
|
||||
*/
|
||||
dispatch(data, compress, options, cb) {
|
||||
if (!compress) {
|
||||
this.sendFrame(Sender.frame(data, options), cb);
|
||||
return;
|
||||
}
|
||||
|
||||
const perMessageDeflate = this._extensions[PerMessageDeflate.extensionName];
|
||||
|
||||
this._bufferedBytes += options[kByteLength];
|
||||
this._deflating = true;
|
||||
perMessageDeflate.compress(data, options.fin, (_, buf) => {
|
||||
if (this._socket.destroyed) {
|
||||
const err = new Error(
|
||||
'The socket was closed while data was being compressed'
|
||||
);
|
||||
|
||||
if (typeof cb === 'function') cb(err);
|
||||
|
||||
for (let i = 0; i < this._queue.length; i++) {
|
||||
const params = this._queue[i];
|
||||
const callback = params[params.length - 1];
|
||||
|
||||
if (typeof callback === 'function') callback(err);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
this._bufferedBytes -= options[kByteLength];
|
||||
this._deflating = false;
|
||||
options.readOnly = false;
|
||||
this.sendFrame(Sender.frame(buf, options), cb);
|
||||
this.dequeue();
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Executes queued send operations.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
dequeue() {
|
||||
while (!this._deflating && this._queue.length) {
|
||||
const params = this._queue.shift();
|
||||
|
||||
this._bufferedBytes -= params[3][kByteLength];
|
||||
Reflect.apply(params[0], this, params.slice(1));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Enqueues a send operation.
|
||||
*
|
||||
* @param {Array} params Send operation parameters.
|
||||
* @private
|
||||
*/
|
||||
enqueue(params) {
|
||||
this._bufferedBytes += params[3][kByteLength];
|
||||
this._queue.push(params);
|
||||
}
|
||||
|
||||
/**
|
||||
* Sends a frame.
|
||||
*
|
||||
* @param {Buffer[]} list The frame to send
|
||||
* @param {Function} [cb] Callback
|
||||
* @private
|
||||
*/
|
||||
sendFrame(list, cb) {
|
||||
if (list.length === 2) {
|
||||
this._socket.cork();
|
||||
this._socket.write(list[0]);
|
||||
this._socket.write(list[1], cb);
|
||||
this._socket.uncork();
|
||||
} else {
|
||||
this._socket.write(list[0], cb);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = Sender;
|
159
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/stream.js
generated
vendored
Executable file
159
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/stream.js
generated
vendored
Executable file
|
@ -0,0 +1,159 @@
|
|||
'use strict';
|
||||
|
||||
const { Duplex } = require('stream');
|
||||
|
||||
/**
|
||||
* Emits the `'close'` event on a stream.
|
||||
*
|
||||
* @param {Duplex} stream The stream.
|
||||
* @private
|
||||
*/
|
||||
function emitClose(stream) {
|
||||
stream.emit('close');
|
||||
}
|
||||
|
||||
/**
|
||||
* The listener of the `'end'` event.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
function duplexOnEnd() {
|
||||
if (!this.destroyed && this._writableState.finished) {
|
||||
this.destroy();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* The listener of the `'error'` event.
|
||||
*
|
||||
* @param {Error} err The error
|
||||
* @private
|
||||
*/
|
||||
function duplexOnError(err) {
|
||||
this.removeListener('error', duplexOnError);
|
||||
this.destroy();
|
||||
if (this.listenerCount('error') === 0) {
|
||||
// Do not suppress the throwing behavior.
|
||||
this.emit('error', err);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Wraps a `WebSocket` in a duplex stream.
|
||||
*
|
||||
* @param {WebSocket} ws The `WebSocket` to wrap
|
||||
* @param {Object} [options] The options for the `Duplex` constructor
|
||||
* @return {Duplex} The duplex stream
|
||||
* @public
|
||||
*/
|
||||
function createWebSocketStream(ws, options) {
|
||||
let terminateOnDestroy = true;
|
||||
|
||||
const duplex = new Duplex({
|
||||
...options,
|
||||
autoDestroy: false,
|
||||
emitClose: false,
|
||||
objectMode: false,
|
||||
writableObjectMode: false
|
||||
});
|
||||
|
||||
ws.on('message', function message(msg, isBinary) {
|
||||
const data =
|
||||
!isBinary && duplex._readableState.objectMode ? msg.toString() : msg;
|
||||
|
||||
if (!duplex.push(data)) ws.pause();
|
||||
});
|
||||
|
||||
ws.once('error', function error(err) {
|
||||
if (duplex.destroyed) return;
|
||||
|
||||
// Prevent `ws.terminate()` from being called by `duplex._destroy()`.
|
||||
//
|
||||
// - If the `'error'` event is emitted before the `'open'` event, then
|
||||
// `ws.terminate()` is a noop as no socket is assigned.
|
||||
// - Otherwise, the error is re-emitted by the listener of the `'error'`
|
||||
// event of the `Receiver` object. The listener already closes the
|
||||
// connection by calling `ws.close()`. This allows a close frame to be
|
||||
// sent to the other peer. If `ws.terminate()` is called right after this,
|
||||
// then the close frame might not be sent.
|
||||
terminateOnDestroy = false;
|
||||
duplex.destroy(err);
|
||||
});
|
||||
|
||||
ws.once('close', function close() {
|
||||
if (duplex.destroyed) return;
|
||||
|
||||
duplex.push(null);
|
||||
});
|
||||
|
||||
duplex._destroy = function (err, callback) {
|
||||
if (ws.readyState === ws.CLOSED) {
|
||||
callback(err);
|
||||
process.nextTick(emitClose, duplex);
|
||||
return;
|
||||
}
|
||||
|
||||
let called = false;
|
||||
|
||||
ws.once('error', function error(err) {
|
||||
called = true;
|
||||
callback(err);
|
||||
});
|
||||
|
||||
ws.once('close', function close() {
|
||||
if (!called) callback(err);
|
||||
process.nextTick(emitClose, duplex);
|
||||
});
|
||||
|
||||
if (terminateOnDestroy) ws.terminate();
|
||||
};
|
||||
|
||||
duplex._final = function (callback) {
|
||||
if (ws.readyState === ws.CONNECTING) {
|
||||
ws.once('open', function open() {
|
||||
duplex._final(callback);
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
// If the value of the `_socket` property is `null` it means that `ws` is a
|
||||
// client websocket and the handshake failed. In fact, when this happens, a
|
||||
// socket is never assigned to the websocket. Wait for the `'error'` event
|
||||
// that will be emitted by the websocket.
|
||||
if (ws._socket === null) return;
|
||||
|
||||
if (ws._socket._writableState.finished) {
|
||||
callback();
|
||||
if (duplex._readableState.endEmitted) duplex.destroy();
|
||||
} else {
|
||||
ws._socket.once('finish', function finish() {
|
||||
// `duplex` is not destroyed here because the `'end'` event will be
|
||||
// emitted on `duplex` after this `'finish'` event. The EOF signaling
|
||||
// `null` chunk is, in fact, pushed when the websocket emits `'close'`.
|
||||
callback();
|
||||
});
|
||||
ws.close();
|
||||
}
|
||||
};
|
||||
|
||||
duplex._read = function () {
|
||||
if (ws.isPaused) ws.resume();
|
||||
};
|
||||
|
||||
duplex._write = function (chunk, encoding, callback) {
|
||||
if (ws.readyState === ws.CONNECTING) {
|
||||
ws.once('open', function open() {
|
||||
duplex._write(chunk, encoding, callback);
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
ws.send(chunk, callback);
|
||||
};
|
||||
|
||||
duplex.on('end', duplexOnEnd);
|
||||
duplex.on('error', duplexOnError);
|
||||
return duplex;
|
||||
}
|
||||
|
||||
module.exports = createWebSocketStream;
|
62
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/subprotocol.js
generated
vendored
Executable file
62
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/subprotocol.js
generated
vendored
Executable file
|
@ -0,0 +1,62 @@
|
|||
'use strict';
|
||||
|
||||
const { tokenChars } = require('./validation');
|
||||
|
||||
/**
|
||||
* Parses the `Sec-WebSocket-Protocol` header into a set of subprotocol names.
|
||||
*
|
||||
* @param {String} header The field value of the header
|
||||
* @return {Set} The subprotocol names
|
||||
* @public
|
||||
*/
|
||||
function parse(header) {
|
||||
const protocols = new Set();
|
||||
let start = -1;
|
||||
let end = -1;
|
||||
let i = 0;
|
||||
|
||||
for (i; i < header.length; i++) {
|
||||
const code = header.charCodeAt(i);
|
||||
|
||||
if (end === -1 && tokenChars[code] === 1) {
|
||||
if (start === -1) start = i;
|
||||
} else if (
|
||||
i !== 0 &&
|
||||
(code === 0x20 /* ' ' */ || code === 0x09) /* '\t' */
|
||||
) {
|
||||
if (end === -1 && start !== -1) end = i;
|
||||
} else if (code === 0x2c /* ',' */) {
|
||||
if (start === -1) {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
|
||||
if (end === -1) end = i;
|
||||
|
||||
const protocol = header.slice(start, end);
|
||||
|
||||
if (protocols.has(protocol)) {
|
||||
throw new SyntaxError(`The "${protocol}" subprotocol is duplicated`);
|
||||
}
|
||||
|
||||
protocols.add(protocol);
|
||||
start = end = -1;
|
||||
} else {
|
||||
throw new SyntaxError(`Unexpected character at index ${i}`);
|
||||
}
|
||||
}
|
||||
|
||||
if (start === -1 || end !== -1) {
|
||||
throw new SyntaxError('Unexpected end of input');
|
||||
}
|
||||
|
||||
const protocol = header.slice(start, i);
|
||||
|
||||
if (protocols.has(protocol)) {
|
||||
throw new SyntaxError(`The "${protocol}" subprotocol is duplicated`);
|
||||
}
|
||||
|
||||
protocols.add(protocol);
|
||||
return protocols;
|
||||
}
|
||||
|
||||
module.exports = { parse };
|
130
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/validation.js
generated
vendored
Executable file
130
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/validation.js
generated
vendored
Executable file
|
@ -0,0 +1,130 @@
|
|||
'use strict';
|
||||
|
||||
const { isUtf8 } = require('buffer');
|
||||
|
||||
//
|
||||
// Allowed token characters:
|
||||
//
|
||||
// '!', '#', '$', '%', '&', ''', '*', '+', '-',
|
||||
// '.', 0-9, A-Z, '^', '_', '`', a-z, '|', '~'
|
||||
//
|
||||
// tokenChars[32] === 0 // ' '
|
||||
// tokenChars[33] === 1 // '!'
|
||||
// tokenChars[34] === 0 // '"'
|
||||
// ...
|
||||
//
|
||||
// prettier-ignore
|
||||
const tokenChars = [
|
||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 0 - 15
|
||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16 - 31
|
||||
0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, // 32 - 47
|
||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, // 48 - 63
|
||||
0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64 - 79
|
||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, // 80 - 95
|
||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96 - 111
|
||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0 // 112 - 127
|
||||
];
|
||||
|
||||
/**
|
||||
* Checks if a status code is allowed in a close frame.
|
||||
*
|
||||
* @param {Number} code The status code
|
||||
* @return {Boolean} `true` if the status code is valid, else `false`
|
||||
* @public
|
||||
*/
|
||||
function isValidStatusCode(code) {
|
||||
return (
|
||||
(code >= 1000 &&
|
||||
code <= 1014 &&
|
||||
code !== 1004 &&
|
||||
code !== 1005 &&
|
||||
code !== 1006) ||
|
||||
(code >= 3000 && code <= 4999)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if a given buffer contains only correct UTF-8.
|
||||
* Ported from https://www.cl.cam.ac.uk/%7Emgk25/ucs/utf8_check.c by
|
||||
* Markus Kuhn.
|
||||
*
|
||||
* @param {Buffer} buf The buffer to check
|
||||
* @return {Boolean} `true` if `buf` contains only correct UTF-8, else `false`
|
||||
* @public
|
||||
*/
|
||||
function _isValidUTF8(buf) {
|
||||
const len = buf.length;
|
||||
let i = 0;
|
||||
|
||||
while (i < len) {
|
||||
if ((buf[i] & 0x80) === 0) {
|
||||
// 0xxxxxxx
|
||||
i++;
|
||||
} else if ((buf[i] & 0xe0) === 0xc0) {
|
||||
// 110xxxxx 10xxxxxx
|
||||
if (
|
||||
i + 1 === len ||
|
||||
(buf[i + 1] & 0xc0) !== 0x80 ||
|
||||
(buf[i] & 0xfe) === 0xc0 // Overlong
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
i += 2;
|
||||
} else if ((buf[i] & 0xf0) === 0xe0) {
|
||||
// 1110xxxx 10xxxxxx 10xxxxxx
|
||||
if (
|
||||
i + 2 >= len ||
|
||||
(buf[i + 1] & 0xc0) !== 0x80 ||
|
||||
(buf[i + 2] & 0xc0) !== 0x80 ||
|
||||
(buf[i] === 0xe0 && (buf[i + 1] & 0xe0) === 0x80) || // Overlong
|
||||
(buf[i] === 0xed && (buf[i + 1] & 0xe0) === 0xa0) // Surrogate (U+D800 - U+DFFF)
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
i += 3;
|
||||
} else if ((buf[i] & 0xf8) === 0xf0) {
|
||||
// 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
|
||||
if (
|
||||
i + 3 >= len ||
|
||||
(buf[i + 1] & 0xc0) !== 0x80 ||
|
||||
(buf[i + 2] & 0xc0) !== 0x80 ||
|
||||
(buf[i + 3] & 0xc0) !== 0x80 ||
|
||||
(buf[i] === 0xf0 && (buf[i + 1] & 0xf0) === 0x80) || // Overlong
|
||||
(buf[i] === 0xf4 && buf[i + 1] > 0x8f) ||
|
||||
buf[i] > 0xf4 // > U+10FFFF
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
i += 4;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
isValidStatusCode,
|
||||
isValidUTF8: _isValidUTF8,
|
||||
tokenChars
|
||||
};
|
||||
|
||||
if (isUtf8) {
|
||||
module.exports.isValidUTF8 = function (buf) {
|
||||
return buf.length < 24 ? _isValidUTF8(buf) : isUtf8(buf);
|
||||
};
|
||||
} /* istanbul ignore else */ else if (!process.env.WS_NO_UTF_8_VALIDATE) {
|
||||
try {
|
||||
const isValidUTF8 = require('utf-8-validate');
|
||||
|
||||
module.exports.isValidUTF8 = function (buf) {
|
||||
return buf.length < 32 ? _isValidUTF8(buf) : isValidUTF8(buf);
|
||||
};
|
||||
} catch (e) {
|
||||
// Continue regardless of the error.
|
||||
}
|
||||
}
|
539
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/websocket-server.js
generated
vendored
Executable file
539
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/websocket-server.js
generated
vendored
Executable file
|
@ -0,0 +1,539 @@
|
|||
/* eslint no-unused-vars: ["error", { "varsIgnorePattern": "^Duplex$" }] */
|
||||
|
||||
'use strict';
|
||||
|
||||
const EventEmitter = require('events');
|
||||
const http = require('http');
|
||||
const { Duplex } = require('stream');
|
||||
const { createHash } = require('crypto');
|
||||
|
||||
const extension = require('./extension');
|
||||
const PerMessageDeflate = require('./permessage-deflate');
|
||||
const subprotocol = require('./subprotocol');
|
||||
const WebSocket = require('./websocket');
|
||||
const { GUID, kWebSocket } = require('./constants');
|
||||
|
||||
const keyRegex = /^[+/0-9A-Za-z]{22}==$/;
|
||||
|
||||
const RUNNING = 0;
|
||||
const CLOSING = 1;
|
||||
const CLOSED = 2;
|
||||
|
||||
/**
|
||||
* Class representing a WebSocket server.
|
||||
*
|
||||
* @extends EventEmitter
|
||||
*/
|
||||
class WebSocketServer extends EventEmitter {
|
||||
/**
|
||||
* Create a `WebSocketServer` instance.
|
||||
*
|
||||
* @param {Object} options Configuration options
|
||||
* @param {Boolean} [options.allowSynchronousEvents=false] Specifies whether
|
||||
* any of the `'message'`, `'ping'`, and `'pong'` events can be emitted
|
||||
* multiple times in the same tick
|
||||
* @param {Boolean} [options.autoPong=true] Specifies whether or not to
|
||||
* automatically send a pong in response to a ping
|
||||
* @param {Number} [options.backlog=511] The maximum length of the queue of
|
||||
* pending connections
|
||||
* @param {Boolean} [options.clientTracking=true] Specifies whether or not to
|
||||
* track clients
|
||||
* @param {Function} [options.handleProtocols] A hook to handle protocols
|
||||
* @param {String} [options.host] The hostname where to bind the server
|
||||
* @param {Number} [options.maxPayload=104857600] The maximum allowed message
|
||||
* size
|
||||
* @param {Boolean} [options.noServer=false] Enable no server mode
|
||||
* @param {String} [options.path] Accept only connections matching this path
|
||||
* @param {(Boolean|Object)} [options.perMessageDeflate=false] Enable/disable
|
||||
* permessage-deflate
|
||||
* @param {Number} [options.port] The port where to bind the server
|
||||
* @param {(http.Server|https.Server)} [options.server] A pre-created HTTP/S
|
||||
* server to use
|
||||
* @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or
|
||||
* not to skip UTF-8 validation for text and close messages
|
||||
* @param {Function} [options.verifyClient] A hook to reject connections
|
||||
* @param {Function} [options.WebSocket=WebSocket] Specifies the `WebSocket`
|
||||
* class to use. It must be the `WebSocket` class or class that extends it
|
||||
* @param {Function} [callback] A listener for the `listening` event
|
||||
*/
|
||||
constructor(options, callback) {
|
||||
super();
|
||||
|
||||
options = {
|
||||
allowSynchronousEvents: false,
|
||||
autoPong: true,
|
||||
maxPayload: 100 * 1024 * 1024,
|
||||
skipUTF8Validation: false,
|
||||
perMessageDeflate: false,
|
||||
handleProtocols: null,
|
||||
clientTracking: true,
|
||||
verifyClient: null,
|
||||
noServer: false,
|
||||
backlog: null, // use default (511 as implemented in net.js)
|
||||
server: null,
|
||||
host: null,
|
||||
path: null,
|
||||
port: null,
|
||||
WebSocket,
|
||||
...options
|
||||
};
|
||||
|
||||
if (
|
||||
(options.port == null && !options.server && !options.noServer) ||
|
||||
(options.port != null && (options.server || options.noServer)) ||
|
||||
(options.server && options.noServer)
|
||||
) {
|
||||
throw new TypeError(
|
||||
'One and only one of the "port", "server", or "noServer" options ' +
|
||||
'must be specified'
|
||||
);
|
||||
}
|
||||
|
||||
if (options.port != null) {
|
||||
this._server = http.createServer((req, res) => {
|
||||
const body = http.STATUS_CODES[426];
|
||||
|
||||
res.writeHead(426, {
|
||||
'Content-Length': body.length,
|
||||
'Content-Type': 'text/plain'
|
||||
});
|
||||
res.end(body);
|
||||
});
|
||||
this._server.listen(
|
||||
options.port,
|
||||
options.host,
|
||||
options.backlog,
|
||||
callback
|
||||
);
|
||||
} else if (options.server) {
|
||||
this._server = options.server;
|
||||
}
|
||||
|
||||
if (this._server) {
|
||||
const emitConnection = this.emit.bind(this, 'connection');
|
||||
|
||||
this._removeListeners = addListeners(this._server, {
|
||||
listening: this.emit.bind(this, 'listening'),
|
||||
error: this.emit.bind(this, 'error'),
|
||||
upgrade: (req, socket, head) => {
|
||||
this.handleUpgrade(req, socket, head, emitConnection);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
if (options.perMessageDeflate === true) options.perMessageDeflate = {};
|
||||
if (options.clientTracking) {
|
||||
this.clients = new Set();
|
||||
this._shouldEmitClose = false;
|
||||
}
|
||||
|
||||
this.options = options;
|
||||
this._state = RUNNING;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the bound address, the address family name, and port of the server
|
||||
* as reported by the operating system if listening on an IP socket.
|
||||
* If the server is listening on a pipe or UNIX domain socket, the name is
|
||||
* returned as a string.
|
||||
*
|
||||
* @return {(Object|String|null)} The address of the server
|
||||
* @public
|
||||
*/
|
||||
address() {
|
||||
if (this.options.noServer) {
|
||||
throw new Error('The server is operating in "noServer" mode');
|
||||
}
|
||||
|
||||
if (!this._server) return null;
|
||||
return this._server.address();
|
||||
}
|
||||
|
||||
/**
|
||||
* Stop the server from accepting new connections and emit the `'close'` event
|
||||
* when all existing connections are closed.
|
||||
*
|
||||
* @param {Function} [cb] A one-time listener for the `'close'` event
|
||||
* @public
|
||||
*/
|
||||
close(cb) {
|
||||
if (this._state === CLOSED) {
|
||||
if (cb) {
|
||||
this.once('close', () => {
|
||||
cb(new Error('The server is not running'));
|
||||
});
|
||||
}
|
||||
|
||||
process.nextTick(emitClose, this);
|
||||
return;
|
||||
}
|
||||
|
||||
if (cb) this.once('close', cb);
|
||||
|
||||
if (this._state === CLOSING) return;
|
||||
this._state = CLOSING;
|
||||
|
||||
if (this.options.noServer || this.options.server) {
|
||||
if (this._server) {
|
||||
this._removeListeners();
|
||||
this._removeListeners = this._server = null;
|
||||
}
|
||||
|
||||
if (this.clients) {
|
||||
if (!this.clients.size) {
|
||||
process.nextTick(emitClose, this);
|
||||
} else {
|
||||
this._shouldEmitClose = true;
|
||||
}
|
||||
} else {
|
||||
process.nextTick(emitClose, this);
|
||||
}
|
||||
} else {
|
||||
const server = this._server;
|
||||
|
||||
this._removeListeners();
|
||||
this._removeListeners = this._server = null;
|
||||
|
||||
//
|
||||
// The HTTP/S server was created internally. Close it, and rely on its
|
||||
// `'close'` event.
|
||||
//
|
||||
server.close(() => {
|
||||
emitClose(this);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* See if a given request should be handled by this server instance.
|
||||
*
|
||||
* @param {http.IncomingMessage} req Request object to inspect
|
||||
* @return {Boolean} `true` if the request is valid, else `false`
|
||||
* @public
|
||||
*/
|
||||
shouldHandle(req) {
|
||||
if (this.options.path) {
|
||||
const index = req.url.indexOf('?');
|
||||
const pathname = index !== -1 ? req.url.slice(0, index) : req.url;
|
||||
|
||||
if (pathname !== this.options.path) return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle a HTTP Upgrade request.
|
||||
*
|
||||
* @param {http.IncomingMessage} req The request object
|
||||
* @param {Duplex} socket The network socket between the server and client
|
||||
* @param {Buffer} head The first packet of the upgraded stream
|
||||
* @param {Function} cb Callback
|
||||
* @public
|
||||
*/
|
||||
handleUpgrade(req, socket, head, cb) {
|
||||
socket.on('error', socketOnError);
|
||||
|
||||
const key = req.headers['sec-websocket-key'];
|
||||
const version = +req.headers['sec-websocket-version'];
|
||||
|
||||
if (req.method !== 'GET') {
|
||||
const message = 'Invalid HTTP method';
|
||||
abortHandshakeOrEmitwsClientError(this, req, socket, 405, message);
|
||||
return;
|
||||
}
|
||||
|
||||
if (req.headers.upgrade.toLowerCase() !== 'websocket') {
|
||||
const message = 'Invalid Upgrade header';
|
||||
abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!key || !keyRegex.test(key)) {
|
||||
const message = 'Missing or invalid Sec-WebSocket-Key header';
|
||||
abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
|
||||
return;
|
||||
}
|
||||
|
||||
if (version !== 8 && version !== 13) {
|
||||
const message = 'Missing or invalid Sec-WebSocket-Version header';
|
||||
abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!this.shouldHandle(req)) {
|
||||
abortHandshake(socket, 400);
|
||||
return;
|
||||
}
|
||||
|
||||
const secWebSocketProtocol = req.headers['sec-websocket-protocol'];
|
||||
let protocols = new Set();
|
||||
|
||||
if (secWebSocketProtocol !== undefined) {
|
||||
try {
|
||||
protocols = subprotocol.parse(secWebSocketProtocol);
|
||||
} catch (err) {
|
||||
const message = 'Invalid Sec-WebSocket-Protocol header';
|
||||
abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
const secWebSocketExtensions = req.headers['sec-websocket-extensions'];
|
||||
const extensions = {};
|
||||
|
||||
if (
|
||||
this.options.perMessageDeflate &&
|
||||
secWebSocketExtensions !== undefined
|
||||
) {
|
||||
const perMessageDeflate = new PerMessageDeflate(
|
||||
this.options.perMessageDeflate,
|
||||
true,
|
||||
this.options.maxPayload
|
||||
);
|
||||
|
||||
try {
|
||||
const offers = extension.parse(secWebSocketExtensions);
|
||||
|
||||
if (offers[PerMessageDeflate.extensionName]) {
|
||||
perMessageDeflate.accept(offers[PerMessageDeflate.extensionName]);
|
||||
extensions[PerMessageDeflate.extensionName] = perMessageDeflate;
|
||||
}
|
||||
} catch (err) {
|
||||
const message =
|
||||
'Invalid or unacceptable Sec-WebSocket-Extensions header';
|
||||
abortHandshakeOrEmitwsClientError(this, req, socket, 400, message);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
//
|
||||
// Optionally call external client verification handler.
|
||||
//
|
||||
if (this.options.verifyClient) {
|
||||
const info = {
|
||||
origin:
|
||||
req.headers[`${version === 8 ? 'sec-websocket-origin' : 'origin'}`],
|
||||
secure: !!(req.socket.authorized || req.socket.encrypted),
|
||||
req
|
||||
};
|
||||
|
||||
if (this.options.verifyClient.length === 2) {
|
||||
this.options.verifyClient(info, (verified, code, message, headers) => {
|
||||
if (!verified) {
|
||||
return abortHandshake(socket, code || 401, message, headers);
|
||||
}
|
||||
|
||||
this.completeUpgrade(
|
||||
extensions,
|
||||
key,
|
||||
protocols,
|
||||
req,
|
||||
socket,
|
||||
head,
|
||||
cb
|
||||
);
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
if (!this.options.verifyClient(info)) return abortHandshake(socket, 401);
|
||||
}
|
||||
|
||||
this.completeUpgrade(extensions, key, protocols, req, socket, head, cb);
|
||||
}
|
||||
|
||||
/**
|
||||
* Upgrade the connection to WebSocket.
|
||||
*
|
||||
* @param {Object} extensions The accepted extensions
|
||||
* @param {String} key The value of the `Sec-WebSocket-Key` header
|
||||
* @param {Set} protocols The subprotocols
|
||||
* @param {http.IncomingMessage} req The request object
|
||||
* @param {Duplex} socket The network socket between the server and client
|
||||
* @param {Buffer} head The first packet of the upgraded stream
|
||||
* @param {Function} cb Callback
|
||||
* @throws {Error} If called more than once with the same socket
|
||||
* @private
|
||||
*/
|
||||
completeUpgrade(extensions, key, protocols, req, socket, head, cb) {
|
||||
//
|
||||
// Destroy the socket if the client has already sent a FIN packet.
|
||||
//
|
||||
if (!socket.readable || !socket.writable) return socket.destroy();
|
||||
|
||||
if (socket[kWebSocket]) {
|
||||
throw new Error(
|
||||
'server.handleUpgrade() was called more than once with the same ' +
|
||||
'socket, possibly due to a misconfiguration'
|
||||
);
|
||||
}
|
||||
|
||||
if (this._state > RUNNING) return abortHandshake(socket, 503);
|
||||
|
||||
const digest = createHash('sha1')
|
||||
.update(key + GUID)
|
||||
.digest('base64');
|
||||
|
||||
const headers = [
|
||||
'HTTP/1.1 101 Switching Protocols',
|
||||
'Upgrade: websocket',
|
||||
'Connection: Upgrade',
|
||||
`Sec-WebSocket-Accept: ${digest}`
|
||||
];
|
||||
|
||||
const ws = new this.options.WebSocket(null, undefined, this.options);
|
||||
|
||||
if (protocols.size) {
|
||||
//
|
||||
// Optionally call external protocol selection handler.
|
||||
//
|
||||
const protocol = this.options.handleProtocols
|
||||
? this.options.handleProtocols(protocols, req)
|
||||
: protocols.values().next().value;
|
||||
|
||||
if (protocol) {
|
||||
headers.push(`Sec-WebSocket-Protocol: ${protocol}`);
|
||||
ws._protocol = protocol;
|
||||
}
|
||||
}
|
||||
|
||||
if (extensions[PerMessageDeflate.extensionName]) {
|
||||
const params = extensions[PerMessageDeflate.extensionName].params;
|
||||
const value = extension.format({
|
||||
[PerMessageDeflate.extensionName]: [params]
|
||||
});
|
||||
headers.push(`Sec-WebSocket-Extensions: ${value}`);
|
||||
ws._extensions = extensions;
|
||||
}
|
||||
|
||||
//
|
||||
// Allow external modification/inspection of handshake headers.
|
||||
//
|
||||
this.emit('headers', headers, req);
|
||||
|
||||
socket.write(headers.concat('\r\n').join('\r\n'));
|
||||
socket.removeListener('error', socketOnError);
|
||||
|
||||
ws.setSocket(socket, head, {
|
||||
allowSynchronousEvents: this.options.allowSynchronousEvents,
|
||||
maxPayload: this.options.maxPayload,
|
||||
skipUTF8Validation: this.options.skipUTF8Validation
|
||||
});
|
||||
|
||||
if (this.clients) {
|
||||
this.clients.add(ws);
|
||||
ws.on('close', () => {
|
||||
this.clients.delete(ws);
|
||||
|
||||
if (this._shouldEmitClose && !this.clients.size) {
|
||||
process.nextTick(emitClose, this);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
cb(ws, req);
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = WebSocketServer;
|
||||
|
||||
/**
|
||||
* Add event listeners on an `EventEmitter` using a map of <event, listener>
|
||||
* pairs.
|
||||
*
|
||||
* @param {EventEmitter} server The event emitter
|
||||
* @param {Object.<String, Function>} map The listeners to add
|
||||
* @return {Function} A function that will remove the added listeners when
|
||||
* called
|
||||
* @private
|
||||
*/
|
||||
function addListeners(server, map) {
|
||||
for (const event of Object.keys(map)) server.on(event, map[event]);
|
||||
|
||||
return function removeListeners() {
|
||||
for (const event of Object.keys(map)) {
|
||||
server.removeListener(event, map[event]);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* Emit a `'close'` event on an `EventEmitter`.
|
||||
*
|
||||
* @param {EventEmitter} server The event emitter
|
||||
* @private
|
||||
*/
|
||||
function emitClose(server) {
|
||||
server._state = CLOSED;
|
||||
server.emit('close');
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle socket errors.
|
||||
*
|
||||
* @private
|
||||
*/
|
||||
function socketOnError() {
|
||||
this.destroy();
|
||||
}
|
||||
|
||||
/**
|
||||
* Close the connection when preconditions are not fulfilled.
|
||||
*
|
||||
* @param {Duplex} socket The socket of the upgrade request
|
||||
* @param {Number} code The HTTP response status code
|
||||
* @param {String} [message] The HTTP response body
|
||||
* @param {Object} [headers] Additional HTTP response headers
|
||||
* @private
|
||||
*/
|
||||
function abortHandshake(socket, code, message, headers) {
|
||||
//
|
||||
// The socket is writable unless the user destroyed or ended it before calling
|
||||
// `server.handleUpgrade()` or in the `verifyClient` function, which is a user
|
||||
// error. Handling this does not make much sense as the worst that can happen
|
||||
// is that some of the data written by the user might be discarded due to the
|
||||
// call to `socket.end()` below, which triggers an `'error'` event that in
|
||||
// turn causes the socket to be destroyed.
|
||||
//
|
||||
message = message || http.STATUS_CODES[code];
|
||||
headers = {
|
||||
Connection: 'close',
|
||||
'Content-Type': 'text/html',
|
||||
'Content-Length': Buffer.byteLength(message),
|
||||
...headers
|
||||
};
|
||||
|
||||
socket.once('finish', socket.destroy);
|
||||
|
||||
socket.end(
|
||||
`HTTP/1.1 ${code} ${http.STATUS_CODES[code]}\r\n` +
|
||||
Object.keys(headers)
|
||||
.map((h) => `${h}: ${headers[h]}`)
|
||||
.join('\r\n') +
|
||||
'\r\n\r\n' +
|
||||
message
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Emit a `'wsClientError'` event on a `WebSocketServer` if there is at least
|
||||
* one listener for it, otherwise call `abortHandshake()`.
|
||||
*
|
||||
* @param {WebSocketServer} server The WebSocket server
|
||||
* @param {http.IncomingMessage} req The request object
|
||||
* @param {Duplex} socket The socket of the upgrade request
|
||||
* @param {Number} code The HTTP response status code
|
||||
* @param {String} message The HTTP response body
|
||||
* @private
|
||||
*/
|
||||
function abortHandshakeOrEmitwsClientError(server, req, socket, code, message) {
|
||||
if (server.listenerCount('wsClientError')) {
|
||||
const err = new Error(message);
|
||||
Error.captureStackTrace(err, abortHandshakeOrEmitwsClientError);
|
||||
|
||||
server.emit('wsClientError', err, socket, req);
|
||||
} else {
|
||||
abortHandshake(socket, code, message);
|
||||
}
|
||||
}
|
1336
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/websocket.js
generated
vendored
Executable file
1336
my-app/node_modules/webpack-dev-server/node_modules/ws/lib/websocket.js
generated
vendored
Executable file
File diff suppressed because it is too large
Load diff
68
my-app/node_modules/webpack-dev-server/node_modules/ws/package.json
generated
vendored
Executable file
68
my-app/node_modules/webpack-dev-server/node_modules/ws/package.json
generated
vendored
Executable file
|
@ -0,0 +1,68 @@
|
|||
{
|
||||
"name": "ws",
|
||||
"version": "8.16.0",
|
||||
"description": "Simple to use, blazing fast and thoroughly tested websocket client and server for Node.js",
|
||||
"keywords": [
|
||||
"HyBi",
|
||||
"Push",
|
||||
"RFC-6455",
|
||||
"WebSocket",
|
||||
"WebSockets",
|
||||
"real-time"
|
||||
],
|
||||
"homepage": "https://github.com/websockets/ws",
|
||||
"bugs": "https://github.com/websockets/ws/issues",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git+https://github.com/websockets/ws.git"
|
||||
},
|
||||
"author": "Einar Otto Stangvik <einaros@gmail.com> (http://2x.io)",
|
||||
"license": "MIT",
|
||||
"main": "index.js",
|
||||
"exports": {
|
||||
".": {
|
||||
"browser": "./browser.js",
|
||||
"import": "./wrapper.mjs",
|
||||
"require": "./index.js"
|
||||
},
|
||||
"./package.json": "./package.json"
|
||||
},
|
||||
"browser": "browser.js",
|
||||
"engines": {
|
||||
"node": ">=10.0.0"
|
||||
},
|
||||
"files": [
|
||||
"browser.js",
|
||||
"index.js",
|
||||
"lib/*.js",
|
||||
"wrapper.mjs"
|
||||
],
|
||||
"scripts": {
|
||||
"test": "nyc --reporter=lcov --reporter=text mocha --throw-deprecation test/*.test.js",
|
||||
"integration": "mocha --throw-deprecation test/*.integration.js",
|
||||
"lint": "eslint --ignore-path .gitignore . && prettier --check --ignore-path .gitignore \"**/*.{json,md,yaml,yml}\""
|
||||
},
|
||||
"peerDependencies": {
|
||||
"bufferutil": "^4.0.1",
|
||||
"utf-8-validate": ">=5.0.2"
|
||||
},
|
||||
"peerDependenciesMeta": {
|
||||
"bufferutil": {
|
||||
"optional": true
|
||||
},
|
||||
"utf-8-validate": {
|
||||
"optional": true
|
||||
}
|
||||
},
|
||||
"devDependencies": {
|
||||
"benchmark": "^2.1.4",
|
||||
"bufferutil": "^4.0.1",
|
||||
"eslint": "^8.0.0",
|
||||
"eslint-config-prettier": "^9.0.0",
|
||||
"eslint-plugin-prettier": "^5.0.0",
|
||||
"mocha": "^8.4.0",
|
||||
"nyc": "^15.0.0",
|
||||
"prettier": "^3.0.0",
|
||||
"utf-8-validate": "^6.0.0"
|
||||
}
|
||||
}
|
8
my-app/node_modules/webpack-dev-server/node_modules/ws/wrapper.mjs
generated
vendored
Executable file
8
my-app/node_modules/webpack-dev-server/node_modules/ws/wrapper.mjs
generated
vendored
Executable file
|
@ -0,0 +1,8 @@
|
|||
import createWebSocketStream from './lib/stream.js';
|
||||
import Receiver from './lib/receiver.js';
|
||||
import Sender from './lib/sender.js';
|
||||
import WebSocket from './lib/websocket.js';
|
||||
import WebSocketServer from './lib/websocket-server.js';
|
||||
|
||||
export { createWebSocketStream, Receiver, Sender, WebSocket, WebSocketServer };
|
||||
export default WebSocket;
|
147
my-app/node_modules/webpack-dev-server/package.json
generated
vendored
Executable file
147
my-app/node_modules/webpack-dev-server/package.json
generated
vendored
Executable file
|
@ -0,0 +1,147 @@
|
|||
{
|
||||
"name": "webpack-dev-server",
|
||||
"version": "4.15.1",
|
||||
"description": "Serves a webpack app. Updates the browser on changes.",
|
||||
"bin": "bin/webpack-dev-server.js",
|
||||
"main": "lib/Server.js",
|
||||
"types": "types/lib/Server.d.ts",
|
||||
"author": "Tobias Koppers @sokra",
|
||||
"bugs": "https://github.com/webpack/webpack-dev-server/issues",
|
||||
"homepage": "https://github.com/webpack/webpack-dev-server#readme",
|
||||
"repository": "https://github.com/webpack/webpack-dev-server",
|
||||
"license": "MIT",
|
||||
"funding": {
|
||||
"type": "opencollective",
|
||||
"url": "https://opencollective.com/webpack"
|
||||
},
|
||||
"files": [
|
||||
"bin",
|
||||
"lib",
|
||||
"client",
|
||||
"types"
|
||||
],
|
||||
"engines": {
|
||||
"node": ">= 12.13.0"
|
||||
},
|
||||
"scripts": {
|
||||
"fmt:check": "prettier \"{**/*,*}.{js,json,md,yml,css,ts}\" --list-different",
|
||||
"lint:js": "eslint . --cache",
|
||||
"lint:types": "tsc --pretty --noEmit",
|
||||
"lint": "npm-run-all -p \"fmt:**\" \"lint:**\"",
|
||||
"fmt": "npm run fmt:check -- --write",
|
||||
"fix:js": "npm run lint:js -- --fix",
|
||||
"fix": "npm-run-all fix:js fmt",
|
||||
"commitlint": "commitlint --from=master",
|
||||
"build:client": "rimraf ./client/* && babel client-src/ --out-dir client/ --ignore \"client-src/webpack.config.js\" --ignore \"client-src/modules\" && webpack --config client-src/webpack.config.js",
|
||||
"build:types": "rimraf ./types/* && tsc --declaration --emitDeclarationOnly --outDir types && node ./scripts/extend-webpack-types.js && prettier \"types/**/*.ts\" --write && prettier \"types/**/*.ts\" --write",
|
||||
"build": "npm-run-all -p \"build:**\"",
|
||||
"test:only": "jest",
|
||||
"test:coverage": "npm run test:only -- --coverage",
|
||||
"test:watch": "npm run test:coverage --watch",
|
||||
"test": "npm run test:coverage",
|
||||
"pretest": "npm run lint",
|
||||
"prepare": "husky install && npm run build",
|
||||
"release": "standard-version"
|
||||
},
|
||||
"dependencies": {
|
||||
"@types/bonjour": "^3.5.9",
|
||||
"@types/connect-history-api-fallback": "^1.3.5",
|
||||
"@types/express": "^4.17.13",
|
||||
"@types/serve-index": "^1.9.1",
|
||||
"@types/serve-static": "^1.13.10",
|
||||
"@types/sockjs": "^0.3.33",
|
||||
"@types/ws": "^8.5.5",
|
||||
"ansi-html-community": "^0.0.8",
|
||||
"bonjour-service": "^1.0.11",
|
||||
"chokidar": "^3.5.3",
|
||||
"colorette": "^2.0.10",
|
||||
"compression": "^1.7.4",
|
||||
"connect-history-api-fallback": "^2.0.0",
|
||||
"default-gateway": "^6.0.3",
|
||||
"express": "^4.17.3",
|
||||
"graceful-fs": "^4.2.6",
|
||||
"html-entities": "^2.3.2",
|
||||
"http-proxy-middleware": "^2.0.3",
|
||||
"ipaddr.js": "^2.0.1",
|
||||
"launch-editor": "^2.6.0",
|
||||
"open": "^8.0.9",
|
||||
"p-retry": "^4.5.0",
|
||||
"rimraf": "^3.0.2",
|
||||
"schema-utils": "^4.0.0",
|
||||
"selfsigned": "^2.1.1",
|
||||
"serve-index": "^1.9.1",
|
||||
"sockjs": "^0.3.24",
|
||||
"spdy": "^4.0.2",
|
||||
"webpack-dev-middleware": "^5.3.1",
|
||||
"ws": "^8.13.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/cli": "^7.17.3",
|
||||
"@babel/core": "^7.20.2",
|
||||
"@babel/eslint-parser": "^7.17.0",
|
||||
"@babel/plugin-transform-object-assign": "^7.14.5",
|
||||
"@babel/plugin-transform-runtime": "^7.17.0",
|
||||
"@babel/preset-env": "^7.20.2",
|
||||
"@babel/runtime": "^7.20.1",
|
||||
"@commitlint/cli": "^16.2.3",
|
||||
"@commitlint/config-conventional": "^16.2.1",
|
||||
"@types/compression": "^1.7.2",
|
||||
"@types/default-gateway": "^3.0.1",
|
||||
"@types/node": "^18.11.9",
|
||||
"@types/node-forge": "^1.3.1",
|
||||
"@types/rimraf": "^3.0.2",
|
||||
"@types/sockjs-client": "^1.5.1",
|
||||
"@types/trusted-types": "^2.0.2",
|
||||
"acorn": "^8.2.4",
|
||||
"babel-jest": "^28.1.3",
|
||||
"babel-loader": "^8.2.4",
|
||||
"body-parser": "^1.19.2",
|
||||
"core-js": "^3.21.1",
|
||||
"css-loader": "^5.2.4",
|
||||
"eslint": "^8.28.0",
|
||||
"eslint-config-prettier": "^8.4.0",
|
||||
"eslint-config-webpack": "^1.2.5",
|
||||
"eslint-plugin-import": "^2.23.2",
|
||||
"execa": "^5.1.1",
|
||||
"file-loader": "^6.2.0",
|
||||
"html-webpack-plugin": "^4.5.2",
|
||||
"http-proxy": "^1.18.1",
|
||||
"husky": "^7.0.0",
|
||||
"jest": "^28.1.3",
|
||||
"jest-environment-jsdom": "^28.1.3",
|
||||
"klona": "^2.0.4",
|
||||
"less": "^4.1.1",
|
||||
"less-loader": "^7.3.0",
|
||||
"lint-staged": "^12.3.4",
|
||||
"marked": "^4.2.3",
|
||||
"memfs": "^3.4.12",
|
||||
"npm-run-all": "^4.1.5",
|
||||
"prettier": "^2.8.0",
|
||||
"puppeteer": "^13.4.1",
|
||||
"require-from-string": "^2.0.2",
|
||||
"rimraf": "^3.0.2",
|
||||
"sockjs-client": "^1.6.1",
|
||||
"standard-version": "^9.3.0",
|
||||
"strip-ansi-v6": "npm:strip-ansi@^6.0.0",
|
||||
"style-loader": "^2.0.0",
|
||||
"supertest": "^6.1.3",
|
||||
"tcp-port-used": "^1.0.2",
|
||||
"typescript": "^4.9.3",
|
||||
"url-loader": "^4.1.1",
|
||||
"wait-for-expect": "^3.0.2",
|
||||
"webpack": "^5.81.0",
|
||||
"webpack-cli": "^4.7.2",
|
||||
"webpack-merge": "^5.8.0"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"webpack": "^4.37.0 || ^5.0.0"
|
||||
},
|
||||
"peerDependenciesMeta": {
|
||||
"webpack-cli": {
|
||||
"optional": true
|
||||
},
|
||||
"webpack": {
|
||||
"optional": true
|
||||
}
|
||||
}
|
||||
}
|
987
my-app/node_modules/webpack-dev-server/types/bin/cli-flags.d.ts
generated
vendored
Executable file
987
my-app/node_modules/webpack-dev-server/types/bin/cli-flags.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,987 @@
|
|||
declare const _exports: {
|
||||
"allowed-hosts": {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: string[];
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"allowed-hosts-reset": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
bonjour: {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
client: {
|
||||
configs: {
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: boolean[];
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"client-logging": {
|
||||
configs: {
|
||||
type: string;
|
||||
values: string[];
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-overlay": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-overlay-errors": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-overlay-trusted-types-policy-name": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"client-overlay-warnings": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-overlay-runtime-errors": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-progress": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-reconnect": {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-web-socket-transport": {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
values: string[];
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-web-socket-url": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-web-socket-url-hostname": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-web-socket-url-password": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-web-socket-url-pathname": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-web-socket-url-port": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"client-web-socket-url-protocol": {
|
||||
configs: (
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: string[];
|
||||
}
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"client-web-socket-url-username": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
compress: {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"history-api-fallback": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
host: {
|
||||
configs: (
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: string[];
|
||||
}
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
hot: {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
type: string;
|
||||
values: string[];
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
http2: {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
https: {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"https-ca": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"https-ca-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"https-cacert": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"https-cacert-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"https-cert": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"https-cert-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"https-crl": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"https-crl-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"https-key": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"https-key-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"https-passphrase": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"https-pfx": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"https-pfx-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"https-request-cert": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
ipc: {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
type: string;
|
||||
values: boolean[];
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"live-reload": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"magic-html": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
open: {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"open-app": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"open-app-name": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"open-app-name-reset": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"open-reset": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"open-target": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"open-target-reset": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
port: {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
type: string;
|
||||
values: string[];
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"server-options-ca": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-ca-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-cacert": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-cacert-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-cert": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-cert-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-crl": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-crl-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-key": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-key-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-passphrase": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-pfx": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-pfx-reset": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-options-request-cert": {
|
||||
configs: {
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
"server-type": {
|
||||
configs: {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: string[];
|
||||
}[];
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
simpleType: string;
|
||||
};
|
||||
static: {
|
||||
configs: (
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}
|
||||
| {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"static-directory": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"static-public-path": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"static-public-path-reset": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"static-reset": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"static-serve-index": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"static-watch": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"watch-files": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"watch-files-reset": {
|
||||
configs: {
|
||||
type: string;
|
||||
multiple: boolean;
|
||||
description: string;
|
||||
path: string;
|
||||
}[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"web-socket-server": {
|
||||
configs: (
|
||||
| {
|
||||
description: string;
|
||||
negatedDescription: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: boolean[];
|
||||
}
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: string[];
|
||||
}
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
"web-socket-server-type": {
|
||||
configs: (
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
values: string[];
|
||||
}
|
||||
| {
|
||||
description: string;
|
||||
multiple: boolean;
|
||||
path: string;
|
||||
type: string;
|
||||
}
|
||||
)[];
|
||||
description: string;
|
||||
simpleType: string;
|
||||
multiple: boolean;
|
||||
};
|
||||
};
|
||||
export = _exports;
|
50
my-app/node_modules/webpack-dev-server/types/bin/process-arguments.d.ts
generated
vendored
Executable file
50
my-app/node_modules/webpack-dev-server/types/bin/process-arguments.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,50 @@
|
|||
export = processArguments;
|
||||
/**
|
||||
* @param {Record<string, Argument>} args object of arguments
|
||||
* @param {any} config configuration
|
||||
* @param {Record<string, string | number | boolean | RegExp | (string | number | boolean | RegExp)[]>} values object with values
|
||||
* @returns {Problem[] | null} problems or null for success
|
||||
*/
|
||||
declare function processArguments(
|
||||
args: Record<string, Argument>,
|
||||
config: any,
|
||||
values: Record<
|
||||
string,
|
||||
string | number | boolean | RegExp | (string | number | boolean | RegExp)[]
|
||||
>
|
||||
): Problem[] | null;
|
||||
declare namespace processArguments {
|
||||
export { ProblemType, Problem, LocalProblem, ArgumentConfig, Argument };
|
||||
}
|
||||
type Argument = {
|
||||
description: string;
|
||||
simpleType: "string" | "number" | "boolean";
|
||||
multiple: boolean;
|
||||
configs: ArgumentConfig[];
|
||||
};
|
||||
type Problem = {
|
||||
type: ProblemType;
|
||||
path: string;
|
||||
argument: string;
|
||||
value?: any | undefined;
|
||||
index?: number | undefined;
|
||||
expected?: string | undefined;
|
||||
};
|
||||
type ProblemType =
|
||||
| "unknown-argument"
|
||||
| "unexpected-non-array-in-path"
|
||||
| "unexpected-non-object-in-path"
|
||||
| "multiple-values-unexpected"
|
||||
| "invalid-value";
|
||||
type LocalProblem = {
|
||||
type: ProblemType;
|
||||
path: string;
|
||||
expected?: string | undefined;
|
||||
};
|
||||
type ArgumentConfig = {
|
||||
description: string;
|
||||
path: string;
|
||||
multiple: boolean;
|
||||
type: "enum" | "string" | "path" | "number" | "boolean" | "RegExp" | "reset";
|
||||
values?: any[] | undefined;
|
||||
};
|
27
my-app/node_modules/webpack-dev-server/types/bin/webpack-dev-server.d.ts
generated
vendored
Executable file
27
my-app/node_modules/webpack-dev-server/types/bin/webpack-dev-server.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,27 @@
|
|||
#!/usr/bin/env node
|
||||
export type CliOption = {
|
||||
/**
|
||||
* display name
|
||||
*/
|
||||
name: string;
|
||||
/**
|
||||
* npm package name
|
||||
*/
|
||||
package: string;
|
||||
/**
|
||||
* name of the executable file
|
||||
*/
|
||||
binName: string;
|
||||
/**
|
||||
* currently installed?
|
||||
*/
|
||||
installed: boolean;
|
||||
/**
|
||||
* homepage
|
||||
*/
|
||||
url: string;
|
||||
/**
|
||||
* preprocessor
|
||||
*/
|
||||
preprocess: Function;
|
||||
};
|
3853
my-app/node_modules/webpack-dev-server/types/lib/Server.d.ts
generated
vendored
Executable file
3853
my-app/node_modules/webpack-dev-server/types/lib/Server.d.ts
generated
vendored
Executable file
File diff suppressed because it is too large
Load diff
10
my-app/node_modules/webpack-dev-server/types/lib/getPort.d.ts
generated
vendored
Executable file
10
my-app/node_modules/webpack-dev-server/types/lib/getPort.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,10 @@
|
|||
export = getPorts;
|
||||
/**
|
||||
* @param {number} basePort
|
||||
* @param {string=} host
|
||||
* @return {Promise<number>}
|
||||
*/
|
||||
declare function getPorts(
|
||||
basePort: number,
|
||||
host?: string | undefined
|
||||
): Promise<number>;
|
15
my-app/node_modules/webpack-dev-server/types/lib/servers/BaseServer.d.ts
generated
vendored
Executable file
15
my-app/node_modules/webpack-dev-server/types/lib/servers/BaseServer.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,15 @@
|
|||
export = BaseServer;
|
||||
declare class BaseServer {
|
||||
/**
|
||||
* @param {import("../Server")} server
|
||||
*/
|
||||
constructor(server: import("../Server"));
|
||||
/** @type {import("../Server")} */
|
||||
server: import("../Server");
|
||||
/** @type {ClientConnection[]} */
|
||||
clients: ClientConnection[];
|
||||
}
|
||||
declare namespace BaseServer {
|
||||
export { ClientConnection };
|
||||
}
|
||||
type ClientConnection = import("../Server").ClientConnection;
|
12
my-app/node_modules/webpack-dev-server/types/lib/servers/SockJSServer.d.ts
generated
vendored
Executable file
12
my-app/node_modules/webpack-dev-server/types/lib/servers/SockJSServer.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,12 @@
|
|||
export = SockJSServer;
|
||||
declare class SockJSServer extends BaseServer {
|
||||
implementation: sockjs.Server;
|
||||
}
|
||||
declare namespace SockJSServer {
|
||||
export { WebSocketServerConfiguration, ClientConnection };
|
||||
}
|
||||
import BaseServer = require("./BaseServer");
|
||||
import sockjs = require("sockjs");
|
||||
type WebSocketServerConfiguration =
|
||||
import("../Server").WebSocketServerConfiguration;
|
||||
type ClientConnection = import("../Server").ClientConnection;
|
17
my-app/node_modules/webpack-dev-server/types/lib/servers/WebsocketServer.d.ts
generated
vendored
Executable file
17
my-app/node_modules/webpack-dev-server/types/lib/servers/WebsocketServer.d.ts
generated
vendored
Executable file
|
@ -0,0 +1,17 @@
|
|||
/// <reference types="node" />
|
||||
export = WebsocketServer;
|
||||
declare class WebsocketServer extends BaseServer {
|
||||
static heartbeatInterval: number;
|
||||
implementation: WebSocket.Server<
|
||||
typeof WebSocket,
|
||||
typeof import("http").IncomingMessage
|
||||
>;
|
||||
}
|
||||
declare namespace WebsocketServer {
|
||||
export { WebSocketServerConfiguration, ClientConnection };
|
||||
}
|
||||
import BaseServer = require("./BaseServer");
|
||||
import WebSocket = require("ws");
|
||||
type WebSocketServerConfiguration =
|
||||
import("../Server").WebSocketServerConfiguration;
|
||||
type ClientConnection = import("../Server").ClientConnection;
|
Loading…
Add table
Add a link
Reference in a new issue