2008-09-02 20:59:00 +00:00
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stdlib.h> /* getenv() */
|
|
|
|
#include <unistd.h> /* write() */
|
|
|
|
#include <glib.h>
|
|
|
|
#include <glib/gprintf.h>
|
|
|
|
#include <glib/gi18n.h>
|
|
|
|
|
2009-01-24 00:28:41 +00:00
|
|
|
#define CURL_DISABLE_TYPECHECK /* otherwise -Wunreachable-code goes insane */
|
2008-09-02 20:59:00 +00:00
|
|
|
#include <curl/curl.h>
|
|
|
|
|
|
|
|
#include <libtransmission/transmission.h>
|
|
|
|
#include <libtransmission/utils.h>
|
|
|
|
#include <libtransmission/version.h>
|
|
|
|
|
|
|
|
#include "blocklist.h"
|
|
|
|
#include "tr-core.h"
|
|
|
|
#include "tr-prefs.h"
|
|
|
|
#include "util.h"
|
|
|
|
|
|
|
|
#define BLOCKLIST_DATE "blocklist-date"
|
|
|
|
|
|
|
|
/***
|
|
|
|
****
|
|
|
|
***/
|
|
|
|
|
|
|
|
struct idle_data
|
|
|
|
{
|
2008-09-23 19:11:04 +00:00
|
|
|
TrCore * core;
|
|
|
|
gboolean isDone;
|
|
|
|
char * str;
|
2008-09-02 20:59:00 +00:00
|
|
|
};
|
|
|
|
static gboolean
|
|
|
|
emitProgressIdle( gpointer gdata )
|
|
|
|
{
|
|
|
|
struct idle_data * data = gdata;
|
|
|
|
|
|
|
|
tr_core_blocksig( data->core, data->isDone, data->str );
|
|
|
|
|
|
|
|
g_free( data->str );
|
|
|
|
g_free( data );
|
|
|
|
return FALSE;
|
|
|
|
}
|
2008-09-23 19:11:04 +00:00
|
|
|
|
2008-09-02 20:59:00 +00:00
|
|
|
static void
|
2008-09-23 19:11:04 +00:00
|
|
|
emitProgress( TrCore * core,
|
|
|
|
gboolean isDone,
|
|
|
|
const char * fmt,
|
|
|
|
... )
|
2008-09-02 20:59:00 +00:00
|
|
|
{
|
|
|
|
struct idle_data * data = tr_new0( struct idle_data, 1 );
|
2008-09-23 19:11:04 +00:00
|
|
|
va_list args;
|
2008-09-02 20:59:00 +00:00
|
|
|
|
|
|
|
data->core = core;
|
|
|
|
data->isDone = isDone;
|
|
|
|
va_start( args, fmt );
|
|
|
|
g_vasprintf( &data->str, fmt, args );
|
|
|
|
va_end( args );
|
|
|
|
|
|
|
|
tr_inf( "%s", data->str );
|
|
|
|
g_idle_add( emitProgressIdle, data );
|
|
|
|
}
|
|
|
|
|
|
|
|
/***
|
|
|
|
****
|
|
|
|
***/
|
|
|
|
|
|
|
|
static size_t
|
2008-09-23 19:11:04 +00:00
|
|
|
writeFunc( void * ptr,
|
|
|
|
size_t size,
|
|
|
|
size_t nmemb,
|
|
|
|
void * fd )
|
2008-09-02 20:59:00 +00:00
|
|
|
{
|
|
|
|
const size_t byteCount = size * nmemb;
|
2008-09-23 19:11:04 +00:00
|
|
|
|
2008-09-02 20:59:00 +00:00
|
|
|
return write( *(int*)fd, ptr, byteCount );
|
|
|
|
}
|
|
|
|
|
|
|
|
static gpointer
|
|
|
|
blocklistThreadFunc( gpointer gcore )
|
|
|
|
{
|
2009-03-04 16:42:20 +00:00
|
|
|
int fd;
|
|
|
|
int rules;
|
|
|
|
gboolean ok = TRUE;
|
|
|
|
char * filename = NULL;
|
|
|
|
char * filename2 = NULL;
|
|
|
|
const char * url = "http://update.transmissionbt.com/level1.gz";
|
|
|
|
TrCore * core = TR_CORE( gcore );
|
2008-09-02 20:59:00 +00:00
|
|
|
|
|
|
|
emitProgress( core, FALSE, _( "Retrieving blocklist..." ) );
|
|
|
|
|
|
|
|
if( ok )
|
|
|
|
{
|
|
|
|
GError * err = NULL;
|
2008-09-23 19:11:04 +00:00
|
|
|
fd = g_file_open_tmp( "transmission-blockfile-XXXXXX", &filename,
|
|
|
|
&err );
|
|
|
|
if( err )
|
|
|
|
{
|
|
|
|
emitProgress( core, TRUE, _(
|
|
|
|
"Unable to get blocklist: %s" ), err->message );
|
2008-09-02 20:59:00 +00:00
|
|
|
g_clear_error( &err );
|
|
|
|
ok = FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( ok )
|
|
|
|
{
|
2008-10-21 03:57:56 +00:00
|
|
|
long verbose = getenv( "TR_CURL_VERBOSE" ) == NULL ? 0L : 1L;
|
|
|
|
|
2008-09-23 19:11:04 +00:00
|
|
|
CURL * curl = curl_easy_init( );
|
2008-09-02 20:59:00 +00:00
|
|
|
curl_easy_setopt( curl, CURLOPT_URL, url );
|
|
|
|
curl_easy_setopt( curl, CURLOPT_ENCODING, "deflate" );
|
2009-03-05 13:14:21 +00:00
|
|
|
curl_easy_setopt( curl, CURLOPT_FOLLOWLOCATION, 1L );
|
|
|
|
curl_easy_setopt( curl, CURLOPT_USERAGENT, "Transmission/" LONG_VERSION_STRING );
|
2008-10-21 03:57:56 +00:00
|
|
|
curl_easy_setopt( curl, CURLOPT_VERBOSE, verbose );
|
2008-09-02 20:59:00 +00:00
|
|
|
curl_easy_setopt( curl, CURLOPT_WRITEFUNCTION, writeFunc );
|
|
|
|
curl_easy_setopt( curl, CURLOPT_WRITEDATA, &fd );
|
|
|
|
curl_easy_setopt( curl, CURLOPT_NOPROGRESS, 1 );
|
|
|
|
ok = !curl_easy_perform( curl );
|
|
|
|
curl_easy_cleanup( curl );
|
|
|
|
close( fd );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( !ok )
|
|
|
|
{
|
|
|
|
emitProgress( core, TRUE, _( "Unable to get blocklist." ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( ok )
|
|
|
|
{
|
|
|
|
char * cmd;
|
|
|
|
emitProgress( core, FALSE, _( "Uncompressing blocklist..." ) );
|
|
|
|
filename2 = g_strdup_printf( "%s.txt", filename );
|
|
|
|
cmd = g_strdup_printf( "zcat %s > %s ", filename, filename2 );
|
|
|
|
tr_dbg( "%s", cmd );
|
2008-10-09 20:03:34 +00:00
|
|
|
(void) system( cmd );
|
2008-09-02 20:59:00 +00:00
|
|
|
g_free( cmd );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( ok )
|
|
|
|
{
|
|
|
|
emitProgress( core, FALSE, _( "Parsing blocklist..." ) );
|
2008-10-28 19:49:33 +00:00
|
|
|
rules = tr_blocklistSetContent( tr_core_session( core ), filename2 );
|
2008-09-02 20:59:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if( ok )
|
|
|
|
{
|
2008-09-23 19:11:04 +00:00
|
|
|
emitProgress( core, TRUE, _(
|
|
|
|
"Blocklist updated with %'d entries" ), rules );
|
2008-09-02 20:59:00 +00:00
|
|
|
pref_int_set( BLOCKLIST_DATE, time( NULL ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
g_free( filename2 );
|
|
|
|
g_free( filename );
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/***
|
|
|
|
****
|
|
|
|
***/
|
|
|
|
|
|
|
|
void
|
|
|
|
gtr_blocklist_update( TrCore * core )
|
|
|
|
{
|
|
|
|
g_thread_create( blocklistThreadFunc, core, TRUE, NULL );
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
gtr_blocklist_maybe_autoupdate( TrCore * core )
|
|
|
|
{
|
|
|
|
if( pref_flag_get( PREF_KEY_BLOCKLIST_UPDATES_ENABLED )
|
2008-09-23 19:11:04 +00:00
|
|
|
&& ( time( NULL ) - pref_int_get( BLOCKLIST_DATE ) >
|
|
|
|
( 60 * 60 * 24 * 7 ) ) )
|
2008-09-02 20:59:00 +00:00
|
|
|
gtr_blocklist_update( core );
|
|
|
|
}
|
2008-09-23 19:11:04 +00:00
|
|
|
|