Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
0af9a41a
Commit
0af9a41a
authored
Aug 02, 2011
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Factor HTTP/HTTPS/RTSP (bind) address in core
parent
e5c2a63d
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
54 additions
and
122 deletions
+54
-122
include/vlc_httpd.h
include/vlc_httpd.h
+3
-3
modules/access/dvb/http.c
modules/access/dvb/http.c
+3
-4
modules/access_output/http.c
modules/access_output/http.c
+8
-22
modules/lua/intf.c
modules/lua/intf.c
+0
-8
modules/lua/libs/httpd.c
modules/lua/libs/httpd.c
+2
-4
modules/lua/vlc.c
modules/lua/vlc.c
+0
-7
modules/misc/rtsp.c
modules/misc/rtsp.c
+9
-36
modules/stream_out/rtp.c
modules/stream_out/rtp.c
+1
-1
modules/stream_out/rtsp.c
modules/stream_out/rtsp.c
+2
-4
src/libvlc-module.c
src/libvlc-module.c
+9
-0
src/missing.c
src/missing.c
+6
-6
src/network/httpd.c
src/network/httpd.c
+11
-27
No files found.
include/vlc_httpd.h
View file @
0af9a41a
...
@@ -99,9 +99,9 @@ struct httpd_message_t
...
@@ -99,9 +99,9 @@ struct httpd_message_t
};
};
/* create a new host */
/* create a new host */
VLC_API
httpd_host_t
*
vlc_http_HostNew
(
vlc_object_t
*
,
const
char
*
psz_host
,
int
i_por
t
)
VLC_USED
;
VLC_API
httpd_host_t
*
vlc_http_HostNew
(
vlc_object_t
*
,
in
t
)
VLC_USED
;
VLC_API
httpd_host_t
*
vlc_https_HostNew
(
vlc_object_t
*
,
const
char
*
,
int
)
VLC_USED
;
VLC_API
httpd_host_t
*
vlc_https_HostNew
(
vlc_object_t
*
,
int
)
VLC_USED
;
VLC_API
httpd_host_t
*
vlc_rtsp_HostNew
(
vlc_object_t
*
,
const
char
*
,
int
)
VLC_USED
;
VLC_API
httpd_host_t
*
vlc_rtsp_HostNew
(
vlc_object_t
*
,
int
)
VLC_USED
;
/* delete a host */
/* delete a host */
VLC_API
void
httpd_HostDelete
(
httpd_host_t
*
);
VLC_API
void
httpd_HostDelete
(
httpd_host_t
*
);
...
...
modules/access/dvb/http.c
View file @
0af9a41a
...
@@ -94,13 +94,12 @@ int HTTPOpen( access_t *p_access )
...
@@ -94,13 +94,12 @@ int HTTPOpen( access_t *p_access )
sprintf
(
psz_tmp
,
":%d"
,
i_port
+
1
);
sprintf
(
psz_tmp
,
":%d"
,
i_port
+
1
);
config_PutPsz
(
p_access
,
"dvb-http-host"
,
psz_tmp
);
config_PutPsz
(
p_access
,
"dvb-http-host"
,
psz_tmp
);
msg_Dbg
(
p_access
,
"base %
s:%d"
,
psz_address
,
i_port
);
msg_Dbg
(
p_access
,
"base %
d"
,
i_port
);
p_sys
->
p_httpd_host
=
vlc_http_HostNew
(
VLC_OBJECT
(
p_access
),
psz_address
,
p_sys
->
p_httpd_host
=
vlc_http_HostNew
(
VLC_OBJECT
(
p_access
),
i_port
);
i_port
);
if
(
p_sys
->
p_httpd_host
==
NULL
)
if
(
p_sys
->
p_httpd_host
==
NULL
)
{
{
msg_Err
(
p_access
,
"cannot listen on
%s:%d"
,
psz_address
,
i_port
);
msg_Err
(
p_access
,
"cannot listen on
port %d"
,
i_port
);
free
(
psz_address
);
free
(
psz_address
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
...
...
modules/access_output/http.c
View file @
0af9a41a
...
@@ -149,7 +149,7 @@ static int Open( vlc_object_t *p_this )
...
@@ -149,7 +149,7 @@ static int Open( vlc_object_t *p_this )
config_ChainParse
(
p_access
,
SOUT_CFG_PREFIX
,
ppsz_sout_options
,
p_access
->
p_cfg
);
config_ChainParse
(
p_access
,
SOUT_CFG_PREFIX
,
ppsz_sout_options
,
p_access
->
p_cfg
);
/* p_access->psz_path = "
hostname
:port/filename" */
/* p_access->psz_path = ":port/filename" */
psz_bind_addr
=
strdup
(
p_access
->
psz_path
);
psz_bind_addr
=
strdup
(
p_access
->
psz_path
);
i_bind_port
=
0
;
i_bind_port
=
0
;
...
@@ -163,19 +163,6 @@ static int Open( vlc_object_t *p_this )
...
@@ -163,19 +163,6 @@ static int Open( vlc_object_t *p_this )
else
else
psz_file_name
=
strdup
(
"/"
);
psz_file_name
=
strdup
(
"/"
);
if
(
psz_bind_addr
[
0
]
==
'['
)
{
psz_bind_addr
++
;
psz_parser
=
strstr
(
psz_bind_addr
,
"]:"
);
if
(
psz_parser
)
{
*
psz_parser
=
'\0'
;
i_bind_port
=
atoi
(
psz_parser
+
2
);
}
psz_parser
=
psz_bind_addr
-
1
;
}
else
{
psz_parser
=
strrchr
(
psz_bind_addr
,
':'
);
psz_parser
=
strrchr
(
psz_bind_addr
,
':'
);
if
(
psz_parser
)
if
(
psz_parser
)
{
{
...
@@ -183,7 +170,6 @@ static int Open( vlc_object_t *p_this )
...
@@ -183,7 +170,6 @@ static int Open( vlc_object_t *p_this )
i_bind_port
=
atoi
(
psz_parser
+
1
);
i_bind_port
=
atoi
(
psz_parser
+
1
);
}
}
psz_parser
=
psz_bind_addr
;
psz_parser
=
psz_bind_addr
;
}
/* TLS support */
/* TLS support */
if
(
p_access
->
psz_access
&&
!
strcmp
(
p_access
->
psz_access
,
"https"
)
)
if
(
p_access
->
psz_access
&&
!
strcmp
(
p_access
->
psz_access
,
"https"
)
)
...
@@ -191,14 +177,14 @@ static int Open( vlc_object_t *p_this )
...
@@ -191,14 +177,14 @@ static int Open( vlc_object_t *p_this )
if
(
i_bind_port
<=
0
)
if
(
i_bind_port
<=
0
)
i_bind_port
=
DEFAULT_SSL_PORT
;
i_bind_port
=
DEFAULT_SSL_PORT
;
p_sys
->
p_httpd_host
=
vlc_https_HostNew
(
VLC_OBJECT
(
p_access
),
p_sys
->
p_httpd_host
=
vlc_https_HostNew
(
VLC_OBJECT
(
p_access
),
psz_bind_addr
,
i_bind_port
);
i_bind_port
);
}
}
else
else
{
{
if
(
i_bind_port
<=
0
)
if
(
i_bind_port
<=
0
)
i_bind_port
=
DEFAULT_PORT
;
i_bind_port
=
DEFAULT_PORT
;
p_sys
->
p_httpd_host
=
vlc_http_HostNew
(
VLC_OBJECT
(
p_access
),
p_sys
->
p_httpd_host
=
vlc_http_HostNew
(
VLC_OBJECT
(
p_access
),
psz_bind_addr
,
i_bind_port
);
i_bind_port
);
}
}
if
(
p_sys
->
p_httpd_host
==
NULL
)
if
(
p_sys
->
p_httpd_host
==
NULL
)
...
...
modules/lua/intf.c
View file @
0af9a41a
...
@@ -203,16 +203,8 @@ static int Start_LuaIntf( vlc_object_t *p_this, const char *name )
...
@@ -203,16 +203,8 @@ static int Start_LuaIntf( vlc_object_t *p_this, const char *name )
{
{
if
(
!
strcmp
(
name
,
"http"
)
)
if
(
!
strcmp
(
name
,
"http"
)
)
{
{
char
*
psz_http_host
=
var_CreateGetNonEmptyString
(
p_intf
,
"http-host"
);
char
*
psz_http_src
=
var_CreateGetNonEmptyString
(
p_intf
,
"http-src"
);
char
*
psz_http_src
=
var_CreateGetNonEmptyString
(
p_intf
,
"http-src"
);
bool
b_http_index
=
var_CreateGetBool
(
p_intf
,
"http-index"
);
bool
b_http_index
=
var_CreateGetBool
(
p_intf
,
"http-index"
);
if
(
psz_http_host
)
{
char
*
psz_esc
=
config_StringEscape
(
psz_http_host
);
asprintf
(
&
psz_config
,
"http={host='%s'"
,
psz_esc
);
free
(
psz_esc
);
free
(
psz_http_host
);
}
if
(
psz_http_src
)
if
(
psz_http_src
)
{
{
char
*
psz_esc
=
config_StringEscape
(
psz_http_src
);
char
*
psz_esc
=
config_StringEscape
(
psz_http_src
);
...
...
modules/lua/libs/httpd.c
View file @
0af9a41a
...
@@ -68,12 +68,10 @@ static const luaL_Reg vlclua_httpd_reg[] = {
...
@@ -68,12 +68,10 @@ static const luaL_Reg vlclua_httpd_reg[] = {
static
int
vlclua_httpd_tls_host_new
(
lua_State
*
L
)
static
int
vlclua_httpd_tls_host_new
(
lua_State
*
L
)
{
{
vlc_object_t
*
p_this
=
vlclua_get_this
(
L
);
vlc_object_t
*
p_this
=
vlclua_get_this
(
L
);
const
char
*
psz_host
=
luaL_checkstring
(
L
,
1
);
int
i_port
=
luaL_checkint
(
L
,
2
);
int
i_port
=
luaL_checkint
(
L
,
2
);
httpd_host_t
*
p_host
=
vlc_http_HostNew
(
p_this
,
psz_host
,
i_port
);
httpd_host_t
*
p_host
=
vlc_http_HostNew
(
p_this
,
i_port
);
if
(
!
p_host
)
if
(
!
p_host
)
return
luaL_error
(
L
,
"Failed to create HTTP host
\"
%s:%d
\"
"
,
return
luaL_error
(
L
,
"Failed to create HTTP port %d
\"
"
,
i_port
);
psz_host
,
i_port
);
httpd_host_t
**
pp_host
=
lua_newuserdata
(
L
,
sizeof
(
httpd_host_t
*
)
);
httpd_host_t
**
pp_host
=
lua_newuserdata
(
L
,
sizeof
(
httpd_host_t
*
)
);
*
pp_host
=
p_host
;
*
pp_host
=
p_host
;
...
...
modules/lua/vlc.c
View file @
0af9a41a
...
@@ -59,12 +59,6 @@
...
@@ -59,12 +59,6 @@
#define CONFIG_TEXT N_("Lua interface configuration")
#define CONFIG_TEXT N_("Lua interface configuration")
#define CONFIG_LONGTEXT N_("Lua interface configuration string. Format is: '[\"<interface module name>\"] = { <option> = <value>, ...}, ...'.")
#define CONFIG_LONGTEXT N_("Lua interface configuration string. Format is: '[\"<interface module name>\"] = { <option> = <value>, ...}, ...'.")
#define HOST_TEXT N_( "Host address" )
#define HOST_LONGTEXT N_( \
"Address and port the HTTP interface will listen on. It defaults to " \
"all network interfaces (0.0.0.0)." \
" If you want the HTTP interface to be available only on the local " \
"machine, enter 127.0.0.1" )
#define SRC_TEXT N_( "Source directory" )
#define SRC_TEXT N_( "Source directory" )
#define SRC_LONGTEXT N_( "Source directory" )
#define SRC_LONGTEXT N_( "Source directory" )
#define INDEX_TEXT N_( "Directory index" )
#define INDEX_TEXT N_( "Directory index" )
...
@@ -108,7 +102,6 @@ vlc_module_begin ()
...
@@ -108,7 +102,6 @@ vlc_module_begin ()
add_submodule
()
add_submodule
()
set_section
(
N_
(
"Lua HTTP"
),
0
)
set_section
(
N_
(
"Lua HTTP"
),
0
)
add_string
(
"http-host"
,
NULL
,
HOST_TEXT
,
HOST_LONGTEXT
,
true
)
add_string
(
"http-src"
,
NULL
,
SRC_TEXT
,
SRC_LONGTEXT
,
true
)
add_string
(
"http-src"
,
NULL
,
SRC_TEXT
,
SRC_LONGTEXT
,
true
)
add_bool
(
"http-index"
,
false
,
INDEX_TEXT
,
INDEX_LONGTEXT
,
true
)
add_bool
(
"http-index"
,
false
,
INDEX_TEXT
,
INDEX_LONGTEXT
,
true
)
set_capability
(
"interface"
,
0
)
set_capability
(
"interface"
,
0
)
...
...
modules/misc/rtsp.c
View file @
0af9a41a
...
@@ -58,13 +58,6 @@
...
@@ -58,13 +58,6 @@
static
int
Open
(
vlc_object_t
*
);
static
int
Open
(
vlc_object_t
*
);
static
void
Close
(
vlc_object_t
*
);
static
void
Close
(
vlc_object_t
*
);
#define HOST_TEXT N_( "RTSP host address" )
#define HOST_LONGTEXT N_( \
"This defines the address, port and path the RTSP VOD server will listen " \
"on.\nSyntax is address:port/path. The default is to listen on all "\
"interfaces (address 0.0.0.0), on port 554, with no path.\nTo listen " \
"only on the local interface, use \"localhost\" as address." )
#define THROTTLE_TEXT N_( "Maximum number of connections" )
#define THROTTLE_TEXT N_( "Maximum number of connections" )
#define THROTTLE_LONGTEXT N_( "This limits the maximum number of clients " \
#define THROTTLE_LONGTEXT N_( "This limits the maximum number of clients " \
"that can connect to the RTSP VOD. 0 means no limit." )
"that can connect to the RTSP VOD. 0 means no limit." )
...
@@ -86,7 +79,6 @@ vlc_module_begin ()
...
@@ -86,7 +79,6 @@ vlc_module_begin ()
set_capability
(
"vod server"
,
1
)
set_capability
(
"vod server"
,
1
)
set_callbacks
(
Open
,
Close
)
set_callbacks
(
Open
,
Close
)
add_shortcut
(
"rtsp"
)
add_shortcut
(
"rtsp"
)
add_string
(
"rtsp-host"
,
NULL
,
HOST_TEXT
,
HOST_LONGTEXT
,
true
)
add_string
(
"rtsp-raw-mux"
,
"ts"
,
RAWMUX_TEXT
,
add_string
(
"rtsp-raw-mux"
,
"ts"
,
RAWMUX_TEXT
,
RAWMUX_TEXT
,
true
)
RAWMUX_TEXT
,
true
)
add_integer
(
"rtsp-throttle-users"
,
0
,
THROTTLE_TEXT
,
add_integer
(
"rtsp-throttle-users"
,
0
,
THROTTLE_TEXT
,
...
@@ -172,7 +164,6 @@ struct vod_sys_t
...
@@ -172,7 +164,6 @@ struct vod_sys_t
{
{
/* RTSP server */
/* RTSP server */
httpd_host_t
*
p_rtsp_host
;
httpd_host_t
*
p_rtsp_host
;
char
*
psz_path
;
int
i_port
;
int
i_port
;
int
i_throttle_users
;
int
i_throttle_users
;
int
i_connections
;
int
i_connections
;
...
@@ -260,14 +251,6 @@ static int Open( vlc_object_t *p_this )
...
@@ -260,14 +251,6 @@ static int Open( vlc_object_t *p_this )
{
{
vod_t
*
p_vod
=
(
vod_t
*
)
p_this
;
vod_t
*
p_vod
=
(
vod_t
*
)
p_this
;
vod_sys_t
*
p_sys
=
NULL
;
vod_sys_t
*
p_sys
=
NULL
;
char
*
psz_url
=
NULL
;
vlc_url_t
url
;
psz_url
=
var_InheritString
(
p_vod
,
"rtsp-host"
);
vlc_UrlParse
(
&
url
,
psz_url
,
0
);
free
(
psz_url
);
if
(
url
.
i_port
<=
0
)
url
.
i_port
=
554
;
p_vod
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
vod_sys_t
)
);
p_vod
->
p_sys
=
p_sys
=
malloc
(
sizeof
(
vod_sys_t
)
);
if
(
!
p_sys
)
goto
error
;
if
(
!
p_sys
)
goto
error
;
...
@@ -281,19 +264,14 @@ static int Open( vlc_object_t *p_this )
...
@@ -281,19 +264,14 @@ static int Open( vlc_object_t *p_this )
p_sys
->
psz_raw_mux
=
var_CreateGetString
(
p_this
,
"rtsp-raw-mux"
);
p_sys
->
psz_raw_mux
=
var_CreateGetString
(
p_this
,
"rtsp-raw-mux"
);
p_sys
->
p_rtsp_host
=
p_sys
->
p_rtsp_host
=
vlc_rtsp_HostNew
(
VLC_OBJECT
(
p_vod
),
554
);
vlc_rtsp_HostNew
(
VLC_OBJECT
(
p_vod
),
url
.
psz_host
,
url
.
i_port
);
if
(
!
p_sys
->
p_rtsp_host
)
if
(
!
p_sys
->
p_rtsp_host
)
{
{
msg_Err
(
p_vod
,
"cannot create RTSP server (%s:%i)"
,
msg_Err
(
p_vod
,
"cannot create RTSP server"
);
url
.
psz_host
,
url
.
i_port
);
goto
error
;
goto
error
;
}
}
p_sys
->
psz_path
=
strdup
(
url
.
psz_path
?
url
.
psz_path
:
"/"
);
p_sys
->
i_port
=
554
;
p_sys
->
i_port
=
url
.
i_port
;
vlc_UrlClean
(
&
url
);
TAB_INIT
(
p_sys
->
i_media
,
p_sys
->
media
);
TAB_INIT
(
p_sys
->
i_media
,
p_sys
->
media
);
p_sys
->
i_media_id
=
0
;
p_sys
->
i_media_id
=
0
;
...
@@ -306,7 +284,6 @@ static int Open( vlc_object_t *p_this )
...
@@ -306,7 +284,6 @@ static int Open( vlc_object_t *p_this )
{
{
msg_Err
(
p_vod
,
"cannot spawn rtsp vod thread"
);
msg_Err
(
p_vod
,
"cannot spawn rtsp vod thread"
);
block_FifoRelease
(
p_sys
->
p_fifo_cmd
);
block_FifoRelease
(
p_sys
->
p_fifo_cmd
);
free
(
p_sys
->
psz_path
);
goto
error
;
goto
error
;
}
}
...
@@ -319,8 +296,6 @@ error:
...
@@ -319,8 +296,6 @@ error:
free
(
p_sys
->
psz_raw_mux
);
free
(
p_sys
->
psz_raw_mux
);
free
(
p_sys
);
free
(
p_sys
);
}
}
vlc_UrlClean
(
&
url
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
...
@@ -359,7 +334,6 @@ static void Close( vlc_object_t * p_this )
...
@@ -359,7 +334,6 @@ static void Close( vlc_object_t * p_this )
msg_Err
(
p_vod
,
"rtsp vod leaking %d medias"
,
p_sys
->
i_media
);
msg_Err
(
p_vod
,
"rtsp vod leaking %d medias"
,
p_sys
->
i_media
);
TAB_CLEAN
(
p_sys
->
i_media
,
p_sys
->
media
);
TAB_CLEAN
(
p_sys
->
i_media
,
p_sys
->
media
);
free
(
p_sys
->
psz_path
);
free
(
p_sys
->
psz_raw_mux
);
free
(
p_sys
->
psz_raw_mux
);
free
(
p_sys
);
free
(
p_sys
);
}
}
...
@@ -382,16 +356,15 @@ static vod_media_t *MediaNew( vod_t *p_vod, const char *psz_name,
...
@@ -382,16 +356,15 @@ static vod_media_t *MediaNew( vod_t *p_vod, const char *psz_name,
TAB_INIT
(
p_media
->
i_rtsp
,
p_media
->
rtsp
);
TAB_INIT
(
p_media
->
i_rtsp
,
p_media
->
rtsp
);
p_media
->
b_raw
=
false
;
p_media
->
b_raw
=
false
;
if
(
asprintf
(
&
p_media
->
psz_rtsp_path
,
"%s%s"
,
p_media
->
psz_rtsp_path
=
strdup
(
psz_name
);
p_sys
->
psz_path
,
psz_name
)
<
0
)
return
NULL
;
p_media
->
p_rtsp_url
=
p_media
->
p_rtsp_url
=
httpd_UrlNewUnique
(
p_sys
->
p_rtsp_host
,
p_media
->
psz_rtsp_path
,
NULL
,
httpd_UrlNewUnique
(
p_sys
->
p_rtsp_host
,
psz_name
,
NULL
,
NULL
,
NULL
);
NULL
,
NULL
);
if
(
!
p_media
->
p_rtsp_url
)
if
(
!
p_media
->
p
sz_rtsp_path
||
!
p_media
->
p
_rtsp_url
)
{
{
msg_Err
(
p_vod
,
"cannot create RTSP url (%s)"
,
p_media
->
psz_rtsp_path
);
msg_Err
(
p_vod
,
"cannot create RTSP url (%s)"
,
psz_name
);
if
(
p_media
->
p_rtsp_url
)
httpd_UrlDelete
(
p_media
->
p_rtsp_url
);
free
(
p_media
->
psz_rtsp_path
);
free
(
p_media
->
psz_rtsp_path
);
free
(
p_media
);
free
(
p_media
);
return
NULL
;
return
NULL
;
...
...
modules/stream_out/rtp.c
View file @
0af9a41a
...
@@ -1320,7 +1320,7 @@ static int HttpSetup( sout_stream_t *p_stream, const vlc_url_t *url)
...
@@ -1320,7 +1320,7 @@ static int HttpSetup( sout_stream_t *p_stream, const vlc_url_t *url)
{
{
sout_stream_sys_t
*
p_sys
=
p_stream
->
p_sys
;
sout_stream_sys_t
*
p_sys
=
p_stream
->
p_sys
;
p_sys
->
p_httpd_host
=
vlc_http_HostNew
(
VLC_OBJECT
(
p_stream
),
url
->
psz_host
,
p_sys
->
p_httpd_host
=
vlc_http_HostNew
(
VLC_OBJECT
(
p_stream
),
url
->
i_port
>
0
?
url
->
i_port
:
80
);
url
->
i_port
>
0
?
url
->
i_port
:
80
);
if
(
p_sys
->
p_httpd_host
)
if
(
p_sys
->
p_httpd_host
)
{
{
...
...
modules/stream_out/rtsp.c
View file @
0af9a41a
...
@@ -117,11 +117,9 @@ rtsp_stream_t *RtspSetup( vlc_object_t *owner, vod_media_t *media,
...
@@ -117,11 +117,9 @@ rtsp_stream_t *RtspSetup( vlc_object_t *owner, vod_media_t *media,
if
(
rtsp
->
psz_path
==
NULL
)
if
(
rtsp
->
psz_path
==
NULL
)
goto
error
;
goto
error
;
msg_Dbg
(
owner
,
"RTSP stream: host %s port %d at %s"
,
msg_Dbg
(
owner
,
"RTSP stream: port %d at %s"
,
rtsp
->
port
,
rtsp
->
psz_path
);
url
->
psz_host
,
rtsp
->
port
,
rtsp
->
psz_path
);
rtsp
->
host
=
vlc_rtsp_HostNew
(
VLC_OBJECT
(
owner
),
url
->
psz_host
,
rtsp
->
host
=
vlc_rtsp_HostNew
(
VLC_OBJECT
(
owner
),
rtsp
->
port
);
rtsp
->
port
);
if
(
rtsp
->
host
==
NULL
)
if
(
rtsp
->
host
==
NULL
)
goto
error
;
goto
error
;
...
...
src/libvlc-module.c
View file @
0af9a41a
...
@@ -889,6 +889,13 @@ static const char *const ppsz_clock_descriptions[] =
...
@@ -889,6 +889,13 @@ static const char *const ppsz_clock_descriptions[] =
#define TIMEOUT_LONGTEXT N_( \
#define TIMEOUT_LONGTEXT N_( \
"Default TCP connection timeout (in milliseconds). " )
"Default TCP connection timeout (in milliseconds). " )
#define HTTP_HOST_TEXT N_( "HTTP server address" )
#define RTSP_HOST_TEXT N_( "RTSP server address" )
#define HOST_LONGTEXT N_( \
"By default, the server will listen on any local IP address. " \
"Specify an IP address (e.g. ::1 or 127.0.0.1) or a host name " \
"(e.g. localhost) to restrict them to a specific network interface." )
#define HTTP_CERT_TEXT N_("HTTP/TLS server certificate")
#define HTTP_CERT_TEXT N_("HTTP/TLS server certificate")
#define CERT_LONGTEXT N_( \
#define CERT_LONGTEXT N_( \
"This X.509 certicate file (PEM format) is used for server-side TLS." )
"This X.509 certicate file (PEM format) is used for server-side TLS." )
...
@@ -1899,6 +1906,8 @@ vlc_module_begin ()
...
@@ -1899,6 +1906,8 @@ vlc_module_begin ()
add_integer
(
"ipv4-timeout"
,
5
*
1000
,
TIMEOUT_TEXT
,
add_integer
(
"ipv4-timeout"
,
5
*
1000
,
TIMEOUT_TEXT
,
TIMEOUT_LONGTEXT
,
true
)
TIMEOUT_LONGTEXT
,
true
)
add_string
(
"http-host"
,
NULL
,
HTTP_HOST_TEXT
,
HOST_LONGTEXT
,
true
)
add_string
(
"rtsp-host"
,
NULL
,
RTSP_HOST_TEXT
,
HOST_LONGTEXT
,
true
)
add_loadfile
(
"http-cert"
,
NULL
,
HTTP_CERT_TEXT
,
CERT_LONGTEXT
,
true
)
add_loadfile
(
"http-cert"
,
NULL
,
HTTP_CERT_TEXT
,
CERT_LONGTEXT
,
true
)
add_deprecated_alias
(
"sout-http-cert"
)
/* since 1.2.0 */
add_deprecated_alias
(
"sout-http-cert"
)
/* since 1.2.0 */
add_loadfile
(
"http-key"
,
NULL
,
HTTP_KEY_TEXT
,
KEY_LONGTEXT
,
true
)
add_loadfile
(
"http-key"
,
NULL
,
HTTP_KEY_TEXT
,
KEY_LONGTEXT
,
true
)
...
...
src/missing.c
View file @
0af9a41a
...
@@ -93,21 +93,21 @@ void httpd_HostDelete (httpd_host_t *h)
...
@@ -93,21 +93,21 @@ void httpd_HostDelete (httpd_host_t *h)
assert
(
0
);
assert
(
0
);
}
}
httpd_host_t
*
vlc_http_HostNew
(
vlc_object_t
*
obj
,
const
char
*
host
,
int
port
)
httpd_host_t
*
vlc_http_HostNew
(
vlc_object_t
*
obj
,
int
port
)
{
{
(
void
)
host
;
(
void
)
port
;
(
void
)
port
;
msg_Err
(
obj
,
"HTTP server not compiled-in!"
);
msg_Err
(
obj
,
"HTTP server not compiled-in!"
);
return
NULL
;
return
NULL
;
}
}
httpd_host_t
*
vlc_https_HostNew
(
vlc_object_t
*
obj
,
const
char
*
host
,
int
port
)
httpd_host_t
*
vlc_https_HostNew
(
vlc_object_t
*
obj
,
int
port
)
{
{
return
httpd_HostNew
(
obj
,
host
,
port
);
return
httpd_HostNew
(
obj
,
port
);
}
}
httpd_host_t
*
vlc_rtsp_HostNew
(
vlc_object_t
*
obj
,
const
char
*
host
,
int
port
)
httpd_host_t
*
vlc_rtsp_HostNew
(
vlc_object_t
*
obj
,
int
port
)
{
{
(
void
)
host
;
(
void
)
port
;
(
void
)
port
;
msg_Err
(
obj
,
"RTSP server not compiled-in!"
);
msg_Err
(
obj
,
"RTSP server not compiled-in!"
);
return
NULL
;
return
NULL
;
}
}
...
...
src/network/httpd.c
View file @
0af9a41a
...
@@ -88,7 +88,6 @@ struct httpd_host_t
...
@@ -88,7 +88,6 @@ struct httpd_host_t
unsigned
i_ref
;
unsigned
i_ref
;
/* address/port and socket for listening at connections */
/* address/port and socket for listening at connections */
char
*
psz_hostname
;
int
i_port
;
int
i_port
;
int
*
fds
;
int
*
fds
;
unsigned
nfd
;
unsigned
nfd
;
...
@@ -968,13 +967,12 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *, const char *, int,
...
@@ -968,13 +967,12 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *, const char *, int,
vlc_tls_creds_t
*
);
vlc_tls_creds_t
*
);
/* create a new host */
/* create a new host */
httpd_host_t
*
vlc_http_HostNew
(
vlc_object_t
*
p_this
,
const
char
*
psz_host
,
httpd_host_t
*
vlc_http_HostNew
(
vlc_object_t
*
p_this
,
int
i_port
)
int
i_port
)
{
{
return
httpd_HostCreate
(
p_this
,
psz_host
,
i_port
,
NULL
);
return
httpd_HostCreate
(
p_this
,
"http-host"
,
i_port
,
NULL
);
}
}
httpd_host_t
*
vlc_https_HostNew
(
vlc_object_t
*
obj
,
const
char
*
host
,
int
port
)
httpd_host_t
*
vlc_https_HostNew
(
vlc_object_t
*
obj
,
int
port
)
{
{
char
*
cert
=
var_InheritString
(
obj
,
"http-cert"
);
char
*
cert
=
var_InheritString
(
obj
,
"http-cert"
);
if
(
cert
==
NULL
)
if
(
cert
==
NULL
)
...
@@ -1021,37 +1019,28 @@ httpd_host_t *vlc_https_HostNew( vlc_object_t *obj, const char *host, int port )
...
@@ -1021,37 +1019,28 @@ httpd_host_t *vlc_https_HostNew( vlc_object_t *obj, const char *host, int port )
free
(
crl
);
free
(
crl
);
}
}
return
httpd_HostCreate
(
obj
,
host
,
port
,
tls
);
return
httpd_HostCreate
(
obj
,
"http-host"
,
port
,
tls
);
error:
error:
vlc_tls_ServerDelete
(
tls
);
vlc_tls_ServerDelete
(
tls
);
return
NULL
;
return
NULL
;
}
}
httpd_host_t
*
vlc_rtsp_HostNew
(
vlc_object_t
*
p_this
,
const
char
*
psz_host
,
httpd_host_t
*
vlc_rtsp_HostNew
(
vlc_object_t
*
p_this
,
int
i_port
)
int
i_port
)
{
{
return
httpd_HostCreate
(
p_this
,
psz_host
,
i_port
,
NULL
);
return
httpd_HostCreate
(
p_this
,
"rtsp-host"
,
i_port
,
NULL
);
}
}
static
vlc_mutex_t
httpd_mutex
=
VLC_STATIC_MUTEX
;
static
vlc_mutex_t
httpd_mutex
=
VLC_STATIC_MUTEX
;
static
httpd_host_t
*
httpd_HostCreate
(
vlc_object_t
*
p_this
,
static
httpd_host_t
*
httpd_HostCreate
(
vlc_object_t
*
p_this
,
const
char
*
psz_hostname
,
int
i_port
,
const
char
*
hostvar
,
int
i_port
,
vlc_tls_creds_t
*
p_tls
)
vlc_tls_creds_t
*
p_tls
)
{
{
httpd_t
*
httpd
;
httpd_t
*
httpd
;
httpd_host_t
*
host
;
httpd_host_t
*
host
;
char
*
psz_host
;
int
i
;
int
i
;
if
(
psz_hostname
==
NULL
)
psz_hostname
=
""
;
psz_host
=
strdup
(
psz_hostname
);
if
(
psz_host
==
NULL
)
return
NULL
;
/* to be sure to avoid multiple creation */
/* to be sure to avoid multiple creation */
vlc_mutex_lock
(
&
httpd_mutex
);
vlc_mutex_lock
(
&
httpd_mutex
);
httpd
=
libvlc_priv
(
p_this
->
p_libvlc
)
->
p_httpd
;
httpd
=
libvlc_priv
(
p_this
->
p_libvlc
)
->
p_httpd
;
...
@@ -1064,7 +1053,6 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
...
@@ -1064,7 +1053,6 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
if
(
httpd
==
NULL
)
if
(
httpd
==
NULL
)
{
{
vlc_mutex_unlock
(
&
httpd_mutex
);
vlc_mutex_unlock
(
&
httpd_mutex
);
free
(
psz_host
);
return
NULL
;
return
NULL
;
}
}
...
@@ -1081,8 +1069,7 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
...
@@ -1081,8 +1069,7 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
/* cannot mix TLS and non-TLS hosts */
/* cannot mix TLS and non-TLS hosts */
if
(
(
(
httpd
->
host
[
i
]
->
p_tls
!=
NULL
)
!=
(
p_tls
!=
NULL
)
)
if
(
(
(
httpd
->
host
[
i
]
->
p_tls
!=
NULL
)
!=
(
p_tls
!=
NULL
)
)
||
(
host
->
i_port
!=
i_port
)
||
(
host
->
i_port
!=
i_port
)
)
||
strcmp
(
host
->
psz_hostname
,
psz_hostname
)
)
continue
;
continue
;
/* Increase existing matching host reference count.
/* Increase existing matching host reference count.
...
@@ -1112,7 +1099,9 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
...
@@ -1112,7 +1099,9 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
vlc_cond_init
(
&
host
->
wait
);
vlc_cond_init
(
&
host
->
wait
);
host
->
i_ref
=
1
;
host
->
i_ref
=
1
;
host
->
fds
=
net_ListenTCP
(
p_this
,
psz_host
,
i_port
);
char
*
hostname
=
var_InheritString
(
p_this
->
p_libvlc
,
hostvar
);
host
->
fds
=
net_ListenTCP
(
p_this
,
hostname
,
i_port
);
free
(
hostname
);
if
(
host
->
fds
==
NULL
)
if
(
host
->
fds
==
NULL
)
{
{
msg_Err
(
p_this
,
"cannot create socket(s) for HTTP host"
);
msg_Err
(
p_this
,
"cannot create socket(s) for HTTP host"
);
...
@@ -1127,8 +1116,6 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
...
@@ -1127,8 +1116,6 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
}
}
host
->
i_port
=
i_port
;
host
->
i_port
=
i_port
;
host
->
psz_hostname
=
psz_host
;
host
->
i_url
=
0
;
host
->
i_url
=
0
;
host
->
url
=
NULL
;
host
->
url
=
NULL
;
host
->
i_client
=
0
;
host
->
i_client
=
0
;
...
@@ -1151,7 +1138,6 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
...
@@ -1151,7 +1138,6 @@ static httpd_host_t *httpd_HostCreate( vlc_object_t *p_this,
return
host
;
return
host
;
error:
error:
free
(
psz_host
);
if
(
httpd
->
i_host
<=
0
)
if
(
httpd
->
i_host
<=
0
)
{
{
libvlc_priv
(
httpd
->
p_libvlc
)
->
p_httpd
=
NULL
;
libvlc_priv
(
httpd
->
p_libvlc
)
->
p_httpd
=
NULL
;
...
@@ -1223,8 +1209,6 @@ void httpd_HostDelete( httpd_host_t *host )
...
@@ -1223,8 +1209,6 @@ void httpd_HostDelete( httpd_host_t *host )
vlc_tls_ServerDelete
(
host
->
p_tls
);
vlc_tls_ServerDelete
(
host
->
p_tls
);
net_ListenClose
(
host
->
fds
);
net_ListenClose
(
host
->
fds
);
free
(
host
->
psz_hostname
);
vlc_cond_destroy
(
&
host
->
wait
);
vlc_cond_destroy
(
&
host
->
wait
);
vlc_mutex_destroy
(
&
host
->
lock
);
vlc_mutex_destroy
(
&
host
->
lock
);
vlc_object_release
(
host
);
vlc_object_release
(
host
);
...
...
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