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
4d65cb1c
Commit
4d65cb1c
authored
8 years ago
by
Deomid Ryabkov
Committed by
Cesanta Bot
8 years ago
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make Mongoose's SHA1 algo pluggable
PUBLISHED_FROM=bdaeed6628ffb544e31d7fd59475f3a2e78c2967
parent
ced823cd
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
22 additions
and
9 deletions
+22
-9
mongoose.c
mongoose.c
+22
-9
No files found.
mongoose.c
View file @
4d65cb1c
...
@@ -4791,19 +4791,32 @@ static void mg_websocket_handler(struct mg_connection *nc, int ev,
...
@@ -4791,19 +4791,32 @@ static void mg_websocket_handler(struct mg_connection *nc, int ev,
}
}
}
}
#ifndef MG_EXT_SHA1
static
void
mg_hash_sha1_v
(
size_t
num_msgs
,
const
uint8_t
*
msgs
[],
const
size_t
*
msg_lens
,
uint8_t
*
digest
)
{
size_t
i
;
cs_sha1_ctx
sha_ctx
;
cs_sha1_init
(
&
sha_ctx
);
for
(
i
=
0
;
i
<
num_msgs
;
i
++
)
{
cs_sha1_update
(
&
sha_ctx
,
msgs
[
i
],
msg_lens
[
i
]);
}
cs_sha1_final
(
digest
,
&
sha_ctx
);
}
#else
extern
void
mg_hash_sha1_v
(
size_t
num_msgs
,
const
uint8_t
*
msgs
[],
const
size_t
*
msg_lens
,
uint8_t
*
digest
);
#endif
static
void
mg_ws_handshake
(
struct
mg_connection
*
nc
,
static
void
mg_ws_handshake
(
struct
mg_connection
*
nc
,
const
struct
mg_str
*
key
)
{
const
struct
mg_str
*
key
)
{
static
const
char
*
magic
=
"258EAFA5-E914-47DA-95CA-C5AB0DC85B11"
;
static
const
char
*
magic
=
"258EAFA5-E914-47DA-95CA-C5AB0DC85B11"
;
char
buf
[
MG_VPRINTF_BUFFER_SIZE
],
sha
[
20
],
b64_sha
[
sizeof
(
sha
)
*
2
];
const
uint8_t
*
msgs
[
2
]
=
{(
const
uint8_t
*
)
key
->
p
,
(
const
uint8_t
*
)
magic
};
cs_sha1_ctx
sha_ctx
;
const
size_t
msg_lens
[
2
]
=
{
key
->
len
,
36
};
unsigned
char
sha
[
20
];
snprintf
(
buf
,
sizeof
(
buf
),
"%.*s%s"
,
(
int
)
key
->
len
,
key
->
p
,
magic
);
char
b64_sha
[
30
];
cs_sha1_init
(
&
sha_ctx
);
cs_sha1_update
(
&
sha_ctx
,
(
unsigned
char
*
)
buf
,
strlen
(
buf
));
cs_sha1_final
((
unsigned
char
*
)
sha
,
&
sha_ctx
);
mg_base64_encode
((
unsigned
char
*
)
sha
,
sizeof
(
sha
),
b64_sha
);
mg_hash_sha1_v
(
2
,
msgs
,
msg_lens
,
sha
);
mg_base64_encode
(
sha
,
sizeof
(
sha
),
b64_sha
);
mg_printf
(
nc
,
"%s%s%s"
,
mg_printf
(
nc
,
"%s%s%s"
,
"HTTP/1.1 101 Switching Protocols
\r\n
"
"HTTP/1.1 101 Switching Protocols
\r\n
"
"Upgrade: websocket
\r\n
"
"Upgrade: websocket
\r\n
"
...
...
This diff is collapsed.
Click to expand it.
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