mirror of
https://github.com/irssi/irssi.git
synced 2025-01-03 14:56:47 -05:00
5146ce9631
This patch adds two new options to /CONNECT and /SERVER to let the user pin either an x509 certificate and/or the public key of a given server. It is possible to fetch the certificate outside of Irssi itself to verify the checksum. To fetch the certificate call: $ openssl s_client -connect chat.freenode.net:6697 < /dev/null 2>/dev/null | \ openssl x509 > freenode.cert This will download chat.freenode.net:6697's TLS certificate and put it into the file freenode.cert. -tls_pinned_cert ---------------- This option allows you to specify the SHA-256 hash of the x509 certificate. When succesfully connected to the server, irssi will verify that the given server certificate matches the pin set by the user. The SHA-256 hash of a given certificate can be verified outside of irssi using the OpenSSL command line tool: $ openssl x509 -in freenode.cert -fingerprint -sha256 -noout -tls_pinned_pubkey ------------------ This option allows you to specify the SHA-256 hash of the subject public key information section of the server certificate. This section contains both the cryptographic parameters for the public key, but also information about the algorithm used together with the public key parameters. When succesfully connected to the server, irssi will verify that the given public key matches the pin set by the user. The SHA-256 hash of a public key can be verified outside of irssi using the OpenSSL command line tool: $ openssl x509 -in freenode.cert -pubkey -noout | \ openssl pkey -pubin -outform der | \ openssl dgst -sha256 -c | \ tr a-z A-Z It is possible to specify both -tls_pinned_cert and -tls_pinned_pubkey together.
48 lines
1.4 KiB
C
48 lines
1.4 KiB
C
/* SERVER_CONNECT_REC definition, used for inheritance */
|
|
|
|
int type; /* module_get_uniq_id("SERVER CONNECT", 0) */
|
|
int chat_type; /* chat_protocol_lookup(xx) */
|
|
|
|
int refcount;
|
|
|
|
/* if we're connecting via proxy, or just NULLs */
|
|
char *proxy;
|
|
int proxy_port;
|
|
char *proxy_string, *proxy_string_after, *proxy_password;
|
|
|
|
unsigned short family; /* 0 = don't care, AF_INET or AF_INET6 */
|
|
char *tag; /* try to keep this tag when connected to server */
|
|
char *address;
|
|
int port;
|
|
char *chatnet;
|
|
|
|
IPADDR *own_ip4, *own_ip6;
|
|
|
|
char *password;
|
|
char *nick;
|
|
char *username;
|
|
char *realname;
|
|
|
|
char *tls_cert;
|
|
char *tls_pkey;
|
|
char *tls_pass;
|
|
char *tls_cafile;
|
|
char *tls_capath;
|
|
char *tls_ciphers;
|
|
char *tls_pinned_cert;
|
|
char *tls_pinned_pubkey;
|
|
|
|
GIOChannel *connect_handle; /* connect using this handle */
|
|
|
|
/* when reconnecting, the old server status */
|
|
unsigned int reconnection:1; /* we're trying to reconnect a connected server */
|
|
unsigned int reconnecting:1; /* we're trying to reconnect any connection */
|
|
unsigned int no_autojoin_channels:1; /* don't autojoin any channels */
|
|
unsigned int no_autosendcmd:1; /* don't execute autosendcmd */
|
|
unsigned int unix_socket:1; /* Connect using named unix socket */
|
|
unsigned int use_tls:1; /* this connection uses TLS */
|
|
unsigned int tls_verify:1;
|
|
unsigned int no_connect:1; /* don't connect() at all, it's done by plugin */
|
|
char *channels;
|
|
char *away_reason;
|