diff options
author | Sebastien Helleu <flashcode@flashtux.org> | 2006-03-25 11:20:37 +0000 |
---|---|---|
committer | Sebastien Helleu <flashcode@flashtux.org> | 2006-03-25 11:20:37 +0000 |
commit | eaa33bfb8e421738ff3b6abd4c9e5a1930362f2d (patch) | |
tree | c8f1472e5d0af9704516b18c05989c13c3254eda /src/irc | |
parent | fcd38093268863f16b92b071e0489d23c26dc436 (diff) | |
download | weechat-eaa33bfb8e421738ff3b6abd4c9e5a1930362f2d.zip |
Added hostname/IP option for connection to server
Diffstat (limited to 'src/irc')
-rw-r--r-- | src/irc/irc-display.c | 4 | ||||
-rw-r--r-- | src/irc/irc-send.c | 22 | ||||
-rw-r--r-- | src/irc/irc-server.c | 49 | ||||
-rw-r--r-- | src/irc/irc.h | 5 |
4 files changed, 48 insertions, 32 deletions
diff --git a/src/irc/irc-display.c b/src/irc/irc-display.c index 8fd191416..5c0f35399 100644 --- a/src/irc/irc-display.c +++ b/src/irc/irc-display.c @@ -291,7 +291,9 @@ irc_display_server (t_irc_server *server) gui_printf (NULL, " server_username . . . . . : %s\n", server->username); gui_printf (NULL, " server_realname . . . . . : %s\n", - server->realname); + server->realname); + gui_printf (NULL, " server_hostname . . . . . : %s\n", + (server->hostname) ? server->hostname : ""); gui_printf (NULL, " server_command . . . . . . : %s\n", (server->command && server->command[0]) ? server->command : ""); diff --git a/src/irc/irc-send.c b/src/irc/irc-send.c index c1162fadf..92d3fccce 100644 --- a/src/irc/irc-send.c +++ b/src/irc/irc-send.c @@ -48,25 +48,31 @@ void irc_login (t_irc_server *server) { - char hostname[128]; + char hostname[128], *ptr_hostname; if ((server->password) && (server->password[0])) server_sendf (server, "PASS %s\r\n", server->password); - gethostname (hostname, sizeof (hostname) - 1); - hostname[sizeof (hostname) - 1] = '\0'; - if (!hostname[0]) - strcpy (hostname, _("unknown")); + if (server->hostname && server->hostname[0]) + ptr_hostname = server->hostname; + else + { + gethostname (hostname, sizeof (hostname) - 1); + hostname[sizeof (hostname) - 1] = '\0'; + if (!hostname[0]) + strcpy (hostname, _("unknown")); + ptr_hostname = hostname; + } irc_display_prefix (server, server->buffer, PREFIX_INFO); gui_printf (server->buffer, - _("%s: using local hostname \"%s\"\n"), - PACKAGE_NAME, hostname); + _("%s: using hostname \"%s\"\n"), + PACKAGE_NAME, ptr_hostname); if (!server->nick) server->nick = strdup (server->nick1); server_sendf (server, "NICK %s\r\n" "USER %s %s %s :%s\r\n", - server->nick, server->username, hostname, "servername", + server->nick, server->username, ptr_hostname, "servername", server->realname); gui_draw_buffer_input (gui_current_window->buffer, 1); } diff --git a/src/irc/irc-server.c b/src/irc/irc-server.c index 7c00e4687..933598dae 100644 --- a/src/irc/irc-server.c +++ b/src/irc/irc-server.c @@ -79,6 +79,7 @@ server_init (t_irc_server *server) server->nick3 = NULL; server->username = NULL; server->realname = NULL; + server->hostname = NULL; server->command = NULL; server->command_delay = 1; server->autojoin = NULL; @@ -291,6 +292,8 @@ server_destroy (t_irc_server *server) free (server->username); if (server->realname) free (server->realname); + if (server->hostname) + free (server->hostname); if (server->command) free (server->command); if (server->autojoin) @@ -360,12 +363,14 @@ server_free_all () */ t_irc_server * -server_new (char *name, int autoconnect, int autoreconnect, int autoreconnect_delay, - int command_line, char *address, int port, int ipv6, int ssl, char *password, +server_new (char *name, int autoconnect, int autoreconnect, + int autoreconnect_delay, int command_line, char *address, + int port, int ipv6, int ssl, char *password, char *nick1, char *nick2, char *nick3, char *username, - char *realname, char *command, int command_delay, char *autojoin, - int autorejoin, char *notify_levels, char *charset_decode_iso, - char *charset_decode_utf, char *charset_encode) + char *realname, char *hostname, char *command, int command_delay, + char *autojoin, int autorejoin, char *notify_levels, + char *charset_decode_iso, char *charset_decode_utf, + char *charset_encode) { t_irc_server *new_server; @@ -375,13 +380,14 @@ server_new (char *name, int autoconnect, int autoreconnect, int autoreconnect_de #ifdef DEBUG weechat_log_printf ("Creating new server (name:%s, address:%s, port:%d, pwd:%s, " "nick1:%s, nick2:%s, nick3:%s, username:%s, realname:%s, " - "command:%s, autojoin:%s, autorejoin:%s, notify_levels:%s, " - "decode_iso:%s, decode_utf:%s, encode:%s)\n", + "hostname: %s, command:%s, autojoin:%s, autorejoin:%s, " + "notify_levels:%s, decode_iso:%s, decode_utf:%s, encode:%s)\n", name, address, port, (password) ? password : "", (nick1) ? nick1 : "", (nick2) ? nick2 : "", (nick3) ? nick3 : "", (username) ? username : "", (realname) ? realname : "", - (command) ? command : "", (autojoin) ? autojoin : "", - (autorejoin) ? "on" : "off", (notify_levels) ? notify_levels : "", + (hostname) ? hostname : "", (command) ? command : "", + (autojoin) ? autojoin : "", (autorejoin) ? "on" : "off", + (notify_levels) ? notify_levels : "", (charset_decode_iso) ? charset_decode_iso : "", (charset_decode_utf) ? charset_decode_utf : "", (charset_encode) ? charset_encode : ""); @@ -406,6 +412,8 @@ server_new (char *name, int autoconnect, int autoreconnect, int autoreconnect_de (username) ? strdup (username) : strdup ("weechat"); new_server->realname = (realname) ? strdup (realname) : strdup ("realname"); + new_server->hostname = + (hostname) ? strdup (hostname) : NULL; new_server->command = (command) ? strdup (command) : NULL; new_server->command_delay = command_delay; @@ -1086,20 +1094,20 @@ pass_httpproxy(int sock, char *address, int port) { char buffer[256]; - char authbuf[128]; // seems to be enougth to store username + password - char authbuf_base64[196]; // enougth to store base64 encoded authbuf + char authbuf[128]; + char authbuf_base64[196]; int n, m; if (strlen(cfg_proxy_username) > 0) { - // authentification + /* authentification */ snprintf(authbuf, sizeof(authbuf), "%s:%s", cfg_proxy_username, cfg_proxy_password); base64encode(authbuf, authbuf_base64); n = snprintf(buffer, sizeof(buffer), "CONNECT %s:%d HTTP/1.0\r\nProxy-Authorization: Basic %s\r\n\r\n", address, port, authbuf_base64); } else { - // no authentification + /* no authentification */ n = snprintf(buffer, sizeof(buffer), "CONNECT %s:%d HTTP/1.0\r\n\r\n", address, port); } @@ -1109,7 +1117,7 @@ pass_httpproxy(int sock, char *address, int port) n = recv(sock, buffer, sizeof(buffer), 0); - /* success result must be like : "HTTP/1.0 200 OK" */ + /* success result must be like: "HTTP/1.0 200 OK" */ if (n < 12) return 1; @@ -1252,28 +1260,27 @@ pass_socks5proxy(int sock, char *address, int port) * - socks version (buffer[0]) = 5 => socks5 * - socks method (buffer[1]) = 2 => authentication */ - - //if (!(buffer[0] == 5 && buffer[1] == 2)) + if (buffer[0] != 5 || buffer[1] != 2) return 1; - + /* authentication as in RFC 1929 */ username_len = strlen(cfg_proxy_username); password_len = strlen(cfg_proxy_password); - + /* make username/password buffer */ buffer[0] = 1; buffer[1] = (unsigned char) username_len; memcpy(buffer + 2, cfg_proxy_username, username_len); buffer[2 + username_len] = (unsigned char) password_len; memcpy(buffer + 3 + username_len, cfg_proxy_password, password_len); - + send (sock, buffer, 3 + username_len + password_len, 0); - + /* server socks5 must respond with 2 bytes */ if (recv (sock, buffer, 2, 0) != 2) return 1; - + /* buffer[1] = auth state, must be 0 for success */ if (buffer[1] != 0) return 1; diff --git a/src/irc/irc.h b/src/irc/irc.h index 94a116318..71c6b42ab 100644 --- a/src/irc/irc.h +++ b/src/irc/irc.h @@ -142,6 +142,7 @@ struct t_irc_server char *nick3; /* 2nd alternate nickname */ char *username; /* user name */ char *realname; /* real name */ + char *hostname; /* custom hostname */ char *command; /* command to run once connected */ int command_delay; /* delay after execution of command */ char *autojoin; /* channels to automatically join */ @@ -310,8 +311,8 @@ extern void server_free (t_irc_server *); extern void server_free_all (); extern t_irc_server *server_new (char *, int, int, int, int, char *, int, int, int, char *, char *, char *, char *, char *, char *, - char *, int, char *, int, char *, char *, char *, - char *); + char *, char *, int, char *, int, char *, char *, + char *, char *); extern char *server_get_charset_decode_iso (t_irc_server *); extern char *server_get_charset_decode_utf (t_irc_server *); extern char *server_get_charset_encode (t_irc_server *); |