Denis.Russell%newcastle.ac.uk@NSFNET-RELAY.AC.UK (12/20/89)
In this discussion of Kerberos and standards and public-key encryption, etc, there seem to be a whole host of inter-related but fairly separable issues. I am trying to come to an understanding of this area. (I've got the task of coming up with a strategy for secure protocols for the UK academic community. These absolutely must be in line with the emerging standards work, but must also allow us to interwork with our colleagues in the USA.) The main things to understand at the minute are the similarities and differences between the kerberos approach and that embodied not only in X.509, but the other efforts in at least four of the ISO layers (link, network, transport, and application). However, lets not get diverted into the sterile wastes of ISO vs the ARPANET stack - there are other orthogonal issues that are of more fundamental interest. Note that this message is aimed primarily of increasing my own understanding of the issues, and hopefully, perhaps that of other list members. I'm sure I've got hold of the wrong end of the stick in more than one place. --------=============oooooooooo=============------------- 1) Public Key vs private key "in principle". Much is made of the fact that one of a pair of symmetric keys can be "published", and thus much of the key management problem apparently disappears. Unfortunately, when you examine what "publication" involves, the issues become much less clear. For most purposes, most people feel comfortable about the authenticity of the published telephone directory in its familiar paper form. However, as a way of managing encryption keys this has several shortcomings: 1.1) Keys for new people must wait for the next printing. 1.2) Read any book about cryptanalysis and you soon learn that the cardinal rule about keys is to change them completely and often. How often is the "paper key directory" to be printed? 1.3) To accommodate the need for change in telephone numbers beyond that provided by the printed directories some form of online system is oftem provided. In France the PTT has gone a long way towards completely replacing printed directories with an online system (there are other complex reasons in this case that are tangential to this discussion). 1.4) As noted recently on the list, revocation of priviliges (keys) is difficult without electronic management - do you dispatch hoardes of messangers with erasers to delete a key from all the distributed directories that should no longer be used? In thinking about this I have always been lead to the inescapable conclusion that "proper" key management must lead inevitably, at least for a large and growing and dynamic community, to some form of electronic publication. If Electronic publication is necessary, and there is a need for mutual authentication of both the publisher and the client, then both public-key and private-key protocols have, surprisingly, the same complexity (Kline and Popeck, 1979, Needham and Schroeder, 1978). Thus, argue Kline and Popek, public key cryptology offers no advantage in practice because to manage change you still need a server, and once you have a server, private key cryptology is just as good. (If it is not necessary for the client to be authenticated to the server (key-provider) then public-key methods probably still have an edge. I'm not absolutely clear when only one-way authentication is actually useful. Perhaps for truly public data, but I suspect that the vast majority of data is not truly public in this sense but is available only on the payment of some money - like buying a newspaper or some kind of subscription to the information source. For example, my public library will lend me books without charge, but only if they know I am a local resident, and thus fund the library through my local taxes - i.e. I have to authenticate myself to them.) 2) Public keys and "signatures". The use of signatures depends even more than communication and printed directories on the long term integrity of the keys. Any "signature" is valid, only as long as the key has not been compromised. Setting aside any technical doubts, what about attacks along more conventional lines, like hacking into one of the computer systems where keys are stored, "borrowing" smart cards overnight, or the 1001 things nobody has yet thought about? In addition, Tanenbaum has pointed out that the signor of a message could compromise his own key (e.g. get his neighbor's teenage son to post it on a bulletin board), and then "repudiate" all the supposedly "non-repudiatable" (yuck, what a word!) messages that he had issued. I've not seen any suggestion of this in the literature, but again one could imagine that just as one can have trusted "authentication servers", one could also imagine trusted "notary servers". Just as present public key protocols sign messages by encrypting a message digest, the NS could store these message digests (which would presumably also cover useful headers like the time and date, name of issuer, etc) and be prepared to verify them at any later time. Such servers could use either public or private key protocols when verifying or denying authenticity, though the same properties are presumably still required of the digest function. This is not an argument for or against one kind of "signature" over another - it is meant only to point out that here too there seems to be a duality between public-key protocols and trusted servers in which the trust placed in the public key algotithms and keys can be compared with the operationally different but functionally similar trust placed in a specialized server. 3) Number of Algorithms I think that only the RSA algorithm (or mathematically equivalent ones) survives as a public key algorithm. Recently, work by Lenstra cast a shadow on RSA - it has emerged only moderately weakened (I think???), but putting all our cryptographic eggs on one single algorithm sounds less than prudent to me. On the other hand there are many private key algorithms. Despite many years of examination and rumours to the contrary, DES has not been cracked. Recently a "harder" version of DES that is simultaneously more efficient in software has slipped out through a wormhole in space. 4) RSA algorithms are very expensive in computer time. However, much of this can be alleviated by combining slower public key algorithms with faster private key methods. For example, use RSA to send a DES key on the front of a message, and then use the DES key to encrypt the the message proper. 5) RSA is patented in the USA (except for the Government and MIT?). Though individual fees are low, some organizations may have problems either with the large total payment, or any payment at all. In any case, the adoption of anything as an international standard normally requires that it not be proprietary. Recently I have witnessed a heated argument between a representative of RSA Inc and the co-chairman of an IEEE committee on this very point (i.e. if THEY can't agree, I think this list would only be wasting its time discussing this point - just lets note it). Interestingly, this patent apparently only applies WITHIN the USA, and use is free in the rest of the world. RSA Inc still hopes to sell related computer programs outside the USA, but it is not clear to me how this would avoid export embargoes mentioned in the next point. 6) There are problems with exporting certain encryption "devices" from the USA. The situation is complex, but apparently applies to kerberos either with or without DES modules. Does this apply to software produced by RSA Inc, and if not, why not? (Yes, maybe I should read Alice in Wonderland with my daughter over Christmas!) Re-implementing the kerberos protocol may not be too difficult for us foreigners - we are already knee-deep in DES implementations :-) 7) The standards scene seems, quite sensibly, to be allowing any encryption method to be a "parameter" (my word) - that is to be chosen separately. I also believe that the choice of public vs private key methods is also being left as open as possible. The exception seems to be X.509 which is likely to be revised when the rest of the security framework gets filled in. So far so good, but sometime a "functional standard" will have to be chosen, and for open working everyone will have to conform. It is not yet clear to me which way this will go. However, at the Computer Security Applications Conference in Tucson in December, there was a lot of talk about public key cryptology and not much about private keys. (Well, RSA Inc had a very persuasive speaker there, but no-one who was there put the case for servers). In addition, the Final Report of the Protection of Logistics Unclassified/Sensitive Systems (PLUS) has recommended the combination of public-key and DES. Another development that is being widely discussed is the specification of protocols for secure mail enshrined in RFCs 1113 to 1115. RFC 1113 (in line with other standsrds work) is specific neither about encryption algorithm nor about the public vs private question, but RFC 1114 on key management specifies public key methods of key distribution using RSA. References: Kline, C.S. and Popek, G.J. "Public vs. Private Key Encryption" AFIPS Conference Proceedings 48 pp831-837 1979. Needham, R.M. and Schroeder, M.D. "Using Encryption for Authentication in Large Networks of Computers" CACM 21 p993 Dec 1978 Tanembaum, A.S. "Computer Networks" Prentice-Hall International ISBN 0 13 164699 0, 1981 (First ed.) --------=============oooooooooo=============------------- It would seem to me that present "interim" solutions that aim to "intercept" ISO standards appear to be trying to keep their options open, but are tending towards the adoption of public-key, i.e. RSA methods. My reading of the background to this that I have tried to set out in the early part of this message makes me very uneasy. Is my unease justified - i.e. should the "server approach" as best exemplified by Kerberos be trying to influence the standards process more, or is the Kerberos approach just an interesting diversion on the true path to open working which will be supported by RSA-based protocols? Sorry for the long message - A merry Christmas to all, and I look forward to a lively and instructive (and constructive) conversation in the new year!!! Denis Russell JANET: Denis.Russell@uk.ac.newcastle Computing Laboratory ARPA: Denis.Russell@newcastle.ac.uk The University Claremont Road Tel: (+44) 91 222 8243 Newcastle upon Tyne Fax: (+44) 91 222 8232 NE1 7RU Telex: 53 65 4 ENGLAND
galvin@TIS.COM (James M Galvin) (12/20/89)
2) Public keys and "signatures". The use of signatures depends even more than communication and printed directories on the long term integrity of the keys. Any "signature" is valid, only as long as the key has not been compromised. You need to be careful to separate technical issues from business/application issues. In particular, if you extend the paradigm stated in The OSI Directory, "authentication is only valid at the time it occurs", then a signature is only valid at the time it is signed. Your concern about non-repudiation is real, and your solution is typical, but it is not a technical problem in as much as digital signatures are not exactly the same as written signatures. 5) RSA is patented in the USA (except for the Government and MIT?). In any case, the adoption of anything as an international standard normally requires that it not be proprietary. Recently I have witnessed a heated argument between a representative of RSA Inc and the co-chairman of an IEEE committee on this very point (i.e. if THEY can't agree, I think this list would only be wasting its time discussing this point - just lets note it). Please note, RSA has not been adopted as an international standard. The Annex comprising its specification is not an integral part of the standard. I understand this is a minor point, practically speaking, but an important one nonetheless. Further, the Directory Services SIG of the OSI Implementor's Workshop has identified an alternative digital signature algorithm and has created agreements explaining how to use it, for just the reasons you cite. Thus, they are not mandating any particular algorithm and they are going to great pains to be sure there is an option, given the constraints to non-government, US organizations. Jim
rsa@well.UUCP (RSA Data Security) (12/22/89)
The debate over the use of Kerberos vs. RSA has been interesting to observe. I feel that since so many posters have discussed what they see as the cost of RSA, this post is appropriate. Let's at least set the record straight. What has been proposed to both CCITT and to NIST/OSI is a licensing proposal where the cost of using RSA is $2.50 per user *one time*. People are confusing the use of RSA in directory authentication with the cost of a certificate ala RFCs 1113-5, which describe the cost of obtaining a *service* (getting a public key certified, at $25 for a two year certificate) Having a certificate for Internet Privacy Enhanced Mail has nothing (at this time) to do with X.509. All cost assumptions thus far posted are based on information that is 100% wrong. It is not possible to address the differences between digital signatures and Kerberos for authentication here. I would simply suggest that any comparison should be made by someone who understands certificate based key management. If someone really wants to understand what public-key is and how it can be uses *and* how it compares to symmetric systems, I suggest "The First Ten Years ofPublic-key Cryptography," by Whitfield Diffie. It appeared in Preceeding of the IEEE Vol. 76, No. 5, May 1988. It also may be appropriate to ask members of the IAB Privacy Task Force why they chose RSA over Kereberos (even though it costs money). Back to X.509: Note that the $2.50 is typically paid by a vendor building a directory product. Also consider the 1988 recommendations in X.411 (many of which require digital signatures to accomplish) and the $2.50 one time seems quite reasonable. This price has not changed since our original proposal to CCITT in 1984. In the meantime, a large number of companies have licensed RSA and are introducing products that use it (Digital Equipment, Motorola, Lotus, Racal-Milgo, Fischer International, Tektronix, Simpact Associates, etc). Apparently these companies saw a reasonable way to purchase licenses to use RSA; don't knock the process if you haven't tried it. The people who complain the loudest about patents and licenses are the ones who seem to know the least about them. There's an awful lot of "hip shooting" on this subject. Anyone who wants to discuss this further can send me E-Mail. On the "alternative" signature scheme proposed by NIST/OSI: ElGamal is a scheme that requires a license to use (it employs methods covered in the patent on exponential key exchange). Unlike RSA, there is no written guarantee of the cost of using the scheme, yet it is named in the NIST/OSI documents. There is *no* public-key cryptosystem we know of that is *not* patented. RSA is the only one we know of to actually submit licenses with defined costs so that standardization can be considered. Standards allow for the adoption of *patented* technology (proprietary is the wrong term for RSA in *this* case as used by James Galvin; no proprietary issues exist, only patent issues - also the "heated exchange" referred to was over the implications of naming the RSA algorithm in the IEEE 802.10 SILS documents and had nothing to do with proprietary/patent issues). ANSI even states that between 2% and 5% is a "reasonable" royalty for such things. Anyone genuinely interested in understanding these issues should obtain and read the related documents and publications. Finally, the $2.50 amount *came from* CCITT and NIST/OSI. It is not even our number; it is the number the representatives on the standards committees insisted on in 1984 and again in 1989 and which we agreed to! No, I don't think the dollar cost of RSA is the problem. The problems are (1) political and (2) mis and disinformation (our main competitors are apathy and ignorance). While organizations in Europe openly adopt and endorse public-key such as RSA (EFTPOS UK, with an endorsement of RSA by the NPL, or National Physical Laboratory), our own government has been strangely silent in the area of public-key while they seem at the same time to be the largest user. Also, the computer security budget of NIST has been cut by over 3 million dollars. Is electronic privacy and authentication for the most automated society on earth so unimportant that congress (or those advising them) feels compelled to cut the equivalent of 6 minutes of of the annual Defense budget from it? Jim Bidzos, President RSA Data Security, Inc. PS: It may be appropriate to have a newsgroup on X.509 and or the Internet RFC's.
rsa@well.UUCP (RSA Data Security) (12/22/89)
Another often-overlooked possibility is to use Kerberos and RSA together. Kerberos can be used, as it is, for authentication in a given domain, and RSA can be used "on top" of Kerberos for inter-domain authentication by system adminsitrators. This way, users don't even need to be aware of anything but Kerberos. That also reduces the cost to $2.50 per domain.