April 30th, 1997 (give or take a few days; remembering exact days can be hard) was the first time Opera's SSL implementation completed a full transaction.
The four months prior to this largely unnoticed (but for Opera significant) event, had been very busy. I had to study and learn about SSL and general cryptography, then do intense design and development work, followed by a lot of testing and debugging.
The SSL support in Opera was my first assignment when I started working at Opera. You might say that I was thrown in at the deep end. The benefit, of course, was that my hands weren't tied by a pre-exisiting design.
Geir1,2, who was then developing the network code, as well as the rendering engine, had been looking at the SSLeay crypto-library (it's now known as OpenSSL), which had an SSL implementation, but hadn't gotten much further than starting to look at the specification and download SSLeay by the time I started at Opera.
After looking at SSLeay's interfaces and code I reached the conclusion that the SSL implementation would not work well with our network code and decided that an independent implementation of the protocol would be better, although I kept SSLeay around for the crypto support, which was independent of the protocol.
A couple of other decisions were:
- Avoid implementing the basic crypto functions myself. It is far too easy to get something wrong in that code, both with respect to performance and correctness (and security). Also, it would take far too long to implement all the necessary functionality. So we used SSLeay for the encryption and certificate support.
- Isolate the encryption and certificate handling code from the rest of the protocol implementation so that we could, if necessary, replace the crypto support library without major changes to the rest of the code.
- Isolate atomic structures as much possible, as well, in object oriented classes, because it made coding easier. This is very easy in C++, and I could do this using techniques I learned during my masters thesis work.
I started by implementing SSL v3, since it was then the most recent definition, and also quite well defined. I still hold the SSL v3 and TLS specifications as some of the best written protocol specifications I have seen (with PKCS #7 and S/MIME as some of the worst ones). SSL v2 I postponed until later.
Implementing something from scratch is hard work, and you often have to backtrack as you find that the current solution design did not work out as expected. But it is, of course, this challenge that is a large part of what attracts many to software development.
After a couple of months, and having integrated the new protocol with the network code, we were ready to make it work.
This also involved a lot of work, and some situations can be a little bizarre. One time I got to the point where I had sent the encrypted keymaterial (used to calculate the encryption keys) to the server, and the server slammed the door in my face (which is what it almost always did when I made a mistake).
All right, that indicated (of course) that something was wrong with the data we sent.
So, I checked that we encrypted correctly, that we encoded the message correctly according to the specification. Everything checks out. OK, let's take a look at what the competition is doing: Huh, it's *not* following the spec?! I test that "method", and it works to get me to the next stage.
I send off an email to the specification authors, and ask what is going on? The answer: It looks like Netscape (who wrote the spec) implemented it wrong in their clients and servers, and so it stuck (but they said TLS 1.0 was going to do it right).
This incident has an amusing follow up story. Almost two years later I was testing against the newest SSLeay development version which was going to support TLS 1.0, and ran into the same problem. I double checked with the TLS spec authors, but the spec had not changed, so I told Eric Young he had made a mistake, and to be sure I had it right he put the question to the TLS work group mailing list, and got the same answer I got.
Finally though, April 30th the code worked well enough that we could actually get a web page back.
The implementation was by no means finished, and work would continue for the rest of the year to get the SSL implementation into a shape fit to be shipped in Opera 3.0. But just to "round" that day off, I spent two or three hours implementing the TLS 1.0 version, even though I wasn't able to test it until early 1999, at which time it took just a week to get it working properly and mostly ready for Opera 3.50.
The SSL implementation wasn't static (and still isn't). Work on improving it continued, and is continuing:
- In 1999 we added TLS 1.0 support, as one of the first clients to do so.
- A while ago I started a complete rewrite of the protocol control engine
because I was encountering more trouble with adding new functionaliy. Part of what I did was to take the design methods I had used earlier and go even further along that route (I get the impression a few colleagues would say I went too far ;), I suspect they just got caught up in the details). This new engine became active in 9.0. - We have regularly updated the version of SSLeay and later OpenSSL, although the first major upgrade was the worst, due to the major internal changes in the certificate system made in the 0.8.x compared to the 0.6.x version we were using at the time.
- We have added new encryption methods as they became available.
- We have improved the security related information we show users.
- We were among the first (if not the first) to deploy a client supporting TLS 1.1 and TLS Extensions, in fact so early we had to disable it and develop a workaround before we could enable it by default (I actually got a question from Microsoft :), about them having the same problems with TLS Extensions that we had).
What is in the future of Opera's SSL/TLS implementation?
- We are adding support for Extended Validation certificates.
- There are some big changes coming in the certificate management system.
- In Kestrel we are planning to completely remove support for SSL v2 and the weak 40 and 56 bit ciphers.
Some may wonder why we are still using our own implementation of SSL and TLS when there are several implementations around. After all, some of the original reasons for the choice no longer exist.
Well, while we do use other implementations on some platforms, for technological reasons, one major reason is that it gives us more control of what functionality we support. For example, we implemented TLS 1.1 and TLS Extension 3 years ago, and we are actually still the only major TLS 1.1 client around, and other TLS Extension clients did not show up until second half of 2006 (although that is a chicken and egg situation). We are also more at liberty to integrate the code better with our own processes and techniques.
Having our own implementation also makes it easier to move the functionality to a new platform, although Open Source implementations have the same benefit.
Another reason may be a bit more philosophical, as Opera's engine is one of only four major SSL/TLS clients deployed, and at least two of the other three are also developed with the server side. This means that Opera's client may be able to keep the others from implementing mistakes that then get turned into de-facto standards (which is what happened with the above mentioned specification). Diversity is what will keep the net working.
But, that question is also similar to a few other questions: Why develelop our own HTML parser, webpage rendering engine, our own browser, and so on? In this context, another obvius reason becomes clear, we think we can implement these things better ourselves.
Although we have hit the occasional troublespot, I think (if I may be so bold) that the design I chose in 1997 has worked out quite well. While there has been some big changes in parts, the basic design and functionality of Opera's SSL implementation are still quite similar to the original implementation.
Happy anniversary and good luck with the next 10 years! 🙂
Happy birthday to your Opera SSL baby.
Very enlightening, Ygnve. :)It’s always very interesting to hear about the components of Opera that don’t otherwise get too much recognition.
Can you tell us a bit more about the SSL implementation for Opera Mini ?Also, should the user get a prompt to accept/install/review “suspicious” certificates ? As far as I can see, pages reported secure (Tools > Page Information > Security; I guess that just means it uses e.g TLS v1.0 256 bit AES) can show a crossed, grayed, padlock on the top to signify some certificate problem, but not much else.
Hi there,you forgot something..What is about the new TLS protocol version 1.2?!?I think you will implement this version into an upcoming Opera Version soon, or not?TLS 1.2 uses better encryption methods, like ECC (Elliptic curve cryptographie/ciphers), etc. :)best regards,tmfo
TLS 1.2 is still very much in the early stages of development, and will probably not be ready for a while. I expect that there may be some changes as people notice problems with the new features, and the new random number calculation method is still being discussed.I know there are a couple of experimental implementations, but have not yet decided if I am going to implement one, but considering how I designed our engine I don’t expect major problems with the new ways of doing things in TLS 1.2.As far as ECC is concerned that is defined for TLS 1.0 already, see http://www.ietf.org/rfc/rfc4492.txt if you are interested.I have been considering support, but have not yet studied the ECC method enough to be sure I’d do it right, and I’ve also not had time to study the patent encumberments (there are quite a few), and what the patentholder have told the IETF about licenses being needed (there was quite a heavy debate about that message at one of the meetings at the Spring-2006 IETF meeting in Dallas, and I am not at all sure what the conclusion was).One thing that may be needed for ECC is a lot of new root certificates.
Regarding SSL in Opera Mini, see the FAQ on the Opera Mini site:http://www.operamini.com/help/faq/#encyption
Hi there,ok thanks for your answer and update :)But it’s a shame to use 256 bit AES symmetric encryption, but only 1024 or 2048 bit asymmetric key..For an 256 bit symmetric key you should use at least 4096 or better 8192 bit asymmetric encryption key, or the security of the symmetric part is compromised because the public key part isn’t strong enough..!And because 8192 bit and bigger keys are not that fast to compute, ECC is a better solution, because you need much fewer key sizes for that and thus computing of these key sizes is faster.Here some FAQ of ECC:http://www.certicom.com/index.php?action=ecc,ecc_faqBtw. Certicom own some patents for ECC..And on this linked webpage you can see that the NIST guidelines/recommendations are even stronger and recommend higher/bigger key sizes (15,360 bit RSA public key size for 256 bit AES symmetric key size..!).Links with more info about ECC:http://www.secg.org/http://research.sun.com/projects/crypto/http://www.cacr.math.uwaterloo.ca/ (ECC Workshops and more)best regards,tmfo
Happy birthday to Opera SSLAnd talking about Opera Mini – is phone with an Internet connection and Java enough to use it?Regards,Duncan
I’ve been using SSL extensively for the past few years but I haven’t got the idea that it was already 10 years old. Well, happy anniversary then!
Beyond any doubt Opera SSL is a great design and the one I have to use very much in my work. I’m really happy that it exists for so long and it still hasn’t been replaced by a newer solution.
Is there any plan to support S/MIME in the Opera e-mail client? It would be pretty cool if I could sign and encrypt e-mails in Opera like is possible in Thunderbird and Apple Mail.
😎 Wasn’t Opera also one of the first to be able to use TLS 1.2
i always use opera mini for SSL connection, because my direct connection cannot browse through the SSL 😀