view src/protocols/icq/proxy.c @ 7724:613b20c69d2c

[gaim-migrate @ 8369] this didn't cause me any problems yesterday, and it compiles, and bug fixing is a good thing. "Some month ago I introduced translatable texts for "gaim --help" and "gaim-remote --help". Unfortunately the output of the translated text is often unreadable. The problem is, that Gaim's *.po files have the UTF-8 locale (because this is the default charset for GTK+ 2.0). But the users may have configured other locales. For instance my SuSE Linux 9.0 system is configured with LANG=de_DE@euro. "euro" is ISO-8859-1 (Western character set, 8 Bit, with the Euro currency symbol). Lots of UTF-8 characters are unreadable if they are displayed in a 8 Bit charset without conversion. Only the 7 Bit chars are displayed right. There are two possible solutions: 1) Make the console texts untranslatable. This isn't very clever. 2) Convert the texts from UTF-8 to user's locale. I choose the second solution. The conversion cannot be made during the translation, because gettext does not allow a mix of different character sets in one po-file. My patch converts the console strings from UTF-8 to users locale. Normally this works right, because most users have a locale which is compatible with their language. The case where a user uses a language (for instance German: LANG=de_DE) with an incompatible character set (for instance the 7Bit charset LC_CTYPE=C) is also handled. The user then sees a warning and the original UTF-8 message. At first I tried to make a new UTF-8 function in src/util.c. But the function is needed 5 times in src/gaim-remote.c and 2 times in src/main.c. gaim-remote is not linked against util.o. Also there are a lot of dependencies from util.o to other files, so I will introduce a lot of trouble to link gaim-remote against util.o. So I only wrote a function in src/gaim-remote.c and used the UTF-8 conversion inline in src/main.c." --Bjoern Voigt committer: Tailor Script <tailor@pidgin.im>
author Luke Schierer <lschiere@pidgin.im>
date Wed, 03 Dec 2003 13:21:55 +0000
parents 424a40f12a6c
children
line wrap: on
line source

/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */

/*
 * $Id: proxy.c 2096 2001-07-31 01:00:39Z warmenhoven $
 *
 * Copyright (C) 1998-2001, Denis V. Dmitrienko <denis@null.net> and
 *                          Bill Soudan <soudan@kde.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 */

#ifdef _WIN32
#include <winsock.h>
#endif

#include <stdlib.h>

#include "icqlib.h"

void icq_HandleProxyResponse(icq_Link *icqlink)
{
  int s;
  char buf[256];
#ifdef _WIN32
  s = recv(icqlink->icq_ProxySok, buf, sizeof(buf), 0);
#else
  s = read(icqlink->icq_ProxySok, &buf, sizeof(buf));
#endif
  if(s<=0)
  {
    icq_FmtLog(icqlink, ICQ_LOG_FATAL, "[SOCKS] Connection terminated\n");
    icq_Disconnect(icqlink);
    invoke_callback(icqlink, icq_Disconnected)(icqlink);
  }
}

/*******************
SOCKS5 Proxy support
********************/
void icq_SetProxy(icq_Link *icqlink, const char *phost, unsigned short pport, 
  int pauth, const char *pname, const char *ppass)
{
  if(icqlink->icq_ProxyHost)
    free(icqlink->icq_ProxyHost);
  if(icqlink->icq_ProxyName)
    free(icqlink->icq_ProxyName);
  if(icqlink->icq_ProxyPass)
    free(icqlink->icq_ProxyPass);

  if(!phost)
  {
    icq_FmtLog(icqlink, ICQ_LOG_ERROR, "[SOCKS] Proxy host is empty\n");
    icqlink->icq_UseProxy = 0;
    return;
  }
  if(!pname)
  {
    icq_FmtLog(icqlink, ICQ_LOG_ERROR, "[SOCKS] User name is empty\n");
    icqlink->icq_UseProxy = 0;
    return;
  }
  if(!pname)
  {
    icq_FmtLog(icqlink, ICQ_LOG_ERROR, "[SOCKS] User password is empty\n");
    icqlink->icq_UseProxy = 0;
    return;
  }

  if(strlen(pname)>255)
  {
    icq_FmtLog(icqlink, ICQ_LOG_ERROR, "[SOCKS] User name greater than 255 chars\n");
    icqlink->icq_UseProxy = 0;
    return;
  }
  if(strlen(ppass)>255)
  {
    icq_FmtLog(icqlink, ICQ_LOG_ERROR, "[SOCKS] User password greater than 255 chars\n");
    icqlink->icq_UseProxy = 0;
    return;
  }

  icqlink->icq_UseProxy = 1;
  icqlink->icq_ProxyHost = strdup(phost);
  icqlink->icq_ProxyPort = pport;
  icqlink->icq_ProxyAuth = pauth;
  icqlink->icq_ProxyName = strdup(pname);
  icqlink->icq_ProxyPass = strdup(ppass);
}

void icq_UnsetProxy(icq_Link *icqlink)
{
  icqlink->icq_UseProxy = 0;
}

int icq_GetProxySok(icq_Link *icqlink)
{
  return icqlink->icq_ProxySok;
}