summary refs log tree commit diff
path: root/chat.c
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2018-08-02 23:59:41 -0400
committerJune McEnroe <june@causal.agency>2018-08-02 23:59:41 -0400
commitd3e90b6cf288ba3de2fc0e68054b4312a976b2e3 (patch)
tree347f5fb397880640414c0bf08f1ca76edd8a6476 /chat.c
parentAdd UI and handle some kinds of server messages (diff)
downloadcatgirl-d3e90b6cf288ba3de2fc0e68054b4312a976b2e3.tar.gz
catgirl-d3e90b6cf288ba3de2fc0e68054b4312a976b2e3.zip
Use libtls "compat" ciphers
irc.mozilla.org, using GnuTLS, doesn't support *any* of the "secure"
ciphers!
Diffstat (limited to '')
-rw-r--r--chat.c23
1 files changed, 13 insertions, 10 deletions
diff --git a/chat.c b/chat.c
index 0b1826a..4955b4b 100644
--- a/chat.c
+++ b/chat.c
@@ -60,6 +60,8 @@ static void uiInit(void) {
 	ui.input = newwin(2, COLS, LINES - 2, 0);
 	mvwhline(ui.input, 0, 0, ACS_HLINE, COLS);
 	wmove(ui.input, 1, 0);
+	cbreak();
+	noecho();
 }
 
 static void uiDraw(void) {
@@ -322,13 +324,22 @@ int main(int argc, char *argv[]) {
 		client.nick = strdup(buf);
 	}
 	erase();
-	cbreak();
-	noecho();
 
 	uiInit();
 	uiChat("=== Traveling...");
 	uiDraw();
 
+	struct tls_config *config = tls_config_new();
+	error = tls_config_set_ciphers(config, "compat");
+	if (error) errx(EX_SOFTWARE, "tls_config: %s", tls_config_error(config));
+
+	client.tls = tls_client();
+	if (!client.tls) errx(EX_SOFTWARE, "tls_client");
+
+	error = tls_configure(client.tls, config);
+	if (error) errx(EX_SOFTWARE, "tls_configure");
+	tls_config_free(config);
+
 	struct addrinfo *ai;
 	struct addrinfo hints = {
 		.ai_family = AF_UNSPEC,
@@ -345,14 +356,6 @@ int main(int argc, char *argv[]) {
 	if (error) err(EX_UNAVAILABLE, "connect");
 	freeaddrinfo(ai);
 
-	client.tls = tls_client();
-	if (!client.tls) errx(EX_OSERR, "tls_client");
-
-	struct tls_config *config = tls_config_new();
-	error = tls_configure(client.tls, config);
-	if (error) errx(EX_OSERR, "tls_configure");
-	tls_config_free(config);
-
 	error = tls_connect_socket(client.tls, client.sock, host);
 	if (error) err(EX_PROTOCOL, "tls_connect");
 
'nohover-highlight'> 2018-03-05Generate tagsJune McEnroe 2017-10-03Simplify Makefile with pattern ruleJune McEnroe Insert rant about how GNU make handles the .c rule with extra dependencies. Also I don't care that everything links curses now. 2017-09-27Remove leading blank linesJune McEnroe 2017-09-27Add merge.c to READMEJune McEnroe 2017-09-03Assert client coords are valid after movementJune McEnroe 2017-09-03Relicense AGPLJune McEnroe I know it's already published under a permissive license in what is probably its final form, but I want to license it AGPL anyway on principle following some conversations I had about open source, corporations and copyleft. 2017-09-01Revert "Add client readOnly mode"June McEnroe This reverts commit 34f25ae40a3db9369e9d98b3814f2b93bbc21451. 2017-09-01Remove clientRemove call from clientCastJune McEnroe If an error occurs on a client socket during a broadcast, that client will show up in the kqueue loop with EV_EOF and get removed that way. Tested by sending SIGKILL to a client and watching its cursor disappear. 2017-09-01Add client readOnly modeJune McEnroe 2017-08-31Clean up merge toolJune McEnroe Choose the version with the most recent access if the modify times are the same. 2017-08-31Choose B for tiles with equal modify timesJune McEnroe This way newer access counts and times will be preserved. 2017-08-31Add quick data file merge toolJune McEnroe Hopefully I won't have to use it ever again. 2017-08-30Use only foreground color for selecting spawnJune McEnroe 2017-08-29Add four additional spawnsJune McEnroe 2017-08-28Add respawningJune McEnroe 2017-08-26Move license above includesJune McEnroe Why was it down there? 2017-08-26Snapshot metadataJune McEnroe 2017-08-26Add meta.c to READMEJune McEnroe 2017-08-26Use MakefileJune McEnroe