Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
3fb69dd7
Commit
3fb69dd7
authored
Feb 16, 2014
by
Rafaël Carré
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
httpd: split user auth
parent
153dd617
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
51 additions
and
32 deletions
+51
-32
src/network/httpd.c
src/network/httpd.c
+51
-32
No files found.
src/network/httpd.c
View file @
3fb69dd7
...
@@ -1915,6 +1915,46 @@ static void httpd_ClientTlsHandshake( httpd_client_t *cl )
...
@@ -1915,6 +1915,46 @@ static void httpd_ClientTlsHandshake( httpd_client_t *cl )
}
}
}
}
static
bool
httpdAuthOk
(
const
char
*
b64
,
const
char
*
user
,
const
char
*
pass
)
{
if
(
!*
user
&&
!*
pass
)
return
true
;
if
(
!
b64
)
return
false
;
if
(
strncasecmp
(
b64
,
"BASIC"
,
5
))
return
false
;
b64
+=
5
;
while
(
*
b64
==
' '
)
b64
++
;
char
*
given_user
=
vlc_b64_decode
(
b64
);
if
(
!
given_user
)
return
false
;
char
*
given_pass
=
NULL
;
given_pass
=
strchr
(
given_user
,
':'
);
if
(
!
given_pass
)
goto
auth_failed
;
*
given_pass
++
=
'\0'
;
if
(
strcmp
(
given_user
,
user
))
goto
auth_failed
;
if
(
strcmp
(
given_pass
,
pass
))
goto
auth_failed
;
free
(
given_user
);
return
true
;
auth_failed:
free
(
given_user
);
return
false
;
}
static
void
httpdLoop
(
httpd_host_t
*
host
)
static
void
httpdLoop
(
httpd_host_t
*
host
)
{
{
struct
pollfd
ufd
[
host
->
nfd
+
host
->
i_client
];
struct
pollfd
ufd
[
host
->
nfd
+
host
->
i_client
];
...
@@ -2031,8 +2071,7 @@ static void httpdLoop(httpd_host_t *host)
...
@@ -2031,8 +2071,7 @@ static void httpdLoop(httpd_host_t *host)
if
(
query
->
i_proto
==
HTTPD_PROTO_NONE
)
{
if
(
query
->
i_proto
==
HTTPD_PROTO_NONE
)
{
cl
->
url
=
NULL
;
cl
->
url
=
NULL
;
cl
->
i_state
=
HTTPD_CLIENT_DEAD
;
cl
->
i_state
=
HTTPD_CLIENT_DEAD
;
}
}
else
{
else
{
/* unimplemented */
/* unimplemented */
answer
->
i_proto
=
query
->
i_proto
;
answer
->
i_proto
=
query
->
i_proto
;
answer
->
i_type
=
HTTPD_MSG_ANSWER
;
answer
->
i_type
=
HTTPD_MSG_ANSWER
;
...
@@ -2062,34 +2101,12 @@ static void httpdLoop(httpd_host_t *host)
...
@@ -2062,34 +2101,12 @@ static void httpdLoop(httpd_host_t *host)
if
(
!
url
->
catch
[
i_msg
].
cb
)
if
(
!
url
->
catch
[
i_msg
].
cb
)
continue
;
continue
;
if
(
answer
&&
(
*
url
->
psz_user
||
*
url
->
psz_password
))
{
if
(
answer
)
{
/* create the headers */
b_auth_failed
=
!
httpdAuthOk
(
url
->
psz_user
,
const
char
*
b64
=
httpd_MsgGet
(
query
,
"Authorization"
);
/* BASIC id */
url
->
psz_password
,
char
*
user
=
NULL
,
*
pass
=
NULL
;
httpd_MsgGet
(
query
,
"Authorization"
));
/* BASIC id */
if
(
b_auth_failed
)
if
(
b64
&&
!
strncasecmp
(
b64
,
"BASIC"
,
5
))
{
break
;
b64
+=
5
;
while
(
*
b64
==
' '
)
b64
++
;
user
=
vlc_b64_decode
(
b64
);
if
(
user
)
{
pass
=
strchr
(
user
,
':'
);
if
(
pass
)
*
pass
++
=
'\0'
;
}
}
if
(
!
user
||
strcmp
(
user
,
url
->
psz_user
)
||
!
pass
||
strcmp
(
pass
,
url
->
psz_password
))
{
httpd_MsgAdd
(
answer
,
"WWW-Authenticate"
,
"Basic realm=
\"
VLC stream
\"
"
);
b_auth_failed
=
true
;
/* We fail for all url */
free
(
user
);
break
;
}
free
(
user
);
}
}
if
(
url
->
catch
[
i_msg
].
cb
(
url
->
catch
[
i_msg
].
p_sys
,
cl
,
answer
,
query
))
if
(
url
->
catch
[
i_msg
].
cb
(
url
->
catch
[
i_msg
].
p_sys
,
cl
,
answer
,
query
))
...
@@ -2111,9 +2128,11 @@ static void httpdLoop(httpd_host_t *host)
...
@@ -2111,9 +2128,11 @@ static void httpdLoop(httpd_host_t *host)
answer
->
i_type
=
HTTPD_MSG_ANSWER
;
answer
->
i_type
=
HTTPD_MSG_ANSWER
;
answer
->
i_version
=
0
;
answer
->
i_version
=
0
;
if
(
b_auth_failed
)
if
(
b_auth_failed
)
{
httpd_MsgAdd
(
answer
,
"WWW-Authenticate"
,
"Basic realm=
\"
VLC stream
\"
"
);
answer
->
i_status
=
401
;
answer
->
i_status
=
401
;
else
}
else
answer
->
i_status
=
404
;
/* no url registered */
answer
->
i_status
=
404
;
/* no url registered */
char
*
p
;
char
*
p
;
...
...
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