]> git.sesse.net Git - vlc/commitdiff
update: performs size and m5 checksum verification (untested)
authorRafaël Carré <funman@videolan.org>
Mon, 26 Nov 2007 14:00:39 +0000 (14:00 +0000)
committerRafaël Carré <funman@videolan.org>
Mon, 26 Nov 2007 14:00:39 +0000 (14:00 +0000)
include/vlc_arrays.h
include/vlc_devices.h
include/vlc_epg.h
include/vlc_md5.h
include/vlc_streaming.h
include/vlc_update.h
src/misc/update.c

index e15fd585761b0040fcff8af9b552c32120c939e8..ed256c83cf0413a436fc56b6cecb27020829efb7 100644 (file)
@@ -2,7 +2,7 @@
  * vlc_arrays.h : Arrays and data structures handling
  *****************************************************************************
  * Copyright (C) 1999-2004 the VideoLAN team
- * $Id: vlc_playlist.h 17108 2006-10-15 15:28:34Z zorglub $
+ * $Id$
  *
  * Authors: Samuel Hocevar <sam@zoy.org>
  *          Clément Stenac <zorglub@videolan.org>
index e2b88e04b6c7d23835c706abdc8bcf6e1748c9f8..9485d54c0ad62dfe3810dfa287dd02560ab88664 100644 (file)
@@ -2,7 +2,7 @@
  * vlc_devices.h : Devices handling
  *****************************************************************************
  * Copyright (C) 1999-2006 the VideoLAN team
- * $Id: vlc_input.h 15915 2006-06-15 21:22:35Z zorglub $
+ * $Id$
  *
  * Authors: Clément Stenac <zorglub@videolan.org>
  *
index 58e4d9588fd41c12cad01849faaeb8f86da80f53..62732f9ec9d8e3910f681390fbc43cd6f5a5127b 100644 (file)
@@ -2,7 +2,7 @@
  * vlc_epg.h: Electronic Program Guide
  *****************************************************************************
  * Copyright (C) 2007 the VideoLAN team
- * $Id: vlc_meta.h 18214 2006-12-03 13:48:21Z zorglub $
+ * $Id$
  *
  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
  *
index 7c84fb9d0a0ca191bc79d2e48c85b3a519ffc6a0..47f5d0b9e59a0d52a6e15fccb4ea460ebe43f418 100644 (file)
@@ -46,4 +46,28 @@ VLC_EXPORT(void, InitMD5, ( struct md5_s * ) );
 VLC_EXPORT(void, AddMD5, ( struct md5_s *, const void *, size_t ) );
 VLC_EXPORT(void, EndMD5, ( struct md5_s * ) );
 
+/** 
+ * Returns a char representation of the md5 hash, as shown by UNIX md5 or
+ * md5sum tools.
+ */
+static inline char * psz_md5_hash( struct md5_s *md5_s )
+{
+    char *psz = malloc( 33 ); /* md5 string is 32 bytes + NULL character */
+    if( !psz ) return NULL;
+
+    int i;
+    for ( i = 0; i < 4; i++ )
+    {
+        sprintf( &psz[8*i], "%02x%02x%02x%02x",
+            md5_s->p_digest[i] & 0xff,
+            ( md5_s->p_digest[i] >> 8 ) & 0xff,
+            ( md5_s->p_digest[i] >> 16 ) & 0xff,
+            md5_s->p_digest[i] >> 24
+        );
+    }
+    psz[32] = '\0';
+
+    return psz;
+}
+
 #endif
index a083232b00be8bdeac96106ef59a034c53d04af6..fa08252ba8ee8752f5a98d041228eef7a63ee897 100644 (file)
@@ -2,7 +2,7 @@
  * vlc_streaming.h: Methods and descriptions for Streaming profiles
  *****************************************************************************
  * Copyright (C) 2002-2005 the VideoLAN team
- * $Id: stream_output.h 14151 2006-02-04 00:08:50Z zorglub $
+ * $Id$
  *
  * Authors: Clément Stenac <zorglub@videolan.org>
  *
index c53005ce91fff475bd59f3c66f8f255a7682eba7..f2588ebdfa33a8b1f907614bb89635f117aeae83 100644 (file)
@@ -2,7 +2,7 @@
  * vlc_update.h: VLC update and plugins download
  *****************************************************************************
  * Copyright (C) 2005 the VideoLAN team
- * $Id$
+ * $Id$
  *
  * Authors: Antoine Cellerier <dionoea -at- videolan -dot- org>
  *
@@ -143,14 +143,7 @@ struct update_iterator_t
     int i_rs;       ///< Release status bitmask
     int i_rt;       ///< Release type bitmask
 
-    struct
-    {
-        int i_type;             ///< Type
-        char* psz_md5;          ///< MD5 hash
-        long int l_size;        ///< Size in bytes
-        char* psz_url;          ///< Absolute URL
-        char* psz_description;  ///< Description
-    } file;         ///< Local 'copy' of the current file's information
+    struct update_file_t file; ///< Local copy of the current file's information
     struct
     {
         char *psz_version;      ///< Version string
index ffe4244453cee9520809aa33810e750cd0e103d2..7cf6ffeebd223bb65faa30e29b13ab260645ec83 100644 (file)
@@ -2,7 +2,7 @@
  * update.c: VLC update and plugins download
  *****************************************************************************
  * Copyright (C) 2005 the VideoLAN team
- * $Id$
+ * $Id$
  *
  * Authors: Antoine Cellerier <dionoea -at- videolan -dot- org>
  *
@@ -48,6 +48,7 @@
 #include <vlc_xml.h>
 #include <vlc_interface.h>
 #include <vlc_charset.h>
+#include <vlc_md5.h>
 
 /*****************************************************************************
  * Misc defines
@@ -1206,7 +1207,7 @@ unsigned int update_iterator_Action( update_iterator_t *p_uit, int i_action )
 typedef struct {
     VLC_COMMON_MEMBERS
     char *psz_dest;     //< Download destination
-    char *psz_src;      //< Download source
+    struct update_file_t src;  //< Download source
     char *psz_status;   //< Download status displayed in progress dialog
 } download_thread_t;
 
@@ -1226,7 +1227,11 @@ void update_download( update_iterator_t *p_uit, const char *psz_dest )
         vlc_object_create( p_uit->p_u->p_libvlc, sizeof( download_thread_t ) );
 
     p_dt->psz_dest = strdup( psz_dest );
-    p_dt->psz_src = strdup( p_uit->file.psz_url );
+    p_dt->src.i_type = p_uit->file.i_type;
+    p_dt->src.l_size = p_uit->file.l_size;
+    p_dt->src.psz_md5 = STRDUP( p_uit->file.psz_md5 );
+    p_dt->src.psz_url = STRDUP( p_uit->file.psz_description );
+    p_dt->src.psz_description = STRDUP( p_uit->file.psz_description );
     asprintf( &p_dt->psz_status, "%s - %s (%s)\nSource: %s\nDestination: %s",
               p_uit->file.psz_description, p_uit->release.psz_version,
               p_uit->release.psz_svn_revision, p_uit->file.psz_url,
@@ -1265,7 +1270,7 @@ static char *size_str( long int l_size )
 void update_download_for_real( download_thread_t *p_this )
 {
     char *psz_dest = p_this->psz_dest;
-    char *psz_src = p_this->psz_src;
+    char *psz_src = p_this->src.psz_url;
     stream_t *p_stream;
     libvlc_int_t *p_libvlc = p_this->p_libvlc;
 
@@ -1294,6 +1299,18 @@ void update_download_for_real( download_thread_t *p_this )
     }
     else
     {
+        l_size = stream_Size(p_stream);
+        if( l_size != p_this->src.l_size )
+        {
+            stream_Delete( p_stream );
+            free( psz_status );
+            msg_Err( p_this,    "%s hasn't a correct size (%li instead of %li)."
+                                " Cancelling download.",
+                                p_this->src.psz_description,
+                                l_size,
+                                p_this->src.l_size );
+            goto end;
+        }
         p_file = utf8_fopen( psz_dest, "w" );
         if( !p_file )
         {
@@ -1304,20 +1321,24 @@ void update_download_for_real( download_thread_t *p_this )
         }
         else
         {
-            long int l_read;
+            int i_read;
             char *psz_s1; char *psz_s2;
+            struct md5_s md5_s;
 
-            l_size = stream_Size(p_stream);
             p_buffer = (void *)malloc( 1<<10 );
             if( p_buffer )
             {
-                while( ( l_read = stream_Read( p_stream, p_buffer, 1<<10 ) ) )
+                if( p_this->src.i_type & ( UPDATE_FILE_TYPE_SOURCE | UPDATE_FILE_TYPE_BINARY | UPDATE_FILE_TYPE_PLUGIN ) )
+                    InitMD5( &md5_s );
+                while( ( i_read = stream_Read( p_stream, p_buffer, 1<<10 ) ) )
                 {
                     float f_progress;
 
-                    fwrite( p_buffer, l_read, 1, p_file );
+                    fwrite( p_buffer, i_read, 1, p_file );
+                    if( p_this->src.i_type & ( UPDATE_FILE_TYPE_SOURCE | UPDATE_FILE_TYPE_BINARY | UPDATE_FILE_TYPE_PLUGIN ) )
+                        AddMD5( &md5_s, p_buffer, (size_t) i_read );
 
-                    l_done += l_read;
+                    l_done += i_read;
                     free( psz_status );
                     f_progress = 100.0*(float)l_done/(float)l_size;
                     psz_s1 = size_str( l_done );
@@ -1330,12 +1351,29 @@ void update_download_for_real( download_thread_t *p_this )
                     intf_ProgressUpdate( p_libvlc, i_progress,
                                         psz_status, f_progress, 0 );
                 }
-
                 free( p_buffer );
             }
             fclose( p_file );
             stream_Delete( p_stream );
 
+            if( l_done == p_this->src.l_size && 
+                p_this->src.i_type & ( UPDATE_FILE_TYPE_SOURCE |
+                UPDATE_FILE_TYPE_BINARY | UPDATE_FILE_TYPE_PLUGIN ) )
+            {
+                EndMD5( &md5_s );
+                char *psz_md5 = psz_md5_hash( &md5_s );
+                if( !p_this->src.psz_md5 || !psz_md5 ||
+                    strncmp( psz_md5, p_this->src.psz_md5, 32 ) )
+                {
+                    msg_Err( p_this, 
+    _("%s has an incorrect checksum, download failed or mirror is compromised.\n
+    Please run an antivirus on %s, and report if that file is trojaned.\n
+    If not, please try later."),
+    p_this->src.psz_description );
+                }
+                free( psz_md5 );
+            }
+
             free( psz_status );
             psz_s2 = size_str( l_size );
             asprintf( &psz_status, "%s\nDone %s (100.00%%)",
@@ -1346,8 +1384,11 @@ void update_download_for_real( download_thread_t *p_this )
         }
     }
 
+end:
     free( p_this->psz_dest );
-    free( p_this->psz_src );
+    free( p_this->src.psz_url );
+    free( p_this->src.psz_description );
+    free( p_this->src.psz_md5 );
     free( p_this->psz_status );
 
     vlc_object_destroy( p_this );