- Automatically Identifying Using SSL + CertFP
Automatically Identifying Using SSL + CertFP
This page describes how to use SSL with a certificate fingerprint to automatically identify your registered nickname with NickServ on connect. You must have an IRC client that supports SSL with a client certificate.
Creating a Self-signed Certificate
First you need generate a self-signed certificate. We will be using OpenSSL which should be available on most Linux and BSD distributions. There are ports for other platforms including Windows.
Generate the Key and Certificate
We need to generate our certificate and key. We’ll use the openssl command with the ‘req’ option.
The fields you are asked to fill out here do not matter for connecting to OFTC so fill them out however you wish. (You can use other key sizes or types like ed25519 if you want, but the fingerprint digest algorithm used below needs to be SHA-1.) You now have two files, the key in nick.key and the certificate in nick.cer. Remember to protect your key using chmod.
If you are curious, you can have a closer look at your cert. We are mainly interested in the certificate fingerprint (CertFP). (This is not a required step, there are other ways to get the fingerprint.)
We now combine certificate and key to a single file nick.pem (Remember to also protect this file because it now includes your private key!):
Connecting to OFTC with your Cert
Unlisted Clients
If you are using a client that is not listed here feel free to submit a step-by-step howto about it, and we will include it. Either grab a staff member from #oftc or send a mail to our support address support@oftc.net with the information needed. Thank you.
soju
Soju does not use self-generated certificates. Instead, it generates and installs its own for you.
To generate a certificate from within soju, message BouncerServ:
Then all that is left to do is to reconnect:
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
irssi
Move the certificates you created some where safe, for example ~/.irssi/certs.
Now remove the current server and re-add it with the SSL flag, using your newly generated certificate. Note that we use the SSL port 6697 to connect.
Next we need to disconnect and connect back to the server. (A /reconnect does not read the new settings we added.)
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
XChat 2.8
XChat supports SSLv3 only, which is not a modern crypto standard anymore. To connect to OFTC, XChat must be patched. A suggested alternative client is HexChat.
This is known to work with XChat 2.8.x. It does NOT work with prior versions!
Copy the nick.pem file to your .xchat2 directory. The filename must be
<network>.pem
. In our case this should be OFTC.pem. On Windows, the
directory is something like C:\Documents and Settings(user)\Application
Data\X-Chat 2.
Now start up XChat.
We need to tell XChat to connect via SSL to OFTC.
- Go to XChat menu and select Network list/.
- Find OFTC in the list of networks and select edit.
- Check mark ‘Use SSL for all the servers on this network’ and ‘Accept invalid SSL certificate’.
- Click ‘Close’ and then click ‘Connect’.
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
HexChat
Hexchat equals XChat very much. The expected cert path is different, though. The client certificate must be named after the entry in the HexChat network list. In Debian GNU/Linux the preconfigured entry is named “OFTC” (see first screenshot).
- mkdir -p ~/.config/hexchat/certs/
- cat nick.cer nick.key > ~/.config/hexchat/certs/OFTC.pem
- chmod 400 ~/.config/hexchat/certs/OFTC.pem
In the second screenshot you can see the selected SSL options. “Accept invalid SSL certificate” will omit the check of the server certificate (optional).
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
KvIRC
- Go to “Settings -> Configure KvIRC”
- Go to “Connection->advanced”
- On the Tab “SSL” check ‘Use ssl certificate’ and ‘Use SSL private key’ and point both to the nick.pem file you created.
- Change your connection settings and enable the ssl option. Also make sure it is set to connect to port 6697.
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
mIRC
- Go Main Options Menu -> Connect -> Options
- Click on the SSL button
- Click on the empty box below ‘Private Key File’, navigate to where you placed your nick.pem file and select it.
- Do the same for ‘Certificate Chain File’
- Make sure to connect to the network over SSL. The command is ‘/server irc.oftc.net +6697’ - note the plus sign before the port number. This is what sets mIRC to connect over SSL. To save this server with the SSL settings, you can simply add the plus sign before the port number in mIRC’s server manager.
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
ChatZilla
- Convert the key to pkcs12: openssl pkcs12 -export -out nick.pfx -in nick.pem
- Go to the Certificate Manager. You should find that in the Preferences, Advanced Options, Encryption. Select ‘View Certificates’ and there you can import the nick.pfx you just generated
- Now connect to OFTC using SSL and Chat**Zilla asks if you want to use the certificate for authentication. Say yes. (Note that you will have to confirm sending the certificate once for every server you connect to. As irc.oftc.net is a rotation it might ask you later again, don’t be surprised).
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
ZNC
- Follow the instructions found on https://wiki.znc.in/Cert
- This should not be confused with https://wiki.znc.in/Certauth which is used to authenticate your remote client to your instance of znc. You’re trying to authenticate your znc instance with OFTC.
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
Quassel
Quassel settings are stored in ~/.config/quassel-irc.org/ so we can make the certs in ~/.config/quassel-irc.org/certs/ .
In the “Settings -> Configure Quassel “ menu, the “Identities” section, “Advanced” tab contains the interface to indicate the certificate.
- Load the key (~/.config/quassel-irc.org/certs/mynick.key)
- Load the certificate (~/.config/quassel-irc.org/certs/mynick.pem)
- Click OK and re-connect to the network.
You (obviously) need to be using an SSL port for this to work. http://bugs.quassel-irc.org/projects/1/wiki#IRC-Configuration has some detail on server settings interface.
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
Emacs/ERC
Move the certificate you created:
In older version of emacs (23, 24, 25) you could set up the “tls-program” variable with either one of this two options:
On Emacs 26/27 onwards disregard all of the above and just use the snippet of code for your respective Emacs version found at the EmacsWiki.
Then call “M-x erc-tls” and connect to irc.oftc.net, port 6697.
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
WeeChat
Move the certificates you created somewhere safe, for example ~/.config/weechat/certs.
Now disconnect and remove the current server. Re-add it with the TLS flag, using your newly generated certificate. Note that we use the SSL/TLS port 6697 to connect.
Exit WeeChat and connect back to the OFTC server.
/connect OFTC
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
Thunderbird
Convert the key to pkcs12:
Go to the Certificate Manager. You should find that in Edit, Preferences, Advanced, Certificates. Select ‘View Certificates’ and there you can import the nick.p12 you just generated.
Now connect to OFTC using SSL and Thunderbirds asks, if you want to use the certificate for authentication. Say yes. (Note that you will have to confirm sending the certificate once for every server you connect to. As irc.oftc.net is a rotation it might ask you later again, don’t be surprised.)
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
AdiIRC
Step 1 is to create a cert in the options dialog:
Step 2 is to use the client certificate for OFTC setup in your server list:
To continue please scroll down to read how to add your certificates fingerprint to NickServ.
Add your Certificate Fingerprint to your Nick in NickServ
If you did everything right you are now using SSL to connect and should see lines similar to the following in your server window. This will most likely be above the motd so you may have to scroll up a bit to see it.
This tells us that we are now connected via SSL and that our certificate is working.
To allow NickServ to identify you based on this certificate you need to associate the certificate fingerprint with your nick. To do this issue the command cert add to Nickserv (try /msg nickserv help cert). Please note you must be identified for this command to work (/msg nickserv identify).
Nickserv will message back saying that the CertFP was added. Now the only thing left to do is reconnect to the server to test it out.
Congratulations! You now have automatic identification via SSL and certificate fingerprints!
Benefits
You may ask yourself what this gets you now. Well, the answer is simple - you can drop any nickserv identify script you have run in the past. As you are identified with your certificate fingerprint you don’t need them anymore. And by using SSL, your connection to the irc server is now encrypted.
The servers also use encryption for the server<->server traffic, so if you and those you chat with both use ssl encrypted connections - then the whole traffic between you and them is encrypted.
Questions
Ask on #oftc or mail support@oftc.net .
irssi does not join some channels on connect
If you find that irssi does not auto-join channels on connect which want you to be identified before you are joining, add -autosendcmd “wait -oftc 2000” to your irssi network settings. This makes irssi wait 2 seconds before any further action, giving services time to identify you.
(In case you are wondering “/network add” is irssi’s way of modifying existing networks. /network was called /ircnet in older irssi versions.)
Expired SSL certificates
Client certificates need to be valid. This ensures that user certificates remain reasonably cryptographically strong. If you encounter problems connecting with SSL, ensure that your system’s real-time clock is set properly, that your certificate issue date is in the past and that your certificate has not expired.
Renew expired certifcates
If your certificate expired, you can simply create a new certificate and then tell Nickserv about it. If you want, you can also simply extend the validity.
This will first generate a CSR and then use that to reissue the certificate with the same data, and another 10 years of lifetime.
You should now tell Nickserv about the new certificate fingerprint.
Note that some dislike this way, as it reuses the same private key.
Last time I tried ssl connection to an IRC network I experienced a huge lag, is that still to be expected?
No. In the early days of supporting ssl connections there were a few problems, as always when you implement new features. Nowadays, ssl support is very stable and reliable. You wont see any difference to a connection without ssl (except having an encrypted connection, of course). All the network operators and lots of other people are using SSL connections to OFTC as their only way to access the network.