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
48476f03
Commit
48476f03
authored
May 09, 2015
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ftp: use TLS I/O helpers
parent
c1ded5e3
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
30 additions
and
16 deletions
+30
-16
modules/access/ftp.c
modules/access/ftp.c
+30
-16
No files found.
modules/access/ftp.c
View file @
48476f03
...
@@ -137,7 +137,6 @@ struct access_sys_t
...
@@ -137,7 +137,6 @@ struct access_sys_t
struct
struct
{
{
vlc_tls_t
*
p_tls
;
vlc_tls_t
*
p_tls
;
v_socket_t
*
p_vs
;
int
fd
;
int
fd
;
}
cmd
,
data
;
}
cmd
,
data
;
...
@@ -168,7 +167,9 @@ static int ftp_SendCommand( vlc_object_t *obj, access_sys_t *sys,
...
@@ -168,7 +167,9 @@ static int ftp_SendCommand( vlc_object_t *obj, access_sys_t *sys,
return
-
1
;
return
-
1
;
msg_Dbg
(
obj
,
"sending request:
\"
%.*s
\"
(%d bytes)"
,
val
-
2
,
cmd
,
val
);
msg_Dbg
(
obj
,
"sending request:
\"
%.*s
\"
(%d bytes)"
,
val
-
2
,
cmd
,
val
);
if
(
net_Write
(
obj
,
sys
->
cmd
.
fd
,
sys
->
cmd
.
p_vs
,
cmd
,
val
)
!=
val
)
if
(
((
sys
->
cmd
.
p_tls
!=
NULL
)
?
vlc_tls_Write
(
sys
->
cmd
.
p_tls
,
cmd
,
val
)
:
net_Write
(
obj
,
sys
->
cmd
.
fd
,
NULL
,
cmd
,
val
))
!=
val
)
{
{
msg_Err
(
obj
,
"request failure"
);
msg_Err
(
obj
,
"request failure"
);
val
=
-
1
;
val
=
-
1
;
...
@@ -203,7 +204,11 @@ static int ftp_RecvAnswer( vlc_object_t *obj, access_sys_t *sys,
...
@@ -203,7 +204,11 @@ static int ftp_RecvAnswer( vlc_object_t *obj, access_sys_t *sys,
if
(
strp
!=
NULL
)
if
(
strp
!=
NULL
)
*
strp
=
NULL
;
*
strp
=
NULL
;
char
*
resp
=
net_Gets
(
obj
,
sys
->
cmd
.
fd
,
sys
->
cmd
.
p_vs
);
char
*
resp
;
if
(
sys
->
cmd
.
p_tls
!=
NULL
)
resp
=
vlc_tls_GetLine
(
sys
->
cmd
.
p_tls
);
else
resp
=
net_Gets
(
obj
,
sys
->
cmd
.
fd
,
NULL
);
if
(
resp
==
NULL
)
if
(
resp
==
NULL
)
{
{
msg_Err
(
obj
,
"response failure"
);
msg_Err
(
obj
,
"response failure"
);
...
@@ -226,7 +231,11 @@ static int ftp_RecvAnswer( vlc_object_t *obj, access_sys_t *sys,
...
@@ -226,7 +231,11 @@ static int ftp_RecvAnswer( vlc_object_t *obj, access_sys_t *sys,
*
end
=
' '
;
*
end
=
' '
;
do
do
{
{
char
*
line
=
net_Gets
(
obj
,
sys
->
cmd
.
fd
,
sys
->
cmd
.
p_vs
);
char
*
line
;
if
(
sys
->
cmd
.
p_tls
!=
NULL
)
line
=
vlc_tls_GetLine
(
sys
->
cmd
.
p_tls
);
else
line
=
net_Gets
(
obj
,
sys
->
cmd
.
fd
,
NULL
);
if
(
line
==
NULL
)
if
(
line
==
NULL
)
{
{
msg_Err
(
obj
,
"response failure"
);
msg_Err
(
obj
,
"response failure"
);
...
@@ -294,7 +303,6 @@ static int createCmdTLS( vlc_object_t *p_access, access_sys_t *p_sys, int fd,
...
@@ -294,7 +303,6 @@ static int createCmdTLS( vlc_object_t *p_access, access_sys_t *p_sys, int fd,
msg_Err
(
p_access
,
"cannot establish FTP/TLS session on command channel"
);
msg_Err
(
p_access
,
"cannot establish FTP/TLS session on command channel"
);
return
-
1
;
return
-
1
;
}
}
p_sys
->
cmd
.
p_vs
=
&
p_sys
->
cmd
.
p_tls
->
sock
;
return
0
;
return
0
;
}
}
...
@@ -304,7 +312,6 @@ static void clearCmdTLS( access_sys_t *p_sys )
...
@@ -304,7 +312,6 @@ static void clearCmdTLS( access_sys_t *p_sys )
if
(
p_sys
->
cmd
.
p_tls
)
vlc_tls_SessionDelete
(
p_sys
->
cmd
.
p_tls
);
if
(
p_sys
->
cmd
.
p_tls
)
vlc_tls_SessionDelete
(
p_sys
->
cmd
.
p_tls
);
if
(
p_sys
->
p_creds
)
vlc_tls_Delete
(
p_sys
->
p_creds
);
if
(
p_sys
->
p_creds
)
vlc_tls_Delete
(
p_sys
->
p_creds
);
p_sys
->
cmd
.
p_tls
=
NULL
;
p_sys
->
cmd
.
p_tls
=
NULL
;
p_sys
->
cmd
.
p_vs
=
NULL
;
p_sys
->
p_creds
=
NULL
;
p_sys
->
p_creds
=
NULL
;
}
}
...
@@ -817,8 +824,10 @@ static ssize_t Read( access_t *p_access, uint8_t *p_buffer, size_t i_len )
...
@@ -817,8 +824,10 @@ static ssize_t Read( access_t *p_access, uint8_t *p_buffer, size_t i_len )
if
(
p_access
->
info
.
b_eof
)
if
(
p_access
->
info
.
b_eof
)
return
0
;
return
0
;
i_read
=
net_Read
(
p_access
,
p_sys
->
data
.
fd
,
p_sys
->
data
.
p_vs
,
if
(
p_sys
->
data
.
p_tls
!=
NULL
)
p_buffer
,
i_len
,
false
);
i_read
=
vlc_tls_Read
(
p_sys
->
data
.
p_tls
,
p_buffer
,
i_len
,
false
);
else
i_read
=
net_Read
(
p_access
,
p_sys
->
data
.
fd
,
NULL
,
p_buffer
,
i_len
,
false
);
if
(
i_read
==
0
)
if
(
i_read
==
0
)
p_access
->
info
.
b_eof
=
true
;
p_access
->
info
.
b_eof
=
true
;
else
if
(
i_read
>
0
)
else
if
(
i_read
>
0
)
...
@@ -833,15 +842,19 @@ static ssize_t Read( access_t *p_access, uint8_t *p_buffer, size_t i_len )
...
@@ -833,15 +842,19 @@ static ssize_t Read( access_t *p_access, uint8_t *p_buffer, size_t i_len )
static
int
DirRead
(
access_t
*
p_access
,
input_item_node_t
*
p_current_node
)
static
int
DirRead
(
access_t
*
p_access
,
input_item_node_t
*
p_current_node
)
{
{
access_sys_t
*
p_sys
=
p_access
->
p_sys
;
access_sys_t
*
p_sys
=
p_access
->
p_sys
;
char
*
psz_line
;
assert
(
p_sys
->
data
.
fd
!=
-
1
);
assert
(
p_sys
->
data
.
fd
!=
-
1
);
assert
(
!
p_sys
->
out
);
assert
(
!
p_sys
->
out
);
while
(
(
psz_line
=
net_Gets
(
p_access
,
p_sys
->
data
.
fd
,
p_sys
->
data
.
p_vs
)
)
)
for
(
;;
)
{
{
char
*
psz_uri
;
char
*
psz_line
;
if
(
p_sys
->
data
.
p_tls
!=
NULL
)
psz_line
=
vlc_tls_GetLine
(
p_sys
->
data
.
p_tls
);
else
psz_line
=
net_Gets
(
p_access
,
p_sys
->
data
.
fd
,
NULL
);
char
*
psz_uri
;
if
(
asprintf
(
&
psz_uri
,
"%s://%s:%d%s%s/%s"
,
if
(
asprintf
(
&
psz_uri
,
"%s://%s:%d%s%s/%s"
,
(
p_sys
->
tlsmode
==
NONE
)
?
"ftp"
:
(
p_sys
->
tlsmode
==
NONE
)
?
"ftp"
:
(
(
p_sys
->
tlsmode
==
IMPLICIT
)
?
"ftps"
:
"ftpes"
),
(
(
p_sys
->
tlsmode
==
IMPLICIT
)
?
"ftps"
:
"ftpes"
),
...
@@ -884,8 +897,12 @@ static ssize_t Write( sout_access_out_t *p_access, block_t *p_buffer )
...
@@ -884,8 +897,12 @@ static ssize_t Write( sout_access_out_t *p_access, block_t *p_buffer )
{
{
block_t
*
p_next
=
p_buffer
->
p_next
;;
block_t
*
p_next
=
p_buffer
->
p_next
;;
i_write
+=
net_Write
(
p_access
,
p_sys
->
data
.
fd
,
p_sys
->
data
.
p_vs
,
if
(
p_sys
->
data
.
p_tls
!=
NULL
)
p_buffer
->
p_buffer
,
p_buffer
->
i_buffer
);
i_write
+=
vlc_tls_Write
(
p_sys
->
data
.
p_tls
,
p_buffer
->
p_buffer
,
p_buffer
->
i_buffer
);
else
i_write
+=
net_Write
(
p_access
,
p_sys
->
data
.
fd
,
NULL
,
p_buffer
->
p_buffer
,
p_buffer
->
i_buffer
);
block_Release
(
p_buffer
);
block_Release
(
p_buffer
);
p_buffer
=
p_next
;
p_buffer
=
p_next
;
...
@@ -1067,7 +1084,6 @@ static int ftp_StartStream( vlc_object_t *p_access, access_sys_t *p_sys,
...
@@ -1067,7 +1084,6 @@ static int ftp_StartStream( vlc_object_t *p_access, access_sys_t *p_sys,
": server not allowing new session ?"
);
": server not allowing new session ?"
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
p_sys
->
data
.
p_vs
=
&
p_sys
->
data
.
p_tls
->
sock
;
}
}
else
else
shutdown
(
p_sys
->
data
.
fd
,
p_sys
->
out
?
SHUT_RD
:
SHUT_WR
);
shutdown
(
p_sys
->
data
.
fd
,
p_sys
->
out
?
SHUT_RD
:
SHUT_WR
);
...
@@ -1087,7 +1103,6 @@ static int ftp_StopStream ( vlc_object_t *p_access, access_sys_t *p_sys )
...
@@ -1087,7 +1103,6 @@ static int ftp_StopStream ( vlc_object_t *p_access, access_sys_t *p_sys )
}
}
p_sys
->
data
.
fd
=
-
1
;
p_sys
->
data
.
fd
=
-
1
;
p_sys
->
data
.
p_tls
=
NULL
;
p_sys
->
data
.
p_tls
=
NULL
;
p_sys
->
data
.
p_vs
=
NULL
;
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
...
@@ -1097,7 +1112,6 @@ static int ftp_StopStream ( vlc_object_t *p_access, access_sys_t *p_sys )
...
@@ -1097,7 +1112,6 @@ static int ftp_StopStream ( vlc_object_t *p_access, access_sys_t *p_sys )
net_Close
(
p_sys
->
data
.
fd
);
net_Close
(
p_sys
->
data
.
fd
);
p_sys
->
data
.
fd
=
-
1
;
p_sys
->
data
.
fd
=
-
1
;
p_sys
->
data
.
p_tls
=
NULL
;
p_sys
->
data
.
p_tls
=
NULL
;
p_sys
->
data
.
p_vs
=
NULL
;
/* Read the final response from RETR/STOR, i.e. 426 or 226 */
/* Read the final response from RETR/STOR, i.e. 426 or 226 */
ftp_RecvCommand
(
p_access
,
p_sys
,
NULL
,
NULL
);
ftp_RecvCommand
(
p_access
,
p_sys
,
NULL
,
NULL
);
}
}
...
...
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