mirror of
https://github.com/weechat/weechat.git
synced 2026-06-26 12:56:37 +02:00
irc: connect with TLS and port 6697 by default (issue #1903)
This commit is contained in:
+1
-1
@@ -36,7 +36,7 @@ New features::
|
||||
* core: add item "mouse_status" in default status bar, change default color to lightgreen
|
||||
* api: add function config_set_version (issue #1238)
|
||||
* alias: use lower case for default aliases, rename all aliases to lower case on upgrade (issue #1872)
|
||||
* irc: rename "ssl" options to "tls"
|
||||
* irc: rename "ssl" options to "tls", connect with TLS and port 6697 by default
|
||||
* irc: add command `/rules` (issue #1864)
|
||||
* irc: add command `/knock` (issue #7)
|
||||
* irc: add server option "registered_mode", add fields "authentication_method" and "sasl_mechanism_used" in server (issue #1625)
|
||||
|
||||
@@ -5549,7 +5549,7 @@ IRC_COMMAND_CALLBACK(server)
|
||||
{
|
||||
int i, detailed_list, one_server_found, length, count, refresh;
|
||||
struct t_irc_server *ptr_server2, *server_found, *new_server;
|
||||
char *server_name, *msg_no_quotes, *message;
|
||||
char *server_name, *msg_no_quotes, *message, *description;
|
||||
|
||||
IRC_BUFFER_GET_SERVER_CHANNEL(buffer);
|
||||
|
||||
@@ -5647,9 +5647,11 @@ IRC_COMMAND_CALLBACK(server)
|
||||
new_server->options[IRC_SERVER_OPTION_ADDRESSES], argv[3], 1);
|
||||
irc_server_apply_command_line_options (new_server, argc, argv);
|
||||
|
||||
description = irc_server_get_addresses_ports_tls (new_server);
|
||||
|
||||
weechat_printf (
|
||||
NULL,
|
||||
_("%s: server added: %s%s%s%s%s"),
|
||||
_("%s: server added: %s%s%s%s%s -> %s"),
|
||||
IRC_PLUGIN_NAME,
|
||||
IRC_COLOR_CHAT_SERVER,
|
||||
new_server->name,
|
||||
@@ -5657,7 +5659,11 @@ IRC_COMMAND_CALLBACK(server)
|
||||
/* TRANSLATORS: "temporary IRC server" */
|
||||
(new_server->temp_server) ? _(" (temporary)") : "",
|
||||
/* TRANSLATORS: "fake IRC server" */
|
||||
(new_server->fake_server) ? _(" (fake)") : "");
|
||||
(new_server->fake_server) ? _(" (fake)") : "",
|
||||
description);
|
||||
|
||||
if (description)
|
||||
free (description);
|
||||
|
||||
/* do not connect to server after adding it */
|
||||
/*
|
||||
@@ -6978,7 +6984,8 @@ irc_command_init ()
|
||||
N_(" server: server name, which can be:\n"
|
||||
" - internal server name (added by /server add, "
|
||||
"recommended usage)\n"
|
||||
" - hostname/port or IP/port, port is 6667 by default\n"
|
||||
" - hostname/port or IP/port, port is 6697 by default "
|
||||
"for TLS, 6667 otherwise\n"
|
||||
" - URL with format: irc[6][s]://[nickname[:password]@]"
|
||||
"irc.example.org[:port][/#channel1][,#channel2[...]]\n"
|
||||
" Note: for an address/IP/URL, a temporary server is "
|
||||
@@ -6999,10 +7006,10 @@ irc_command_init ()
|
||||
"\n"
|
||||
"Examples:\n"
|
||||
" /connect libera\n"
|
||||
" /connect irc.oftc.net/6667\n"
|
||||
" /connect irc6.oftc.net/6667 -ipv6\n"
|
||||
" /connect irc6.oftc.net/6697 -ipv6 -tls\n"
|
||||
" /connect my.server.org/6697 -tls -password=test\n"
|
||||
" /connect irc.oftc.net\n"
|
||||
" /connect irc.oftc.net/6667 -notls\n"
|
||||
" /connect irc6.oftc.net/9999 -ipv6\n"
|
||||
" /connect my.server.org -password=test\n"
|
||||
" /connect irc://nick@irc.oftc.net/#channel\n"
|
||||
" /connect -switch"),
|
||||
"%(irc_servers)|-all|-auto|-open|-nojoin|-switch|%*",
|
||||
@@ -7522,7 +7529,8 @@ irc_command_init ()
|
||||
"is used to connect to the server (/connect name) and to set server "
|
||||
"options: irc.server.name.xxx\n"
|
||||
"hostname: name or IP address of server, with optional port "
|
||||
"(default: 6667), many addresses can be separated by a comma\n"
|
||||
"(default: 6697 for TLS, 6667 otherwise), many addresses can be "
|
||||
"separated by a comma\n"
|
||||
" -temp: add a temporary server (not saved)\n"
|
||||
" option: set option for server (for boolean option, value can be "
|
||||
"omitted)\n"
|
||||
@@ -7557,9 +7565,9 @@ irc_command_init ()
|
||||
"Examples:\n"
|
||||
" /server listfull\n"
|
||||
" /server add libera irc.libera.chat\n"
|
||||
" /server add libera irc.libera.chat/6697 -tls -autoconnect\n"
|
||||
" /server add libera irc.libera.chat/6667 -notls -autoconnect\n"
|
||||
" /server add chatspike irc.chatspike.net/6667,"
|
||||
"irc.duckspike.net/6667\n"
|
||||
"irc.duckspike.net/6667 -notls\n"
|
||||
" /server copy libera libera-test\n"
|
||||
" /server rename libera-test libera2\n"
|
||||
" /server reorder libera2 libera\n"
|
||||
|
||||
@@ -997,8 +997,18 @@ irc_config_server_default_change_cb (const void *pointer, void *data,
|
||||
switch (index_option)
|
||||
{
|
||||
case IRC_SERVER_OPTION_ADDRESSES:
|
||||
irc_server_set_addresses (ptr_server,
|
||||
weechat_config_string (option));
|
||||
irc_server_set_addresses (
|
||||
ptr_server,
|
||||
weechat_config_string (option),
|
||||
IRC_SERVER_OPTION_BOOLEAN(
|
||||
ptr_server, IRC_SERVER_OPTION_TLS));
|
||||
break;
|
||||
case IRC_SERVER_OPTION_TLS:
|
||||
irc_server_set_addresses (
|
||||
ptr_server,
|
||||
IRC_SERVER_OPTION_STRING(
|
||||
ptr_server, IRC_SERVER_OPTION_ADDRESSES),
|
||||
weechat_config_boolean (option));
|
||||
break;
|
||||
case IRC_SERVER_OPTION_NICKS:
|
||||
irc_server_set_nicks (ptr_server,
|
||||
@@ -1006,10 +1016,15 @@ irc_config_server_default_change_cb (const void *pointer, void *data,
|
||||
break;
|
||||
case IRC_SERVER_OPTION_AWAY_CHECK:
|
||||
case IRC_SERVER_OPTION_AWAY_CHECK_MAX_NICKS:
|
||||
if (IRC_SERVER_OPTION_INTEGER(ptr_server, IRC_SERVER_OPTION_AWAY_CHECK) > 0)
|
||||
if (IRC_SERVER_OPTION_INTEGER(
|
||||
ptr_server, IRC_SERVER_OPTION_AWAY_CHECK) > 0)
|
||||
{
|
||||
irc_server_check_away (ptr_server);
|
||||
}
|
||||
else
|
||||
{
|
||||
irc_server_remove_away (ptr_server);
|
||||
}
|
||||
break;
|
||||
case IRC_SERVER_OPTION_REGISTERED_MODE:
|
||||
irc_mode_registered_mode_change (ptr_server);
|
||||
@@ -1280,7 +1295,17 @@ irc_config_server_change_cb (const void *pointer, void *data,
|
||||
irc_server_set_addresses (
|
||||
ptr_server,
|
||||
IRC_SERVER_OPTION_STRING(ptr_server,
|
||||
IRC_SERVER_OPTION_ADDRESSES));
|
||||
IRC_SERVER_OPTION_ADDRESSES),
|
||||
IRC_SERVER_OPTION_BOOLEAN(ptr_server,
|
||||
IRC_SERVER_OPTION_TLS));
|
||||
break;
|
||||
case IRC_SERVER_OPTION_TLS:
|
||||
irc_server_set_addresses (
|
||||
ptr_server,
|
||||
IRC_SERVER_OPTION_STRING(ptr_server,
|
||||
IRC_SERVER_OPTION_ADDRESSES),
|
||||
IRC_SERVER_OPTION_BOOLEAN(ptr_server,
|
||||
IRC_SERVER_OPTION_TLS));
|
||||
break;
|
||||
case IRC_SERVER_OPTION_NICKS:
|
||||
irc_server_set_nicks (
|
||||
|
||||
@@ -80,7 +80,7 @@ char *irc_server_options[IRC_SERVER_NUM_OPTIONS][2] =
|
||||
{ { "addresses", "" },
|
||||
{ "proxy", "" },
|
||||
{ "ipv6", "on" },
|
||||
{ "tls", "off" },
|
||||
{ "tls", "on" },
|
||||
{ "tls_cert", "" },
|
||||
{ "tls_password", "" },
|
||||
{ "tls_priorities", "NORMAL:-VERS-SSL3.0" },
|
||||
@@ -583,24 +583,80 @@ irc_server_get_name_without_port (const char *name)
|
||||
return strdup (name);
|
||||
}
|
||||
|
||||
/*
|
||||
* Gets a string with addresses and ports and TLS option for the server.
|
||||
*
|
||||
* For example if addresses = "irc.example.org,irc2.example.org/7000" and
|
||||
* "tls" option if on, the result is:
|
||||
*
|
||||
* "irc.example.org/6697,irc2.example.org/7000 (TLS: enabled)"
|
||||
*
|
||||
* Note: result must be freed after use.
|
||||
*/
|
||||
|
||||
char *
|
||||
irc_server_get_addresses_ports_tls (struct t_irc_server *server)
|
||||
{
|
||||
char **result, str_port[32], str_tls[256];
|
||||
int i;
|
||||
|
||||
if (!server)
|
||||
return NULL;
|
||||
|
||||
result = weechat_string_dyn_alloc (64);
|
||||
if (!result)
|
||||
return NULL;
|
||||
|
||||
for (i = 0; i < server->addresses_count; i++)
|
||||
{
|
||||
if (i > 0)
|
||||
weechat_string_dyn_concat (result, ", ", -1);
|
||||
weechat_string_dyn_concat (result, server->addresses_array[i], -1);
|
||||
weechat_string_dyn_concat (result, "/", -1);
|
||||
snprintf (str_port, sizeof (str_port), "%d", server->ports_array[i]);
|
||||
weechat_string_dyn_concat (result, str_port, -1);
|
||||
}
|
||||
|
||||
snprintf (str_tls, sizeof (str_tls),
|
||||
" (TLS: %s)",
|
||||
IRC_SERVER_OPTION_BOOLEAN(server, IRC_SERVER_OPTION_TLS) ?
|
||||
_("enabled") : _("disabled"));
|
||||
weechat_string_dyn_concat (result, str_tls, -1);
|
||||
|
||||
return weechat_string_dyn_free (result, 0);
|
||||
}
|
||||
|
||||
/*
|
||||
* Sets addresses for server.
|
||||
*
|
||||
* The "tls" is the boolean value of option ".tls" in server, used to find the
|
||||
* default port if not specified in the address:
|
||||
* - 6697 if tls is 1
|
||||
* - 6667 if tls is 0
|
||||
*
|
||||
* Returns:
|
||||
* 1: addresses have been set (changed)
|
||||
* 0: nothing set (addresses unchanged)
|
||||
*/
|
||||
|
||||
int
|
||||
irc_server_set_addresses (struct t_irc_server *server, const char *addresses)
|
||||
irc_server_set_addresses (struct t_irc_server *server, const char *addresses,
|
||||
int tls)
|
||||
{
|
||||
int i;
|
||||
int rc, i, default_port;
|
||||
char *pos, *error, *addresses_eval;
|
||||
const char *ptr_addresses;
|
||||
long number;
|
||||
|
||||
if (!server)
|
||||
return 0;
|
||||
|
||||
rc = 1;
|
||||
addresses_eval = NULL;
|
||||
|
||||
default_port = (tls) ?
|
||||
IRC_SERVER_DEFAULT_PORT_TLS : IRC_SERVER_DEFAULT_PORT_CLEARTEXT;
|
||||
|
||||
ptr_addresses = addresses;
|
||||
if (ptr_addresses && (strncmp (ptr_addresses, "fake:", 5) == 0))
|
||||
{
|
||||
@@ -618,8 +674,7 @@ irc_server_set_addresses (struct t_irc_server *server, const char *addresses)
|
||||
if (server->addresses_eval
|
||||
&& (strcmp (server->addresses_eval, addresses_eval) == 0))
|
||||
{
|
||||
free (addresses_eval);
|
||||
return 0;
|
||||
rc = 0;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -649,7 +704,7 @@ irc_server_set_addresses (struct t_irc_server *server, const char *addresses)
|
||||
/* set new addresses/ports */
|
||||
server->addresses_eval = addresses_eval;
|
||||
if (!addresses_eval)
|
||||
return 1;
|
||||
return rc;
|
||||
server->addresses_array = weechat_string_split (
|
||||
addresses_eval,
|
||||
",",
|
||||
@@ -673,16 +728,16 @@ irc_server_set_addresses (struct t_irc_server *server, const char *addresses)
|
||||
error = NULL;
|
||||
number = strtol (pos, &error, 10);
|
||||
server->ports_array[i] = (error && !error[0]) ?
|
||||
number : IRC_SERVER_DEFAULT_PORT;
|
||||
number : default_port;
|
||||
}
|
||||
else
|
||||
{
|
||||
server->ports_array[i] = IRC_SERVER_DEFAULT_PORT;
|
||||
server->ports_array[i] = default_port;
|
||||
}
|
||||
server->retry_array[i] = 0;
|
||||
}
|
||||
|
||||
return 1;
|
||||
return rc;
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -696,7 +751,8 @@ irc_server_set_index_current_address (struct t_irc_server *server, int index)
|
||||
|
||||
addresses_changed = irc_server_set_addresses (
|
||||
server,
|
||||
IRC_SERVER_OPTION_STRING(server, IRC_SERVER_OPTION_ADDRESSES));
|
||||
IRC_SERVER_OPTION_STRING(server, IRC_SERVER_OPTION_ADDRESSES),
|
||||
IRC_SERVER_OPTION_BOOLEAN(server, IRC_SERVER_OPTION_TLS));
|
||||
|
||||
if (addresses_changed)
|
||||
{
|
||||
@@ -1659,6 +1715,10 @@ irc_server_alloc (const char *name)
|
||||
|
||||
/* create options with null value */
|
||||
for (i = 0; i < IRC_SERVER_NUM_OPTIONS; i++)
|
||||
{
|
||||
new_server->options[i] = NULL;
|
||||
}
|
||||
for (i = 0; i < IRC_SERVER_NUM_OPTIONS; i++)
|
||||
{
|
||||
length = strlen (new_server->name) + 1 +
|
||||
strlen (irc_server_options[i][0]) +
|
||||
@@ -1707,7 +1767,7 @@ irc_server_alloc (const char *name)
|
||||
* - "pass": password for the server (can be used as nick password on most
|
||||
* servers)
|
||||
* - "server": server address
|
||||
* - "port": port (default is 6667 without TLS and 6697 with TLS)
|
||||
* - "port": port (default is 6697 with TLS, 6667 otherwise)
|
||||
* - "#chan1": channel to auto-join
|
||||
*
|
||||
* Returns pointer to new server, NULL if error.
|
||||
@@ -1743,7 +1803,7 @@ irc_server_alloc_with_url (const char *irc_url)
|
||||
ipv6 = 0;
|
||||
tls = 0;
|
||||
snprintf (default_port, sizeof (default_port),
|
||||
"%d", IRC_SERVER_DEFAULT_PORT);
|
||||
"%d", IRC_SERVER_DEFAULT_PORT_CLEARTEXT);
|
||||
|
||||
pos_server = strstr (irc_url2, "://");
|
||||
if (!pos_server || !pos_server[3])
|
||||
|
||||
@@ -120,9 +120,10 @@ enum t_irc_server_option
|
||||
weechat_config_string(irc_config_server_default[__index]) \
|
||||
: weechat_config_string_default(irc_config_server_default[__index])))
|
||||
|
||||
#define IRC_SERVER_DEFAULT_PORT 6667
|
||||
#define IRC_SERVER_DEFAULT_PORT_TLS 6697
|
||||
#define IRC_SERVER_DEFAULT_NICKS "weechat1,weechat2,weechat3,weechat4,weechat5"
|
||||
#define IRC_SERVER_DEFAULT_PORT_CLEARTEXT 6667
|
||||
#define IRC_SERVER_DEFAULT_PORT_TLS 6697
|
||||
|
||||
#define IRC_SERVER_DEFAULT_NICKS "weechat1,weechat2,weechat3,weechat4,weechat5"
|
||||
|
||||
/* number of queues for sending messages */
|
||||
#define IRC_SERVER_NUM_OUTQUEUES_PRIO 2
|
||||
@@ -333,8 +334,9 @@ extern void irc_server_sasl_get_creds (struct t_irc_server *server,
|
||||
char **key);
|
||||
extern int irc_server_sasl_enabled (struct t_irc_server *server);
|
||||
extern char *irc_server_get_name_without_port (const char *name);
|
||||
extern char *irc_server_get_addresses_ports_tls (struct t_irc_server *server);
|
||||
extern int irc_server_set_addresses (struct t_irc_server *server,
|
||||
const char *addresses);
|
||||
const char *addresses, int tls);
|
||||
extern void irc_server_set_nicks (struct t_irc_server *server,
|
||||
const char *nicks);
|
||||
extern void irc_server_set_nick (struct t_irc_server *server,
|
||||
|
||||
@@ -177,12 +177,97 @@ TEST(IrcServer, GetNameWithoutPort)
|
||||
|
||||
/*
|
||||
* Tests functions:
|
||||
* irc_server_get_addresses_ports_tls
|
||||
* irc_server_set_addresses
|
||||
*/
|
||||
|
||||
TEST(IrcServer, SetAddresses)
|
||||
{
|
||||
/* TODO: write tests */
|
||||
struct t_irc_server *server;
|
||||
char *str;
|
||||
|
||||
POINTERS_EQUAL(NULL, irc_server_get_addresses_ports_tls (NULL));
|
||||
|
||||
server = irc_server_alloc ("server1");
|
||||
|
||||
config_file_option_set (server->options[IRC_SERVER_OPTION_TLS], "off", 1);
|
||||
|
||||
LONGS_EQUAL(0, irc_server_set_addresses (NULL, NULL, 0));
|
||||
LONGS_EQUAL(0, irc_server_set_addresses (NULL, "irc.example.org", 0));
|
||||
|
||||
LONGS_EQUAL(1, irc_server_set_addresses (server, "fake:irc.fake.org", 0));
|
||||
LONGS_EQUAL(1, server->fake_server);
|
||||
STRCMP_EQUAL("irc.fake.org", server->addresses_eval);
|
||||
LONGS_EQUAL(1, server->addresses_count);
|
||||
STRCMP_EQUAL("irc.fake.org", server->addresses_array[0]);
|
||||
LONGS_EQUAL(6667, server->ports_array[0]);
|
||||
LONGS_EQUAL(0, server->retry_array[0]);
|
||||
|
||||
WEE_TEST_STR("irc.fake.org/6667 (TLS: disabled)",
|
||||
irc_server_get_addresses_ports_tls (server));
|
||||
|
||||
LONGS_EQUAL(1, irc_server_set_addresses (server, "irc.example.org", 0));
|
||||
LONGS_EQUAL(0, server->fake_server);
|
||||
STRCMP_EQUAL("irc.example.org", server->addresses_eval);
|
||||
LONGS_EQUAL(1, server->addresses_count);
|
||||
STRCMP_EQUAL("irc.example.org", server->addresses_array[0]);
|
||||
LONGS_EQUAL(6667, server->ports_array[0]);
|
||||
LONGS_EQUAL(0, server->retry_array[0]);
|
||||
|
||||
WEE_TEST_STR("irc.example.org/6667 (TLS: disabled)",
|
||||
irc_server_get_addresses_ports_tls (server));
|
||||
|
||||
LONGS_EQUAL(1,
|
||||
irc_server_set_addresses (
|
||||
server, "irc.example.org,irc2.example.org/6666", 0));
|
||||
LONGS_EQUAL(0, server->fake_server);
|
||||
STRCMP_EQUAL("irc.example.org,irc2.example.org/6666", server->addresses_eval);
|
||||
LONGS_EQUAL(2, server->addresses_count);
|
||||
STRCMP_EQUAL("irc.example.org", server->addresses_array[0]);
|
||||
STRCMP_EQUAL("irc2.example.org", server->addresses_array[1]);
|
||||
LONGS_EQUAL(6667, server->ports_array[0]);
|
||||
LONGS_EQUAL(6666, server->ports_array[1]);
|
||||
LONGS_EQUAL(0, server->retry_array[0]);
|
||||
LONGS_EQUAL(0, server->retry_array[1]);
|
||||
|
||||
WEE_TEST_STR("irc.example.org/6667, irc2.example.org/6666 (TLS: disabled)",
|
||||
irc_server_get_addresses_ports_tls (server));
|
||||
|
||||
config_file_option_set (server->options[IRC_SERVER_OPTION_TLS], "on", 1);
|
||||
|
||||
LONGS_EQUAL(1,
|
||||
irc_server_set_addresses (
|
||||
server, "irc.example.org,irc2.example.org/7000", 1));
|
||||
LONGS_EQUAL(0, server->fake_server);
|
||||
STRCMP_EQUAL("irc.example.org,irc2.example.org/7000", server->addresses_eval);
|
||||
LONGS_EQUAL(2, server->addresses_count);
|
||||
STRCMP_EQUAL("irc.example.org", server->addresses_array[0]);
|
||||
STRCMP_EQUAL("irc2.example.org", server->addresses_array[1]);
|
||||
LONGS_EQUAL(6697, server->ports_array[0]);
|
||||
LONGS_EQUAL(7000, server->ports_array[1]);
|
||||
LONGS_EQUAL(0, server->retry_array[0]);
|
||||
LONGS_EQUAL(0, server->retry_array[1]);
|
||||
|
||||
WEE_TEST_STR("irc.example.org/6697, irc2.example.org/7000 (TLS: enabled)",
|
||||
irc_server_get_addresses_ports_tls (server));
|
||||
|
||||
LONGS_EQUAL(0,
|
||||
irc_server_set_addresses (
|
||||
server, "irc.example.org,irc2.example.org/7000", 1));
|
||||
LONGS_EQUAL(0, server->fake_server);
|
||||
STRCMP_EQUAL("irc.example.org,irc2.example.org/7000", server->addresses_eval);
|
||||
LONGS_EQUAL(2, server->addresses_count);
|
||||
STRCMP_EQUAL("irc.example.org", server->addresses_array[0]);
|
||||
STRCMP_EQUAL("irc2.example.org", server->addresses_array[1]);
|
||||
LONGS_EQUAL(6697, server->ports_array[0]);
|
||||
LONGS_EQUAL(7000, server->ports_array[1]);
|
||||
LONGS_EQUAL(0, server->retry_array[0]);
|
||||
LONGS_EQUAL(0, server->retry_array[1]);
|
||||
|
||||
WEE_TEST_STR("irc.example.org/6697, irc2.example.org/7000 (TLS: enabled)",
|
||||
irc_server_get_addresses_ports_tls (server));
|
||||
|
||||
irc_server_free (server);
|
||||
}
|
||||
|
||||
/*
|
||||
|
||||
Reference in New Issue
Block a user