Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
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-1.1
Commits
b3b41c2c
Commit
b3b41c2c
authored
Nov 03, 2009
by
Rafaël Carré
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update: correctly handle different line endings
parent
feac5bc6
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
60 additions
and
61 deletions
+60
-61
src/misc/update.c
src/misc/update.c
+45
-30
src/misc/update_crypto.c
src/misc/update_crypto.c
+15
-31
No files found.
src/misc/update.c
View file @
b3b41c2c
...
@@ -186,6 +186,7 @@ static bool GetUpdateFile( update_t *p_update )
...
@@ -186,6 +186,7 @@ static bool GetUpdateFile( update_t *p_update )
int
i_revision
=
0
;
int
i_revision
=
0
;
unsigned
char
extra
;
unsigned
char
extra
;
char
*
psz_version_line
=
NULL
;
char
*
psz_version_line
=
NULL
;
char
*
psz_update_data
=
NULL
;
p_stream
=
stream_UrlNew
(
p_update
->
p_libvlc
,
UPDATE_VLC_STATUS_URL
);
p_stream
=
stream_UrlNew
(
p_update
->
p_libvlc
,
UPDATE_VLC_STATUS_URL
);
if
(
!
p_stream
)
if
(
!
p_stream
)
...
@@ -195,15 +196,34 @@ static bool GetUpdateFile( update_t *p_update )
...
@@ -195,15 +196,34 @@ static bool GetUpdateFile( update_t *p_update )
goto
error
;
goto
error
;
}
}
/* Start reading the status file */
const
int64_t
i_read
=
stream_Size
(
p_stream
);
if
(
!
(
psz_version_line
=
stream_ReadLine
(
p_stream
)
)
)
psz_update_data
=
malloc
(
i_read
+
1
);
/* terminating '\0' */
if
(
!
psz_update_data
)
goto
error
;
if
(
stream_Read
(
p_stream
,
psz_update_data
,
i_read
)
!=
i_read
)
{
{
msg_Err
(
p_update
->
p_libvlc
,
"
Update file %s is corrupted : missing version
"
,
msg_Err
(
p_update
->
p_libvlc
,
"
Couldn't download update file %s
"
,
UPDATE_VLC_STATUS_URL
);
UPDATE_VLC_STATUS_URL
);
goto
error
;
goto
error
;
}
}
psz_update_data
[
i_read
]
=
'\0'
;
stream_Delete
(
p_stream
);
p_stream
=
NULL
;
/* first line : version number */
/* first line : version number */
char
*
psz_update_data_parser
=
psz_update_data
;
size_t
i_len
=
strcspn
(
psz_update_data
,
"
\r\n
"
);
psz_update_data_parser
+=
i_len
;
while
(
*
psz_update_data_parser
==
'\r'
||
*
psz_update_data_parser
==
'\n'
)
psz_update_data_parser
++
;
if
(
!
(
psz_version_line
=
malloc
(
i_len
+
1
))
)
goto
error
;
strncpy
(
psz_version_line
,
psz_update_data
,
i_len
);
psz_version_line
[
i_len
]
=
'\0'
;
p_update
->
release
.
extra
=
0
;
p_update
->
release
.
extra
=
0
;
switch
(
sscanf
(
psz_version_line
,
"%i.%i.%i%c"
,
switch
(
sscanf
(
psz_version_line
,
"%i.%i.%i%c"
,
&
i_major
,
&
i_minor
,
&
i_revision
,
&
extra
)
)
&
i_major
,
&
i_minor
,
&
i_revision
,
&
extra
)
)
...
@@ -221,16 +241,27 @@ static bool GetUpdateFile( update_t *p_update )
...
@@ -221,16 +241,27 @@ static bool GetUpdateFile( update_t *p_update )
}
}
/* second line : URL */
/* second line : URL */
if
(
!
(
p_update
->
release
.
psz_url
=
stream_ReadLine
(
p_stream
)
)
)
i_len
=
strcspn
(
psz_update_data_parser
,
"
\r\n
"
);
if
(
i_len
==
0
)
{
{
msg_Err
(
p_update
->
p_libvlc
,
"Update file %s is corrupted
: URL missing"
,
msg_Err
(
p_update
->
p_libvlc
,
"Update file %s is corrupted: URL missing"
,
UPDATE_VLC_STATUS_URL
);
UPDATE_VLC_STATUS_URL
);
goto
error
;
goto
error
;
}
}
if
(
!
(
p_update
->
release
.
psz_url
=
malloc
(
i_len
+
1
))
)
goto
error
;
strncpy
(
p_update
->
release
.
psz_url
,
psz_update_data_parser
,
i_len
);
p_update
->
release
.
psz_url
[
i_len
]
=
'\0'
;
psz_update_data_parser
+=
i_len
;
while
(
*
psz_update_data_parser
==
'\r'
||
*
psz_update_data_parser
==
'\n'
)
psz_update_data_parser
++
;
/* Remaining data : description */
/* Remaining data : description */
i
nt
i_read
=
stream_Size
(
p_stream
)
-
stream_Tell
(
p_stream
);
i
_len
=
strlen
(
psz_update_data_parser
);
if
(
i_
read
<
=
0
)
if
(
i_
len
=
=
0
)
{
{
msg_Err
(
p_update
->
p_libvlc
,
msg_Err
(
p_update
->
p_libvlc
,
"Update file %s is corrupted: description missing"
,
"Update file %s is corrupted: description missing"
,
...
@@ -238,20 +269,12 @@ static bool GetUpdateFile( update_t *p_update )
...
@@ -238,20 +269,12 @@ static bool GetUpdateFile( update_t *p_update )
goto
error
;
goto
error
;
}
}
p_update
->
release
.
psz_desc
=
(
char
*
)
malloc
(
i_read
+
1
);
if
(
!
(
p_update
->
release
.
psz_desc
=
malloc
(
i_len
+
1
))
)
if
(
!
p_update
->
release
.
psz_desc
)
goto
error
;
goto
error
;
strncpy
(
p_update
->
release
.
psz_desc
,
psz_update_data_parser
,
i_len
);
p_update
->
release
.
psz_desc
[
i_len
]
=
'\0'
;
if
(
stream_Read
(
p_stream
,
p_update
->
release
.
psz_desc
,
i_read
)
!=
i_read
)
printf
(
"desc %s
\n
"
,
p_update
->
release
.
psz_desc
);
{
msg_Err
(
p_update
->
p_libvlc
,
"Couldn't download update file %s"
,
UPDATE_VLC_STATUS_URL
);
goto
error
;
}
p_update
->
release
.
psz_desc
[
i_read
]
=
'\0'
;
stream_Delete
(
p_stream
);
p_stream
=
NULL
;
/* Now that we know the status is valid, we must download its signature
/* Now that we know the status is valid, we must download its signature
* to authenticate it */
* to authenticate it */
...
@@ -321,16 +344,7 @@ static bool GetUpdateFile( update_t *p_update )
...
@@ -321,16 +344,7 @@ static bool GetUpdateFile( update_t *p_update )
}
}
}
}
/* FIXME : read the status file all at once instead of line per line */
uint8_t
*
p_hash
=
hash_sha1_from_text
(
psz_update_data
,
&
sign
);
char
*
psz_text
;
if
(
asprintf
(
&
psz_text
,
"%s
\n
%s
\n
%s"
,
psz_version_line
,
p_update
->
release
.
psz_url
,
p_update
->
release
.
psz_desc
)
==
-
1
)
{
goto
error
;
}
FREENULL
(
psz_version_line
);
uint8_t
*
p_hash
=
hash_sha1_from_text
(
psz_text
,
&
sign
);
if
(
!
p_hash
)
if
(
!
p_hash
)
{
{
msg_Warn
(
p_update
->
p_libvlc
,
"Can't compute SHA1 hash for status file"
);
msg_Warn
(
p_update
->
p_libvlc
,
"Can't compute SHA1 hash for status file"
);
...
@@ -361,6 +375,7 @@ error:
...
@@ -361,6 +375,7 @@ error:
if
(
p_stream
)
if
(
p_stream
)
stream_Delete
(
p_stream
);
stream_Delete
(
p_stream
);
free
(
psz_version_line
);
free
(
psz_version_line
);
free
(
psz_update_data
);
return
false
;
return
false
;
}
}
...
...
src/misc/update_crypto.c
View file @
b3b41c2c
...
@@ -653,34 +653,6 @@ error:
...
@@ -653,34 +653,6 @@ error:
}
}
/* hash a text
* * provided as a buffer (\0 terminated)
* * with "\r\n" line endings if it's a text signature, else use UNIX line
* * endings
*/
static
int
hash_from_string
(
const
char
*
psz_string
,
gcry_md_hd_t
hd
,
bool
text_signature
)
{
while
(
*
psz_string
)
{
size_t
i_len
=
strcspn
(
psz_string
,
"
\r\n
"
);
if
(
!
i_len
)
break
;
gcry_md_write
(
hd
,
psz_string
,
i_len
);
if
(
text_signature
)
gcry_md_putc
(
hd
,
'\r'
);
gcry_md_putc
(
hd
,
'\n'
);
psz_string
+=
i_len
;
while
(
*
psz_string
==
'\r'
||
*
psz_string
==
'\n'
)
psz_string
++
;
}
return
0
;
}
/* hash a binary file */
/* hash a binary file */
static
int
hash_from_binary_file
(
const
char
*
psz_file
,
gcry_md_hd_t
hd
)
static
int
hash_from_binary_file
(
const
char
*
psz_file
,
gcry_md_hd_t
hd
)
{
{
...
@@ -754,11 +726,23 @@ uint8_t *hash_sha1_from_text( const char *psz_string,
...
@@ -754,11 +726,23 @@ uint8_t *hash_sha1_from_text( const char *psz_string,
if
(
gcry_md_open
(
&
hd
,
GCRY_MD_SHA1
,
0
)
)
if
(
gcry_md_open
(
&
hd
,
GCRY_MD_SHA1
,
0
)
)
return
NULL
;
return
NULL
;
if
(
hash_from_string
(
psz_string
,
hd
,
p_sig
->
type
==
TEXT_SIGNATURE
)
<
0
)
if
(
p_sig
->
type
==
TEXT_SIGNATURE
)
while
(
*
psz_string
)
{
{
gcry_md_close
(
hd
);
size_t
i_len
=
strcspn
(
psz_string
,
"
\r\n
"
);
return
NULL
;
if
(
!
i_len
)
break
;
gcry_md_write
(
hd
,
psz_string
,
i_len
);
gcry_md_putc
(
hd
,
'\r'
);
gcry_md_putc
(
hd
,
'\n'
);
psz_string
+=
i_len
;
while
(
*
psz_string
==
'\r'
||
*
psz_string
==
'\n'
)
psz_string
++
;
}
}
else
gcry_md_write
(
hd
,
psz_string
,
strlen
(
psz_string
)
);
return
hash_finish
(
hd
,
p_sig
);
return
hash_finish
(
hd
,
p_sig
);
}
}
...
...
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