Ignore:
Timestamp:
May 8, 2009, 2:35:23 PM (13 years ago)
Author:
charles
Message:

(1.5x) revert r8352; it's not a sufficient fix

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/1.5x/daemon/remote.c

    r8352 r8357  
    127127static char * auth = NULL;
    128128static char * netrc = NULL;
    129 static char * cookies = NULL;
    130129
    131130static char*
     
    12241223}
    12251224
    1226 /* very basic handling of cookies: when we get Set-Cookie, throw out all
    1227  * the previous cookies...  T only uses one cookie (session_id) */
    1228 static size_t
    1229 parseResponseHeader( void *ptr, size_t size, size_t nmemb, void * stream UNUSED )
    1230 {
    1231     const char * line = ptr;
    1232     const size_t linelen = size * nmemb;
    1233     const char * lineend = line + linelen;
    1234     const char * key = "Set-Cookie: ";
    1235     const size_t keylen = strlen( key );
    1236     if( ( linelen >= keylen ) && !memcmp( line, key, keylen ) ) {
    1237         const char * begin = line + keylen;
    1238         const char * end = begin;
    1239         while(( end!=lineend ) && !strchr("\r\n",*end))
    1240             ++end;
    1241         tr_free( cookies );
    1242         cookies = tr_strndup( begin, end-begin );
    1243     }
    1244 
    1245     return linelen;
    1246 }
    1247 
    1248 static CURL*
    1249 tr_curl_easy_init( struct evbuffer * writebuf )
    1250 {
    1251     CURL * curl = curl_easy_init( );
    1252     curl_easy_setopt( curl, CURLOPT_USERAGENT, MY_NAME "/" LONG_VERSION_STRING );
    1253     curl_easy_setopt( curl, CURLOPT_WRITEFUNCTION, writeFunc );
    1254     curl_easy_setopt( curl, CURLOPT_WRITEDATA, writebuf );
    1255     curl_easy_setopt( curl, CURLOPT_HEADERFUNCTION, parseResponseHeader );
    1256     curl_easy_setopt( curl, CURLOPT_POST, 1 );
    1257     curl_easy_setopt( curl, CURLOPT_NETRC, CURL_NETRC_OPTIONAL );
    1258     curl_easy_setopt( curl, CURLOPT_HTTPAUTH, CURLAUTH_ANY );
    1259     curl_easy_setopt( curl, CURLOPT_TIMEOUT, 60L );
    1260     curl_easy_setopt( curl, CURLOPT_VERBOSE, debug );
    1261 #ifdef HAVE_ZLIB
    1262     curl_easy_setopt( curl, CURLOPT_ENCODING, "deflate" );
    1263 #endif
    1264     if( cookies )
    1265         curl_easy_setopt( curl, CURLOPT_COOKIE, cookies );
    1266     if( netrc )
    1267         curl_easy_setopt( curl, CURLOPT_NETRC_FILE, netrc );
    1268     if( auth )
    1269         curl_easy_setopt( curl, CURLOPT_USERPWD, auth );
    1270     return curl;
    1271 }
    1272 
    12731225static void
    12741226processRequests( const char *  host,
     
    12771229                 int           reqCount )
    12781230{
    1279     int i;
    1280     CURL * curl = NULL;
     1231    int               i;
     1232    CURL *            curl;
    12811233    struct evbuffer * buf = evbuffer_new( );
    1282     char * url = tr_strdup_printf( "http://%s:%d/transmission/rpc", host, port );
    1283 
    1284     for( i=0; i<reqCount; ++i )
     1234    char *            url = tr_strdup_printf(
     1235        "http://%s:%d/transmission/rpc", host, port );
     1236
     1237    curl = curl_easy_init( );
     1238    curl_easy_setopt( curl, CURLOPT_VERBOSE, debug );
     1239#ifdef HAVE_LIBZ
     1240    curl_easy_setopt( curl, CURLOPT_ENCODING, "deflate" );
     1241#endif
     1242    curl_easy_setopt( curl, CURLOPT_USERAGENT, MY_NAME "/" LONG_VERSION_STRING );
     1243    curl_easy_setopt( curl, CURLOPT_WRITEFUNCTION, writeFunc );
     1244    curl_easy_setopt( curl, CURLOPT_WRITEDATA, buf );
     1245    curl_easy_setopt( curl, CURLOPT_POST, 1 );
     1246    curl_easy_setopt( curl, CURLOPT_URL, url );
     1247    curl_easy_setopt( curl, CURLOPT_NETRC, CURL_NETRC_OPTIONAL );
     1248    curl_easy_setopt( curl, CURLOPT_HTTPAUTH, CURLAUTH_ANY );
     1249    curl_easy_setopt( curl, CURLOPT_TIMEOUT, 60L );
     1250    if( netrc )
     1251        curl_easy_setopt( curl, CURLOPT_NETRC_FILE, netrc );
     1252    if( auth )
     1253        curl_easy_setopt( curl, CURLOPT_USERPWD, auth );
     1254
     1255    for( i = 0; i < reqCount; ++i )
    12851256    {
    12861257        CURLcode res;
    1287         evbuffer_drain( buf, EVBUFFER_LENGTH( buf ) );
    1288 
    1289         if( curl == NULL )
    1290         {
    1291             curl = tr_curl_easy_init( buf );
    1292             curl_easy_setopt( curl, CURLOPT_URL, url );
    1293         }
    1294 
    12951258        curl_easy_setopt( curl, CURLOPT_POSTFIELDS, reqs[i] );
    1296 
    12971259        if( debug )
    12981260            fprintf( stderr, "posting:\n--------\n%s\n--------\n", reqs[i] );
    12991261        if( ( res = curl_easy_perform( curl ) ) )
    1300             tr_nerr( MY_NAME, "(%s:%d) %s", host, port, curl_easy_strerror( res ) );
    1301         else {
    1302             long response;
    1303             curl_easy_getinfo( curl, CURLINFO_RESPONSE_CODE, &response );
    1304             switch( response ) {
    1305                 case 200:
    1306                     processResponse( host, port, EVBUFFER_DATA(buf), EVBUFFER_LENGTH(buf) );
    1307                     break;
    1308                 case 409:
    1309                     /* session_id cookie expired.  by the time we reach line this our
    1310                      * curl header func has already found the new session_id, so make
    1311                      * a new CURL* and try again... */
    1312                     curl_easy_cleanup( curl );
    1313                     curl = NULL;
    1314                     --i;
    1315                     break;
    1316                 default:
    1317                     fprintf( stderr, "Unexpected response: %s\n", (char*)EVBUFFER_DATA(buf) );
    1318                     break;
    1319             }
    1320         }
     1262            tr_nerr( MY_NAME, "(%s:%d) %s", host, port,
     1263                    curl_easy_strerror( res ) );
     1264        else
     1265            processResponse( host, port, EVBUFFER_DATA(
     1266                                buf ), EVBUFFER_LENGTH( buf ) );
     1267
     1268        evbuffer_drain( buf, EVBUFFER_LENGTH( buf ) );
    13211269    }
    13221270
     
    13241272    tr_free( url );
    13251273    evbuffer_free( buf );
    1326     if( curl != NULL )
    1327         curl_easy_cleanup( curl );
     1274    curl_easy_cleanup( curl );
    13281275}
    13291276
Note: See TracChangeset for help on using the changeset viewer.