Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
mongoose
Commits
f5f6edcf
Commit
f5f6edcf
authored
Dec 26, 2013
by
Sergey Lyubka
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added mg_printf() back
parent
9cb1048c
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
58 additions
and
10 deletions
+58
-10
mongoose.c
mongoose.c
+57
-10
mongoose.h
mongoose.h
+1
-0
No files found.
mongoose.c
View file @
f5f6edcf
...
@@ -475,7 +475,7 @@ static void send_http_error(struct connection *conn, int code) {
...
@@ -475,7 +475,7 @@ static void send_http_error(struct connection *conn, int code) {
close_local_endpoint
(
conn
);
// This will write to the log file
close_local_endpoint
(
conn
);
// This will write to the log file
}
}
static
void
mg_
printf
(
struct
connection
*
conn
,
const
char
*
fmt
,
...)
{
static
void
mg_
fmt
(
struct
connection
*
conn
,
const
char
*
fmt
,
...)
{
char
buf
[
IOBUF_SIZE
];
char
buf
[
IOBUF_SIZE
];
va_list
ap
;
va_list
ap
;
int
len
;
int
len
;
...
@@ -488,6 +488,53 @@ static void mg_printf(struct connection *conn, const char *fmt, ...) {
...
@@ -488,6 +488,53 @@ static void mg_printf(struct connection *conn, const char *fmt, ...) {
close_local_endpoint
(
conn
);
// Log the request
close_local_endpoint
(
conn
);
// Log the request
}
}
// Print message to buffer. If buffer is large enough to hold the message,
// return buffer. If buffer is to small, allocate large enough buffer on heap,
// and return allocated buffer.
static
int
alloc_vprintf
(
char
**
buf
,
size_t
size
,
const
char
*
fmt
,
va_list
ap
)
{
va_list
ap_copy
;
int
len
;
// Windows is not standard-compliant, and vsnprintf() returns -1 if
// buffer is too small. Also, older versions of msvcrt.dll do not have
// _vscprintf(). However, if size is 0, vsnprintf() behaves correctly.
// Therefore, we make two passes: on first pass, get required message length.
// On second pass, actually print the message.
va_copy
(
ap_copy
,
ap
);
len
=
vsnprintf
(
NULL
,
0
,
fmt
,
ap_copy
);
if
(
len
>
(
int
)
size
&&
(
size
=
len
+
1
)
>
0
&&
(
*
buf
=
(
char
*
)
malloc
(
size
))
==
NULL
)
{
len
=
-
1
;
// Allocation failed, mark failure
}
else
{
va_copy
(
ap_copy
,
ap
);
vsnprintf
(
*
buf
,
size
,
fmt
,
ap_copy
);
}
return
len
;
}
int
mg_vprintf
(
struct
mg_connection
*
conn
,
const
char
*
fmt
,
va_list
ap
)
{
char
mem
[
IOBUF_SIZE
],
*
buf
=
mem
;
int
len
;
if
((
len
=
alloc_vprintf
(
&
buf
,
sizeof
(
mem
),
fmt
,
ap
))
>
0
)
{
len
=
mg_write
(
conn
,
buf
,
(
size_t
)
len
);
}
if
(
buf
!=
mem
&&
buf
!=
NULL
)
{
free
(
buf
);
}
return
len
;
}
int
mg_printf
(
struct
mg_connection
*
conn
,
const
char
*
fmt
,
...)
{
va_list
ap
;
va_start
(
ap
,
fmt
);
return
mg_vprintf
(
conn
,
fmt
,
ap
);
}
// A helper function for traversing a comma separated list of values.
// A helper function for traversing a comma separated list of values.
// It returns a list pointer shifted to the next value, or NULL if the end
// It returns a list pointer shifted to the next value, or NULL if the end
// of the list found.
// of the list found.
...
@@ -2232,7 +2279,7 @@ static void handle_put(struct connection *conn, const char *path) {
...
@@ -2232,7 +2279,7 @@ static void handle_put(struct connection *conn, const char *path) {
conn
->
mg_conn
.
status_code
=
!
stat
(
path
,
&
st
)
?
200
:
201
;
conn
->
mg_conn
.
status_code
=
!
stat
(
path
,
&
st
)
?
200
:
201
;
if
((
rc
=
put_dir
(
path
))
==
0
)
{
if
((
rc
=
put_dir
(
path
))
==
0
)
{
mg_
printf
(
conn
,
"HTTP/1.1 %d OK
\r\n\r\n
"
,
conn
->
mg_conn
.
status_code
);
mg_
fmt
(
conn
,
"HTTP/1.1 %d OK
\r\n\r\n
"
,
conn
->
mg_conn
.
status_code
);
}
else
if
(
rc
==
-
1
)
{
}
else
if
(
rc
==
-
1
)
{
send_http_error
(
conn
,
500
);
send_http_error
(
conn
,
500
);
}
else
if
(
cl_hdr
==
NULL
)
{
}
else
if
(
cl_hdr
==
NULL
)
{
...
@@ -2282,12 +2329,12 @@ static void send_options(struct connection *conn) {
...
@@ -2282,12 +2329,12 @@ static void send_options(struct connection *conn) {
#ifndef NO_AUTH
#ifndef NO_AUTH
static
void
send_authorization_request
(
struct
connection
*
conn
)
{
static
void
send_authorization_request
(
struct
connection
*
conn
)
{
conn
->
mg_conn
.
status_code
=
401
;
conn
->
mg_conn
.
status_code
=
401
;
mg_
printf
(
conn
,
mg_
fmt
(
conn
,
"HTTP/1.1 401 Unauthorized
\r\n
"
"HTTP/1.1 401 Unauthorized
\r\n
"
"WWW-Authenticate: Digest qop=
\"
auth
\"
, "
"WWW-Authenticate: Digest qop=
\"
auth
\"
, "
"realm=
\"
%s
\"
, nonce=
\"
%lu
\"\r\n\r\n
"
,
"realm=
\"
%s
\"
, nonce=
\"
%lu
\"\r\n\r\n
"
,
conn
->
server
->
config_options
[
AUTH_DOMAIN
],
conn
->
server
->
config_options
[
AUTH_DOMAIN
],
(
unsigned
long
)
time
(
NULL
));
(
unsigned
long
)
time
(
NULL
));
}
}
// Use the global passwords file, if specified by auth_gpass option,
// Use the global passwords file, if specified by auth_gpass option,
...
@@ -2921,8 +2968,8 @@ static void open_local_endpoint(struct connection *conn) {
...
@@ -2921,8 +2968,8 @@ static void open_local_endpoint(struct connection *conn) {
send_http_error
(
conn
,
404
);
send_http_error
(
conn
,
404
);
}
else
if
(
is_directory
&&
}
else
if
(
is_directory
&&
conn
->
mg_conn
.
uri
[
strlen
(
conn
->
mg_conn
.
uri
)
-
1
]
!=
'/'
)
{
conn
->
mg_conn
.
uri
[
strlen
(
conn
->
mg_conn
.
uri
)
-
1
]
!=
'/'
)
{
mg_
printf
(
conn
,
"HTTP/1.1 301 Moved Permanently
\r\n
"
mg_
fmt
(
conn
,
"HTTP/1.1 301 Moved Permanently
\r\n
"
"Location: %s/
\r\n\r\n
"
,
conn
->
mg_conn
.
uri
);
"Location: %s/
\r\n\r\n
"
,
conn
->
mg_conn
.
uri
);
}
else
if
(
is_directory
&&
!
find_index_file
(
conn
,
path
,
sizeof
(
path
),
&
st
))
{
}
else
if
(
is_directory
&&
!
find_index_file
(
conn
,
path
,
sizeof
(
path
),
&
st
))
{
if
(
!
mg_strcasecmp
(
dir_lst
,
"yes"
))
{
if
(
!
mg_strcasecmp
(
dir_lst
,
"yes"
))
{
#ifndef NO_DIRECTORY_LISTING
#ifndef NO_DIRECTORY_LISTING
...
...
mongoose.h
View file @
f5f6edcf
...
@@ -77,6 +77,7 @@ int mg_iterate_over_connections(struct mg_server *,
...
@@ -77,6 +77,7 @@ int mg_iterate_over_connections(struct mg_server *,
int
mg_write
(
struct
mg_connection
*
,
const
void
*
buf
,
int
len
);
int
mg_write
(
struct
mg_connection
*
,
const
void
*
buf
,
int
len
);
int
mg_websocket_write
(
struct
mg_connection
*
,
int
opcode
,
int
mg_websocket_write
(
struct
mg_connection
*
,
int
opcode
,
const
char
*
data
,
size_t
data_len
);
const
char
*
data
,
size_t
data_len
);
int
mg_printf
(
struct
mg_connection
*
conn
,
const
char
*
fmt
,
...);
const
char
*
mg_get_header
(
const
struct
mg_connection
*
,
const
char
*
name
);
const
char
*
mg_get_header
(
const
struct
mg_connection
*
,
const
char
*
name
);
const
char
*
mg_get_mime_type
(
const
char
*
file_name
);
const
char
*
mg_get_mime_type
(
const
char
*
file_name
);
...
...
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