Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
M
mongoose
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
esp
mongoose
Commits
d8c12e44
Commit
d8c12e44
authored
Sep 09, 2010
by
valenok
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactored set_port_option
parent
4c1451ba
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
64 additions
and
61 deletions
+64
-61
mongoose.c
mongoose.c
+64
-61
No files found.
mongoose.c
View file @
d8c12e44
...
@@ -373,6 +373,7 @@ struct socket {
...
@@ -373,6 +373,7 @@ struct socket {
struct
usa
lsa
;
// Local socket address
struct
usa
lsa
;
// Local socket address
struct
usa
rsa
;
// Remote socket address
struct
usa
rsa
;
// Remote socket address
int
is_ssl
;
// Is socket SSL-ed
int
is_ssl
;
// Is socket SSL-ed
int
is_proxy
;
};
};
enum
{
enum
{
...
@@ -1554,7 +1555,7 @@ struct mg_connection *mg_connect(struct mg_connection *conn,
...
@@ -1554,7 +1555,7 @@ struct mg_connection *mg_connect(struct mg_connection *conn,
cry
(
conn
,
"%s: socket: %s"
,
__func__
,
strerror
(
ERRNO
));
cry
(
conn
,
"%s: socket: %s"
,
__func__
,
strerror
(
ERRNO
));
}
else
{
}
else
{
sin
.
sin_family
=
AF_INET
;
sin
.
sin_family
=
AF_INET
;
sin
.
sin_port
=
htons
(
port
);
sin
.
sin_port
=
htons
(
(
uint16_t
)
port
);
sin
.
sin_addr
=
*
(
struct
in_addr
*
)
he
->
h_addr_list
[
0
];
sin
.
sin_addr
=
*
(
struct
in_addr
*
)
he
->
h_addr_list
[
0
];
if
(
connect
(
sock
,
(
struct
sockaddr
*
)
&
sin
,
sizeof
(
sin
))
!=
0
)
{
if
(
connect
(
sock
,
(
struct
sockaddr
*
)
&
sin
,
sizeof
(
sin
))
!=
0
)
{
cry
(
conn
,
"%s: connect(%s:%d): %s"
,
__func__
,
host
,
port
,
cry
(
conn
,
"%s: connect(%s:%d): %s"
,
__func__
,
host
,
port
,
...
@@ -1575,52 +1576,6 @@ struct mg_connection *mg_connect(struct mg_connection *conn,
...
@@ -1575,52 +1576,6 @@ struct mg_connection *mg_connect(struct mg_connection *conn,
return
newconn
;
return
newconn
;
}
}
// Setup listening socket on given address, return socket.
// Address format: [local_ip_address:]port_number
static
SOCKET
mg_open_listening_port
(
struct
mg_context
*
ctx
,
const
char
*
str
,
struct
usa
*
usa
)
{
SOCKET
sock
;
int
on
=
1
,
a
,
b
,
c
,
d
,
port
;
// MacOS needs that. If we do not zero it, bind() will fail.
(
void
)
memset
(
usa
,
0
,
sizeof
(
*
usa
));
if
(
sscanf
(
str
,
"%d.%d.%d.%d:%d"
,
&
a
,
&
b
,
&
c
,
&
d
,
&
port
)
==
5
)
{
// IP address to bind to is specified
usa
->
u
.
sin
.
sin_addr
.
s_addr
=
htonl
((
a
<<
24
)
|
(
b
<<
16
)
|
(
c
<<
8
)
|
d
);
}
else
if
(
sscanf
(
str
,
"%d"
,
&
port
)
==
1
)
{
// Only port number is specified. Bind to all addresses
usa
->
u
.
sin
.
sin_addr
.
s_addr
=
htonl
(
INADDR_ANY
);
}
else
{
return
INVALID_SOCKET
;
}
usa
->
len
=
sizeof
(
usa
->
u
.
sin
);
usa
->
u
.
sin
.
sin_family
=
AF_INET
;
usa
->
u
.
sin
.
sin_port
=
htons
((
uint16_t
)
port
);
if
((
sock
=
socket
(
PF_INET
,
SOCK_STREAM
,
6
))
!=
INVALID_SOCKET
&&
#if !defined(_WIN32)
// On windows, SO_REUSEADDR is recommended only for broadcast UDP sockets
setsockopt
(
sock
,
SOL_SOCKET
,
SO_REUSEADDR
,
(
char
*
)
&
on
,
sizeof
(
on
))
==
0
&&
#endif // !_WIN32
bind
(
sock
,
&
usa
->
u
.
sa
,
usa
->
len
)
==
0
&&
listen
(
sock
,
20
)
==
0
)
{
// Success
set_close_on_exec
(
sock
);
}
else
{
// Error
cry
(
fc
(
ctx
),
"%s(%d): %s"
,
__func__
,
port
,
strerror
(
ERRNO
));
if
(
sock
!=
INVALID_SOCKET
)
(
void
)
closesocket
(
sock
);
sock
=
INVALID_SOCKET
;
}
return
sock
;
}
// Check whether full request is buffered. Return:
// Check whether full request is buffered. Return:
// -1 if request is malformed
// -1 if request is malformed
// 0 if request is not yet fully buffered
// 0 if request is not yet fully buffered
...
@@ -3287,30 +3242,78 @@ static void close_all_listening_sockets(struct mg_context *ctx) {
...
@@ -3287,30 +3242,78 @@ static void close_all_listening_sockets(struct mg_context *ctx) {
}
}
}
}
// Valid listening port specification is: [ip_address:]port[s[p]]
// Examples: 80, 443s, 127.0.0.1:3128p, 1.2.3.4:8080sp
static
int
parse_port_string
(
const
struct
vec
*
vec
,
struct
socket
*
so
)
{
struct
usa
*
usa
=
&
so
->
lsa
;
int
a
,
b
,
c
,
d
,
port
,
len
;
// MacOS needs that. If we do not zero it, subsequent bind() will fail.
memset
(
so
,
0
,
sizeof
(
*
so
));
if
(
sscanf
(
vec
->
ptr
,
"%d.%d.%d.%d:%d%n"
,
&
a
,
&
b
,
&
c
,
&
d
,
&
port
,
&
len
)
==
5
)
{
// IP address to bind to is specified
usa
->
u
.
sin
.
sin_addr
.
s_addr
=
htonl
((
a
<<
24
)
|
(
b
<<
16
)
|
(
c
<<
8
)
|
d
);
}
else
if
(
sscanf
(
vec
->
ptr
,
"%d%n"
,
&
port
,
&
len
)
==
1
)
{
// Only port number is specified. Bind to all addresses
usa
->
u
.
sin
.
sin_addr
.
s_addr
=
htonl
(
INADDR_ANY
);
}
else
{
return
0
;
}
assert
(
len
>
0
&&
len
<=
(
int
)
vec
->
len
);
so
->
is_ssl
=
vec
->
ptr
[
len
]
==
's'
;
so
->
is_proxy
=
vec
->
ptr
[
len
]
==
'p'
||
(
vec
->
ptr
[
len
]
==
's'
&&
vec
->
ptr
[
len
+
1
]
==
'p'
);
if
(
vec
->
ptr
[
len
+
so
->
is_ssl
+
so
->
is_proxy
]
!=
'\0'
&&
vec
->
ptr
[
len
+
so
->
is_ssl
+
so
->
is_proxy
]
!=
','
)
{
return
0
;
}
usa
->
len
=
sizeof
(
usa
->
u
.
sin
);
usa
->
u
.
sin
.
sin_family
=
AF_INET
;
usa
->
u
.
sin
.
sin_port
=
htons
((
uint16_t
)
port
);
return
1
;
}
static
int
set_ports_option
(
struct
mg_context
*
ctx
)
{
static
int
set_ports_option
(
struct
mg_context
*
ctx
)
{
SOCKET
sock
;
const
char
*
list
=
ctx
->
config
[
LISTENING_PORTS
];
const
char
*
list
=
ctx
->
config
[
LISTENING_PORTS
];
int
is_ssl
,
success
=
1
;
int
reuseaddr
=
1
,
success
=
1
;
SOCKET
sock
;
struct
vec
vec
;
struct
vec
vec
;
struct
socket
*
listener
;
struct
socket
so
,
*
listener
;
while
(
success
&&
(
list
=
next_option
(
list
,
&
vec
,
NULL
))
!=
NULL
)
{
while
(
success
&&
(
list
=
next_option
(
list
,
&
vec
,
NULL
))
!=
NULL
)
{
is_ssl
=
vec
.
ptr
[
vec
.
len
-
1
]
==
's'
;
if
(
!
parse_port_string
(
&
vec
,
&
so
))
{
cry
(
fc
(
ctx
),
"%s: %.*s: invalid port spec. Expecting list of: %s"
,
if
((
listener
=
calloc
(
1
,
sizeof
(
*
listener
)))
==
NULL
)
{
__func__
,
vec
.
len
,
vec
.
ptr
,
"[IP_ADDRESS:]PORT[s[p]]"
);
cry
(
fc
(
ctx
),
"%s"
,
"Too many listeninig sockets"
);
success
=
0
;
}
else
if
((
sock
=
mg_open_listening_port
(
ctx
,
vec
.
ptr
,
&
listener
->
lsa
))
==
INVALID_SOCKET
)
{
cry
(
fc
(
ctx
),
"cannot bind to %.*s"
,
vec
.
len
,
vec
.
ptr
);
success
=
0
;
success
=
0
;
}
else
if
(
is_ssl
&&
ctx
->
ssl_ctx
==
NULL
)
{
}
else
if
(
so
.
is_ssl
&&
ctx
->
ssl_ctx
==
NULL
)
{
(
void
)
closesocket
(
sock
);
cry
(
fc
(
ctx
),
"Cannot add SSL socket, is -ssl_cert option set?"
);
cry
(
fc
(
ctx
),
"Cannot add SSL socket, is -ssl_cert option set?"
);
success
=
0
;
success
=
0
;
}
else
if
((
sock
=
socket
(
PF_INET
,
SOCK_STREAM
,
6
))
==
INVALID_SOCKET
||
#if !defined(_WIN32)
// On Windows, SO_REUSEADDR is recommended only for
// broadcast UDP sockets
setsockopt
(
sock
,
SOL_SOCKET
,
SO_REUSEADDR
,
&
reuseaddr
,
sizeof
(
reuseaddr
))
!=
0
||
#endif // !_WIN32
bind
(
sock
,
&
so
.
lsa
.
u
.
sa
,
so
.
lsa
.
len
)
!=
0
||
listen
(
sock
,
20
)
!=
0
)
{
closesocket
(
sock
);
cry
(
fc
(
ctx
),
"%s: cannot bind to %.*s: %s"
,
__func__
,
vec
.
len
,
vec
.
ptr
,
strerror
(
ERRNO
));
success
=
0
;
}
else
if
((
listener
=
calloc
(
1
,
sizeof
(
*
listener
)))
==
NULL
)
{
closesocket
(
sock
);
cry
(
fc
(
ctx
),
"%s: %s"
,
__func__
,
strerror
(
ERRNO
));
success
=
0
;
}
else
{
}
else
{
*
listener
=
so
;
listener
->
sock
=
sock
;
listener
->
sock
=
sock
;
listener
->
is_ssl
=
is_ssl
;
set_close_on_exec
(
listener
->
sock
)
;
listener
->
next
=
ctx
->
listening_sockets
;
listener
->
next
=
ctx
->
listening_sockets
;
ctx
->
listening_sockets
=
listener
;
ctx
->
listening_sockets
=
listener
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment