summaryrefslogtreecommitdiffhomepage
path: root/src/nodejs
diff options
context:
space:
mode:
authorGabor Javorszky <g.javorszky@f5.com>2024-02-14 18:16:01 +0000
committerGitHub <noreply@github.com>2024-02-14 18:16:01 +0000
commitfbeb2065b180e2376088387ee150d3975dc08cd5 (patch)
tree41401338a7c1f484c0609e4dd63779bedf6aae52 /src/nodejs
parent2b0d93d1a73703ca4c3f1892cfd922b1d2107fb4 (diff)
downloadunit-fbeb2065b180e2376088387ee150d3975dc08cd5.tar.gz
unit-fbeb2065b180e2376088387ee150d3975dc08cd5.tar.bz2
fix: Take options as well as requestListener (#1091)
* Take options as well as requestListener Unit-http have not kept up with the signature of nodejs's http package development. Nodejs allows an optional `options` object to be passed to the `createServer` function, we didn't. This resulted in function signature errors when user code that did make use of the options arg tried to call unit's replaced function. This change changes the signature to be more in line with how nodejs does it discarding it and printing a message to stdout. * Add test file to start node application with options * Add changes to docs/changes.xml Closes: https://github.com/nginx/unit/issues/1043
Diffstat (limited to 'src/nodejs')
-rw-r--r--src/nodejs/unit-http/http.js4
-rw-r--r--src/nodejs/unit-http/http_server.js10
2 files changed, 11 insertions, 3 deletions
diff --git a/src/nodejs/unit-http/http.js b/src/nodejs/unit-http/http.js
index d298a35f..60b8004f 100644
--- a/src/nodejs/unit-http/http.js
+++ b/src/nodejs/unit-http/http.js
@@ -11,8 +11,8 @@ const {
ServerResponse,
} = require('./http_server');
-function createServer (requestHandler) {
- return new Server(requestHandler);
+function createServer (options, requestHandler) {
+ return new Server(options, requestHandler);
}
const http = require("http")
diff --git a/src/nodejs/unit-http/http_server.js b/src/nodejs/unit-http/http_server.js
index 8eb13d7f..b78f309a 100644
--- a/src/nodejs/unit-http/http_server.js
+++ b/src/nodejs/unit-http/http_server.js
@@ -5,6 +5,7 @@
'use strict';
+const { stderr } = require('process');
const EventEmitter = require('events');
const http = require('http');
const util = require('util');
@@ -413,7 +414,14 @@ ServerRequest.prototype._read = function _read(n) {
};
-function Server(requestListener) {
+function Server(options, requestListener) {
+ if (typeof options === 'function') {
+ requestListener = options;
+ options = {};
+ } else {
+ stderr.write("http.Server constructor was called with unsupported options, using default settings\n");
+ }
+
EventEmitter.call(this);
this.unit = new unit_lib.Unit();