Mercurial > hg > nginx-ranges
view src/core/ngx_unix_domain.c @ 78:9db7e0b5b27f NGINX_0_1_39
nginx 0.1.39
*) The changes in the ngx_http_charset_module: the "default_charset"
directive was canceled; the "charset" directive sets the response
charset; the "source_charset" directive sets the source charset only.
*) Bugfix: the backend "WWW-Authenticate" header line did not
transferred while the 401 response code redirecting.
*) Bugfix: the ngx_http_proxy_module and ngx_http_fastcgi_module may
close a connection before anything was transferred to a client; bug
appeared in 0.1.38.
*) Workaround: the Linux glibc crypt_r() initialization bug.
*) Bugfix: the ngx_http_ssi_module did not support the relative URI in
the "include virtual" command.
*) Bugfix: if the backend response had the "Location" header line and
nginx should not rewrite this line, then the 500 code response body
was transferred; bug appeared in 0.1.29.
*) Bugfix: some directives of the ngx_http_proxy_module and
ngx_http_fastcgi_module were not inherited from the server to the
location level; bug appeared in 0.1.29.
*) Bugfix: the ngx_http_ssl_module did not support the certificate
chain.
*) Bugfix: the ngx_http_autoindex_module did not show correctly the
long file names; bug appeared in 0.1.38.
*) Bugfixes in IMAP/POP3 proxy in interaction with a backend at the
login state.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Thu, 14 Jul 2005 00:00:00 +0400 |
parents | 818201e5a553 |
children | 146eff53ab60 |
line wrap: on
line source
/* * Copyright (C) Igor Sysoev */ #include <ngx_config.h> #include <ngx_core.h> #include <ngx_event.h> #include <ngx_event_connect.h> /* Solaris has predefined "#define sun 1" */ #undef sun ngx_peers_t * ngx_unix_upstream_parse(ngx_conf_t *cf, ngx_unix_domain_upstream_t *u) { size_t len; ngx_uint_t i; ngx_peers_t *peers; struct sockaddr_un *sun; len = u->url.len - 5; if (u->uri_part) { for (i = 5; i < u->url.len; i++) { if (u->url.data[i] == ':') { len = i - 5; u->uri.len = u->url.len - 5 - len - 1; u->uri.data = u->url.data + 5 + len + 1; break; } } if (u->uri.len == 0) { ngx_conf_log_error(NGX_LOG_EMERG, cf, 0, "the unix domain upstream \"%V\" has no URI", &u->name); return NULL; } } if (len == 0) { ngx_conf_log_error(NGX_LOG_EMERG, cf, 0, "the unix domain socket \"%V\" has no path", &u->name); return NULL; } if (len + 1 > sizeof(sun->sun_path)) { ngx_conf_log_error(NGX_LOG_EMERG, cf, 0, "the unix domain socket path \"%V\" is too long", &u->name); return NULL; } /* MP: ngx_shared_palloc() */ peers = ngx_pcalloc(cf->pool, sizeof(ngx_peers_t)); if (peers == NULL) { return NULL; } sun = ngx_pcalloc(cf->pool, sizeof(struct sockaddr_un)); if (sun == NULL) { return NULL; } peers->number = 1; sun->sun_family = AF_UNIX; (void) ngx_cpystrn((u_char *) sun->sun_path, u->url.data + 5, len + 1); peers->peer[0].sockaddr = (struct sockaddr *) sun; peers->peer[0].socklen = sizeof(struct sockaddr_un); peers->peer[0].name.len = 5 + len; peers->peer[0].name.data = u->url.data; peers->peer[0].uri_separator = ":"; return peers; }