mirror of
https://github.com/nginx/nginx.git
synced 2024-12-17 15:17:48 +08:00
1765f47544
*) Change: the "add_header" directive adds the string to 204, 301, and 302 responses. *) Feature: the "server" directive in the "upstream" context supports the "weight" parameter. *) Feature: the "server_name" directive supports the "*" wildcard. *) Feature: nginx supports the request body size more than 2G. *) Bugfix: if a client was successfully authorized using "satisfy_any on", then anyway the message "access forbidden by rule" was written in the log. *) Bugfix: the "PUT" method may erroneously not create a file and return the 409 code. *) Bugfix: if the IMAP/POP3 backend returned an error, then nginx continued proxying anyway.
119 lines
2.4 KiB
C
119 lines
2.4 KiB
C
|
|
/*
|
|
* Copyright (C) Igor Sysoev
|
|
*/
|
|
|
|
|
|
#ifndef _NGX_INET_H_INCLUDED_
|
|
#define _NGX_INET_H_INCLUDED_
|
|
|
|
|
|
#include <ngx_config.h>
|
|
#include <ngx_core.h>
|
|
|
|
|
|
#define NGX_PARSE_URL_INET 1
|
|
#define NGX_PARSE_URL_UNIX 2
|
|
|
|
|
|
typedef struct {
|
|
in_addr_t addr;
|
|
in_addr_t mask;
|
|
} ngx_inet_cidr_t;
|
|
|
|
|
|
typedef struct {
|
|
struct sockaddr *sockaddr;
|
|
socklen_t socklen;
|
|
|
|
ngx_str_t name;
|
|
char *uri_separator;
|
|
|
|
ngx_uint_t current_weight;
|
|
ngx_uint_t weight;
|
|
|
|
ngx_uint_t fails;
|
|
time_t accessed;
|
|
|
|
ngx_uint_t max_fails;
|
|
time_t fail_timeout;
|
|
|
|
#if (NGX_SSL)
|
|
ngx_ssl_session_t *ssl_session;
|
|
#endif
|
|
} ngx_peer_t;
|
|
|
|
|
|
struct ngx_peers_s {
|
|
ngx_uint_t current;
|
|
|
|
ngx_uint_t number;
|
|
ngx_uint_t last_cached;
|
|
|
|
/* ngx_mutex_t *mutex; */
|
|
ngx_connection_t **cached;
|
|
|
|
ngx_peer_t peer[1];
|
|
};
|
|
|
|
|
|
typedef struct {
|
|
ngx_int_t type;
|
|
|
|
ngx_peers_t *peers;
|
|
|
|
ngx_str_t url;
|
|
ngx_str_t host;
|
|
ngx_str_t host_header;
|
|
ngx_str_t port;
|
|
ngx_str_t uri;
|
|
|
|
in_port_t portn;
|
|
in_port_t default_portn;
|
|
|
|
unsigned listen:1;
|
|
unsigned uri_part:1;
|
|
unsigned upstream:1;
|
|
|
|
unsigned default_port:1;
|
|
unsigned wildcard:1;
|
|
|
|
char *err;
|
|
} ngx_url_t;
|
|
|
|
|
|
typedef struct {
|
|
ngx_str_t name; /* "schema:host:port/uri" */
|
|
ngx_str_t url; /* "host:port/uri" */
|
|
ngx_str_t host;
|
|
ngx_str_t uri;
|
|
ngx_str_t host_header; /* "host:port" */
|
|
ngx_str_t port_text; /* "port" */
|
|
|
|
in_port_t port;
|
|
|
|
in_port_t default_port_value;
|
|
|
|
unsigned default_port:1;
|
|
unsigned wildcard:1;
|
|
|
|
unsigned uri_part:1;
|
|
unsigned port_only:1;
|
|
} ngx_inet_upstream_t;
|
|
|
|
|
|
size_t ngx_sock_ntop(int family, struct sockaddr *sa, u_char *text,
|
|
size_t len);
|
|
size_t ngx_inet_ntop(int family, void *addr, u_char *text, size_t len);
|
|
|
|
ngx_int_t ngx_ptocidr(ngx_str_t *text, void *cidr);
|
|
|
|
ngx_peers_t *ngx_inet_upstream_parse(ngx_conf_t *cf, ngx_inet_upstream_t *u);
|
|
ngx_peers_t *ngx_inet_resolve_peer(ngx_conf_t *cf, ngx_str_t *name,
|
|
in_port_t port);
|
|
char *ngx_inet_parse_host_port(ngx_inet_upstream_t *u);
|
|
ngx_int_t ngx_parse_url(ngx_conf_t *cf, ngx_url_t *u);
|
|
|
|
|
|
#endif /* _NGX_INET_H_INCLUDED_ */
|