Welcome! Log In Create A New Profile

Advanced

[njs] HTTP: fixed r.return() with empty string as a body argument.

Anonymous User
September 26, 2024 12:48AM
details: https://github.com/nginx/njs/commit/6e6a9c5ffabefbc9cd5d3a04d33f38a697ae0e65
branches: master
commit: 6e6a9c5ffabefbc9cd5d3a04d33f38a697ae0e65
user: Dmitry Volyntsev <xeioex@nginx.com>
date: Tue, 17 Sep 2024 22:58:31 -0700
description:
HTTP: fixed r.return() with empty string as a body argument.


---
nginx/ngx_http_js_module.c | 22 ++++++++++++----------
nginx/t/js_return.t | 38 ++++++++++++++++++++++++++++++++++++--
2 files changed, 48 insertions(+), 12 deletions(-)

diff --git a/nginx/ngx_http_js_module.c b/nginx/ngx_http_js_module.c
index dec65198..c34fccbd 100644
--- a/nginx/ngx_http_js_module.c
+++ b/nginx/ngx_http_js_module.c
@@ -2704,14 +2704,16 @@ ngx_http_js_ext_return(njs_vm_t *vm, njs_value_t *args, njs_uint_t nargs,
return NJS_ERROR;
}

- if (ngx_js_string(vm, njs_arg(args, nargs, 2), &text) != NGX_OK) {
- njs_vm_error(vm, "failed to convert text");
- return NJS_ERROR;
- }
-
ctx = ngx_http_get_module_ctx(r, ngx_http_js_module);

- if (status < NGX_HTTP_BAD_REQUEST || text.length) {
+ if (status < NGX_HTTP_BAD_REQUEST
+ || !njs_value_is_null_or_undefined(njs_arg(args, nargs, 2)))
+ {
+ if (ngx_js_string(vm, njs_arg(args, nargs, 2), &text) != NGX_OK) {
+ njs_vm_error(vm, "failed to convert text");
+ return NJS_ERROR;
+ }
+
ngx_memzero(&cv, sizeof(ngx_http_complex_value_t));

cv.value.data = text.start;
@@ -5352,11 +5354,11 @@ ngx_http_qjs_ext_return(JSContext *cx, JSValueConst this_val,

ctx = ngx_http_get_module_ctx(r, ngx_http_js_module);

- if (ngx_qjs_string(ctx->engine, argv[1], &body) != NGX_OK) {
- return JS_ThrowOutOfMemory(cx);
- }
+ if (status < NGX_HTTP_BAD_REQUEST || !JS_IsNullOrUndefined(argv[1])) {
+ if (ngx_qjs_string(ctx->engine, argv[1], &body) != NGX_OK) {
+ return JS_ThrowOutOfMemory(cx);
+ }

- if (status < NGX_HTTP_BAD_REQUEST || body.len) {
ngx_memzero(&cv, sizeof(ngx_http_complex_value_t));

cv.value.data = body.data;
diff --git a/nginx/t/js_return.t b/nginx/t/js_return.t
index 2cc32f74..6f8c4a93 100644
--- a/nginx/t/js_return.t
+++ b/nginx/t/js_return.t
@@ -46,21 +46,29 @@ http {
location / {
js_content test.returnf;
}
+
+ location /njs {
+ js_content test.njs;
+ }
}
}

EOF

$t->write_file('test.js', <<EOF);
+ function test_njs(r) {
+ r.return(200, njs.version);
+ }
+
function returnf(r) {
r.return(Number(r.args.c), r.args.t);
}

- export default {returnf};
+ export default {njs:test_njs, returnf};

EOF

-$t->try_run('no njs return')->plan(5);
+$t->try_run('no njs return')->plan(6);

###############################################################################

@@ -70,4 +78,30 @@ like(http_get('/?c=301&t=path'), qr/ 301 .*Location: path/s, 'return redirect');
like(http_get('/?c=404'), qr/404 Not.*html/s, 'return error page');
like(http_get('/?c=inv'), qr/ 500 /, 'return invalid');

+TODO: {
+local $TODO = 'not yet' unless has_version('0.8.6');
+
+unlike(http_get('/?c=404&t='), qr/Not.*html/s, 'return empty body');
+
+}
+
+###############################################################################
+
+sub has_version {
+ my $need = shift;
+
+ http_get('/njs') =~ /^([.0-9]+)$/m;
+
+ my @v = split(/\./, $1);
+ my ($n, $v);
+
+ for $n (split(/\./, $need)) {
+ $v = shift @v || 0;
+ return 0 if $n > $v;
+ return 1 if $v > $n;
+ }
+
+ return 1;
+}
+
###############################################################################
_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
https://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

[njs] HTTP: fixed r.return() with empty string as a body argument.

Anonymous User 59 September 26, 2024 12:48AM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 237
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 500 on July 15, 2024
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready