USRE35808E - Fair cryptosystems and methods of use - Google Patents
Fair cryptosystems and methods of use Download PDFInfo
- Publication number
- USRE35808E USRE35808E US08/526,977 US52697795A USRE35808E US RE35808 E USRE35808 E US RE35808E US 52697795 A US52697795 A US 52697795A US RE35808 E USRE35808 E US RE35808E
- Authority
- US
- United States
- Prior art keywords
- user
- secret key
- trustees
- key
- entity
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime
Links
- 238000000034 method Methods 0.000 title claims abstract description 49
- 238000004891 communication Methods 0.000 claims abstract description 55
- 230000000694 effects Effects 0.000 claims abstract description 21
- 230000003993 interaction Effects 0.000 claims abstract description 7
- 238000012544 monitoring process Methods 0.000 claims 6
- 230000008901 benefit Effects 0.000 description 6
- 230000008569 process Effects 0.000 description 3
- 238000010200 validation analysis Methods 0.000 description 3
- 238000012795 verification Methods 0.000 description 3
- 230000008859 change Effects 0.000 description 2
- 230000001010 compromised effect Effects 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 230000008520 organization Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04K—SECRET COMMUNICATION; JAMMING OF COMMUNICATION
- H04K1/00—Secret communication
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/02—Payment architectures, schemes or protocols involving a neutral party, e.g. certification authority, notary or trusted third party [TTP]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/382—Payment protocols; Details thereof insuring higher security of transaction
- G06Q20/3829—Payment protocols; Details thereof insuring higher security of transaction involving key management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/389—Keeping log of transactions for guaranteeing non-repudiation of a transaction
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/40—Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
- G06Q20/403—Solvency checks
-
- G—PHYSICS
- G07—CHECKING-DEVICES
- G07F—COIN-FREED OR LIKE APPARATUS
- G07F17/00—Coin-freed apparatus for hiring articles; Coin-freed facilities or services
- G07F17/32—Coin-freed apparatus for hiring articles; Coin-freed facilities or services for games, toys, sports, or amusements
- G07F17/3241—Security aspects of a gaming system, e.g. detecting cheating, device integrity, surveillance
-
- G—PHYSICS
- G07—CHECKING-DEVICES
- G07F—COIN-FREED OR LIKE APPARATUS
- G07F7/00—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus
- G07F7/08—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means
- G07F7/10—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means together with a coded signal, e.g. in the form of personal identification information, like personal identification number [PIN] or biometric data
- G07F7/1016—Devices or methods for securing the PIN and other transaction-data, e.g. by encryption
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0816—Key establishment, i.e. cryptographic processes or cryptographic protocols whereby a shared secret becomes available to two or more parties, for subsequent use
- H04L9/085—Secret sharing or secret splitting, e.g. threshold schemes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/321—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving a third party or a trusted authority
Definitions
- the present invention relates generally to cryptosystems and more particularly to methods for enabling a given entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users.
- double-key cryptosystem the process of encrypting and decrypting is instead governed by different keys. In essence, one comes up with a pair of matching encryption and decryption keys. What is encrypted using a given encryption key can only be decrypted using the corresponding decryption key. Moreover, the encryption key does not "betray" its matching decryption key. That is, knowledge of the encryption key does not help to find out the value of the decryption key.
- double-key systems is that they can allow two parties who have never safely exchanged any key to privately communicate over an insecure communication line (i.e., one that may be tapped by an adversary). They do this by executing an on-line, private communication protocol.
- Party A alerts Party B that he wants to talk to him privately.
- Party B then computes a pair of matching encryption and decryption keys (E B , D B ). B then sends A key E B .
- a main disadvantage is that any such system can be abused, for example, by terrorists and criminal organizations who can use their own PKC (without knowledge of the authorities) and thus conduct their illegal business with great secrecy and yet with extreme convenience.
- the trustees Upon a predetermined request or condition, e.g., a court order authorizing the entity to monitor the communications of a user suspected of unlawful activity, the trustees reveal to the entity the shares of the secret key of such user to enable the entity to reconstruct the secret key and monitor the suspect user's communications.
- a predetermined request or condition e.g., a court order authorizing the entity to monitor the communications of a user suspected of unlawful activity
- the method can be carried out whether or not the identity of the suspect user is known to the trustees, and even if less than all of the shares of the suspect user's secret key are required to be revealed in order to reconstruct the secret key.
- the method is robust enough to be effective if a given minority of trustees have been compromised and cannot be trusted to cooperate with the entity.
- the suspect user's activities are characterized as unlawful if the entity, after reconstructing or having tried to reconstruct the secret key, is still unable to monitor the suspect user's communications.
- FIG. 1 is a simplified diagram of a communications system over which a government entity desires to monitor communications of users suspected of unlawful activities;
- FIG. 1 represents a simple communications system 10 comprising a telephone network connected between a calling station 12 and a called station 14.
- One or more local central offices or telephone switches 16 connect telephone signals over the network in a well-known fashion.
- a government entity such as local law enforcement agency 18, desires to monitor communications to and/or from calling station 12 because the user of such calling station is suspected of unlawful activity.
- the user of the calling station 12 communicates using a PKC.
- the agency 18 obtains a court order from court 20 to privately monitor the line 15.
- the agency's is able to monitor the line 15 while at the same time the privacy rights of other law-abiding users of the network are maintained. This is accomplished as will be described by requiring that each user "secret share" the user's secret key (of the PKC) with a plurality of trustees 22a . . . 22n.
- a "fair" PKC is a special type of public-key cryptosystem. Every user can still choose his own keys and keep secret his private one; nonetheless, a special agreed-upon party (e.g., the government), and solely this party, under the proper circumstances envisaged by the law (e.g., a court order), and solely under these circumstances, is authorized to monitor all messages sent to a specific user.
- a fair PKC improves the security of the existing communication systems (e.g., the telephone service 10) while remaining within the constraints of accepted legal procedures.
- fair PKC's are constructed in the following general way. Referring now to FIGS. 1-2, it is assumed that there are five (5) trustees 22a . . . 22e and that the government desires, upon receiving a court order, to monitor the telephone communications to or from the calling station 12.
- users of the communications system and trustees may be people or computing devices. It is preferable that the trustees are chosen to be trustworthy. For instance, they may be judges (or computers controlled by them), or computers specially set up for this purpose.
- Each user independently chooses his own public and secret keys according to a given double-key system (for instance, the public key consists of the product of two primes, and the secret key one of these two primes). Since the user has chosen both of his keys, he can be sure of their "quality" and of the privacy of his decryption key. He then breaks his secret decryption key into five special "pieces" (i.e., he computes from his decryption key 5 special strings/numbers) possessing the following properties:
- the i-th special piece can be individually verified to be correct.
- property (3) insures that each special piece can be verified to be correct (i.e., that together with the other 4 special pieces it yields the private key) individually, i.e., without knowing the secret key at all and without knowing the value of any of the other special pieces.
- trustee 22i his own public key and the i-th piece of its associated secret key.
- Each trustee 22 individually inspects his received piece, and, if it is correct, approves the public key (e.g. signs it) and safely stores the piece relative to it.
- These approvals are given to a key management center 24, either directly by the trustees, or (possibly in a single message) by the individual user who collects them from the trustees.
- the center 24, which may or may not coincide with the government, itself approves (e.g., signs) any public key that is approved by all trustees.
- These center-approved keys are the public keys of the fair PKC and they are distributed and used for private communication as in an ordinary PKC.
- the government Upon receiving the shares, the government reconstructs the given decryption key.
- each trustee previously verified whether he was given a correct special piece of a given decryption key.
- every public key was authorized by the key management center 24 only if it was approved by all trustees 22.
- the government is guaranteed that, in case of a court order, it will be given all special pieces of any decryption key.
- property (1) this is a guarantee that the government will be able to reconstruct any given decryption key if necessary to monitor communications over the network.
- User X computes Sxy by raising Y's public key to his private key mod pX, and user Y by raising X's public key to his secret key mod p. In fact:
- Each user X randomly chooses 5 integers Sx1, . . . Sx5 in the interval 1, p-1! and lets Sx be their sum mod p. It should be understood that all following operations are modulo p. User X then computes the numbers:
- Px will be User X's public key and Sx his private key.
- the ti's will be referred to as the public pieces of Px, and the Sxi's as the private pieces. It should be noted that the product of the public pieces equals the public key Px. In fact:
- T1, . . . T5 be the five trustees.
- User X now gives Px, the public pieces and Sx1 to trustee T1, Px, the public pieces and Sx2 to trustee T2, and so on.
- Piece Sxi is privately given to trustee Ti.
- the key management center Upon receiving all the signed sequences relative to a given public key Px, the key management center verifies that these sequences contain the same subsequence of public pieces t1 . . . t5 and that the product of the public pieces indeed equals Px. If so, center 24 approves Px as a public key and distributes it as in the original scheme (e.g., signs it and gives it to user X).
- the encryption and decryption instructions for any pair of users X and Y are exactly as in the Diffie and Hellman scheme (i.e., with common, secret key Sxy).
- the key management center validates the public key Px, then its private key is guaranteed to be reconstructable by the government in case of a court order.
- the center receives all 5 public pieces of Px, each signed by the proper trustee. These signatures testify that trustee Ti possesses the discrete logarithm of public piece ti. Since the center verifies that the product of the public pieces equals Px, it also knows that the sum of the secret pieces in storage with the trustees equals the discrete logarithm of Px; i.e, user X's private key. Thus the center knows that, if a court order were issued requesting the private key of X, the government is guaranteed to obtain the needed private key by summing the values received by the trustees.
- the public key consists of an integer N product of two primes and one exponent e (relatively prime with f(N), where F is Euler's quotient function). No matter what the exponent, the private key may always be chosen to be N's factorization.
- the RSA scheme has certain characteristics that derive from aspects of number theory:
- the trustees are privately provided information that, perhaps together with other given common information, enables one to reconstruct two (or more) square roots x and y (x different from ⁇ y mod N) of a common square mod N.
- the given common information may be the -1 Jacobi symbol root of X 2 , which is equal to y.
- the product of the last 5 squares, Z is itself a square.
- One square root of Z mod N is X, which has Jacobi symbol equal to 1 (since the Jacobi symbol is multiplicative).
- the user computes Y, one of the Jacobi -1 roots mod N. X 1 , . . .
- X 5 will be the public pieces of public key N and the X i 's the private pieces.
- the user gives trustee Ti private piece X i (and possibly the corresponding public piece, all other public pieces and Px, depending on whether it is desired that the verification of the shares so as to satisfy properties (1)-(3) is performed by both trustees and the center, or the trustees alone).
- Trustee Ti squares Xi mod N gives the key management center his signature of X i 2 , and stores X i .
- the center Upon receiving the valid signature of the public pieces of N and the Jacobi -1 value Y from the user, the center checks whether mod N the square of Y equals the product of the five public pieces. If so, it checks, possibly with the help of the user, that N is the product of two prime powers. If so, the center approves N.
- Y is different from X since it has different Jacobi symbol
- Possession of such square roots, by Facts 1 and 2 is equivalent to having the factorization of N, provided that N is product of at most two prime powers. This last property has also been checked by the center before it has approved N.
- Verification that N is the product of at most two prime powers can be performed in various ways.
- the center and user can engage in a zero-knowledge proof of this fact.
- the user may provide the center with the square root mod N for roughly 1/4 of the integers in a prescribed and random enough sequence of integers. For instance, such a sequence could be determined by one-way hashing N to a short seed and then expanding it into a longer sequence using a psuedo-random generator. If a dishonest user has chosen his N to be the product of three or more prime powers, then it would be apparently for him to hope that roughly 1/4of the integers in the sequence are squares mod N. In fact, for his choice of N, at most 1/8 of the integers have square roots mod N.
- the above schemes can be modified in many ways. For instance, the proof that N is product of two prime powers can be done by the trustees (in collaboration with the user), who then inform the center of their findings. Also, the scheme can be modified so that the cooperation of the majority of the trustees is sufficient for reconstructing the secret key, while any minority cannot gain any information about the secret key. Also, as with all fair cryptosystems, one can arrange that when the government asks a trustee for his piece of the secret key of a user, the trustee does not learn about the identity of the user. The variations are discussed in more detail below.
- the schemes described above are robust in the sense that some trustees, accidentally or maliciously, may reveal the shares in their possession without compromising the security of the system.
- these schemes rely on the fact that the trustees will collaborate during the reconstruction stage. In fact, it was insisted that all of the shares should be needed for recovering a secret key. This requirement may be disadvantageous, either because some trustees may reveal to be untrustworthy and refuse to give the government the key in their possession, or because, despite all file backups, the trustee may have genuinely lost the information in its possession. Whatever the reason, in this circumstance the reconstruction of a secret key will be prevented. This problem is also solved by the present invention.
- secret sharing (with parameters n,T,t) is a prior cryptographic scheme consisting of two phases: in phase one a secret value chosen by a distinguished person, the dealer, is put in safe storage with n people or computers, the trustees, by giving each one of them a piece of information. In phase two, when the trustees pool together the information in their possession, the secret is recovered.
- Secret sharing has a major disadvantage--it presupposes that the dealer gives the trustees correct shares (pieces of information) about his secret value.
- "Verifiable Secret Sharing” (VSS) solves this "honesty" problem.
- each trustee can verify that the share given to him is genuine without knowing at all the shares of other trustees of the secret itself. Specifically, the trustee can verify that, if T verified shares are revealed, the original secret will be reconstructed, no matter what the dealer or dishonest trustees might do.
- the tiabc's will be referred to as public pieces of Px, and the Siabc's as private pieces. Again, the product of the public pieces equals the public key Px. In fact,
- trustee Ta gives trustee Ta t1abc and S1abc, trustee Tb t2abc and S2abc, and trustee Tc t3abc and S3abc, always specifying the triplet in question.
- trustee Ta all other trustees do something similar
- t1abc g S1abc
- signs the value Px, t1abc, (a,b,c)
- the key management center for each triple (a,b,c), retrieves the values t1abc, t2abc and t3abc from the signed information received from trustees, Ta, Tb and Tc. If the product of these three values equals Px and the signatures are valid, the center approves Px as a public key.
- the center Since the center does not know the factorization of the Ni's, this is not useful information to predict Sx, nor can the center verify that the decryption of the n ciphertexts are proper shares of Sx. For this, the center will seek the cooperation of the n trustees, but without informing them of the identity of the user as will be described.
- the center stores the values tj's and Uj's relative to user U and then forwards Ui and ti to trustee Ti. If every trustee Ti verified that the decryption of Ui is a proper private piece relative to ti, the center approves Px.
- the ei-th root of zi is the product mod Ni of the ei-th root of Ui (i.e., Sxi) and the ei-th root of yi (i.e., Ri).
- the judge divides it by yi mod Ni, thereby computing the desired Sxi.
- the product of these Sxi's equals the desired Sx.
- the government in case of a court order, the government is only authorized to understand the messages concerning a given user for a limited amount of time.
- the collective approval of all trustees may stand for the government approval.
- trustees need not store their piece of the private key.
- the basic process of key selection and public-key validation can be done before the device leaves the factory.
- a "copy" of the trustee can be maintained within the factory.
- a copy of a trustee is a physically secure chip--one whose data cannot be read--containing a copy of the trustee's decryption key.
- the trustee i.e., the party capable of giving the piece of a private key under a court order
- each user's private key is encrypted with the public key of the government.
- a fair PKC can be used in private organizations as well. For example, in a large organization where there is a need for privacy, assume there is an established "superior" but not all employees can be trusted since there are too many of them. The need for privacy requires the use of encryption. Because not all employees can be trusted, using a single encryption key for the whole company is unacceptable, as is using a number of single-key cryptosystems (since this would generate enormous key-distribution problems). Having each employee use his own double-key system is also dangerous, since he or she might conspire against the company with great secrecy, expediity and convenience.
- each trustee first deposits an encrypted version or otherwise committed version of his share, so that, when he is asked to reveal what his share was, he cannot change his mind about its value.
- the user gives his shares to the trustees signed; such signatures can be relative to a different public key (if they are digital signatures) or to the same new public key if the new key can be used for signing as well.
- the share revealed by the trustee clearly proves that it way originated.
- the user may sign (with the trustee's key) the encryption of the share given to a trustee, and the signature can be revealed together with the share. This approach insures that one can both be certain that what was revealed was a share approved by the user and also that the trustees and the user cannot collaborate later on in changing its value.
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Computer Security & Cryptography (AREA)
- Accounting & Taxation (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Finance (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- General Engineering & Computer Science (AREA)
- Storage Device Security (AREA)
- Computer And Data Communications (AREA)
- Mobile Radio Communication Systems (AREA)
- Burglar Alarm Systems (AREA)
- Prostheses (AREA)
- Nitrogen And Oxygen Or Sulfur-Condensed Heterocyclic Ring Systems (AREA)
- Adornments (AREA)
Abstract
A method, using a public-key cryptosystem, for enabling a predetermined entity to monitor communications of users . .suspected of unlawful activities while protecting the privacy of law-abiding users.!., wherein each user is assigned a pair of matching secret and public keys. According to the method, each user's secret key is broken into shares. Then, each user provides a plurality of "trustees" pieces of information. The pieces of information provided to each trustee enable that trustee to verify that such information includes a "share" of a secret key of some given public key. Each trustee can verify that the pieces of information provided include a share of the secret key without interaction with any other trustee or by sending messages to the user. Upon a predetermined request or condition, e.g., a court order authorizing the entity to monitor the communications of a user . .suspected of unlawful activity.!., the trustees reveal to the entity the shares of the secret key of such user. This enables the entity to reconstruct the secret key and monitor the . .suspect.!. user's communications.
Description
The present invention relates generally to cryptosystems and more particularly to methods for enabling a given entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users.
In a single-key cryptosystem a common secret key is used both to encrypt and decrypt messages. Thus only two parties who have safely exchanged such a key beforehand can use these systems for private communication. This severely limits the applicability of single-key systems.
In a double-key cryptosystem, the process of encrypting and decrypting is instead governed by different keys. In essence, one comes up with a pair of matching encryption and decryption keys. What is encrypted using a given encryption key can only be decrypted using the corresponding decryption key. Moreover, the encryption key does not "betray" its matching decryption key. That is, knowledge of the encryption key does not help to find out the value of the decryption key. The advantage of double-key systems is that they can allow two parties who have never safely exchanged any key to privately communicate over an insecure communication line (i.e., one that may be tapped by an adversary). They do this by executing an on-line, private communication protocol.
In particular, Party A alerts Party B that he wants to talk to him privately. Party B then computes a pair of matching encryption and decryption keys (EB, DB). B then sends A key EB. Party A now encrypts his message m, obtaining the ciphertext c=EB (m), and sends c to B over the insecure channel. B decrypts the ciphertext by computing m=DB (c). If an adversary eavesdrops all communication between A and B, he will then hear both B's encryption key, EB, and A's ciphertext, c. However, since the adversary does not know B's decryption key, DB, he cannot compute m from c.
The utility of the above protocol is still quite limited since it suffers from two drawbacks. First, for A to send a private message to B it is necessary also that B send a message to A, at least the first time. In some situations this is a real disadvantage. Moreover, A has no guarantee (since the line is insecure anyway) that the received string DB really is B's encryption key. Indeed, it may be a key sent by an adversary, who will then understand the subsequent, encrypted transmission.
An ordinary public-key cryptosystem ("PKC") solves both difficulties and greatly facilitates communication. Such a system essentially consists of using a double-key system in conjunction with a proper key management center. Each user X comes up with a pair of matching encryption and decryption keys (EX, DX) of a double-key system. He keeps DX for himself and gives EX to the key management center. The center is responsible for updating and publicizing a directory of correct public keys for each user, that is, a correct list of entries of the type (X, EX). For instance, upon receiving the request from X to have EX as his public key, the center properly checks X's identity, and (digitally) signs the pair (X, EX), together with the current date if every encryption key has a limited validity. The center publicizes EX by distributing the signed information to all users in the system. This way, without any interaction, users can send each other private messages via their public, encryption key that they can look up in the directory published by the center. The identity problem is also solved, since the center's signature of the pair (X, EX) guarantees that the pair has been distributed by the center, which has already checked X's identity.
The convenience of a PKC depends on the key management center. Because setting up such a center on a grand scale requires a great deal of effort, the precise protocols to be followed must be properly chosen. Moreover, public-key cryptography has certain disadvantages. A main disadvantage is that any such system can be abused, for example, by terrorists and criminal organizations who can use their own PKC (without knowledge of the authorities) and thus conduct their illegal business with great secrecy and yet with extreme convenience.
It would therefore be desirable to prevent any abuse of a public key cryptosystem while maintaining all of its lawful advantages.
It is an object of the present invention to provide methods for enabling a given entity, such as the government, to monitor communications of users suspected of unlawful activities while at the same time protecting the privacy of law-abiding users.
It is a further object of the invention to provide such methods using either public or private key cryptosystems.
It is a still further object of the invention to provide so-called "fair" cryptosystems wherein an entity can monitor communications of suspect users only upon predetermined occurrences, e.g., the obtaining of a court order.
It is another object to describe methods of constructing fair cryptosystems for use in such communications techniques.
In one embodiment, these and other objects of the invention are provided in a method, using a public-key cryptosystem, for enabling a predetermined entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users, wherein each user is assigned a pair of matching secret and public keys. According to the method, each user's secret key is broken into shares. Then, each user provides a plurality of "trustees" pieces of information. The pieces of information provided to each trustee enable that trustee to verify that such information includes a "share" of a secret key of some given public key. Further, each trustee can verify that the pieces of information provided include a share of the secret key without interaction with any other trustee or by sending messages to the user. Upon a predetermined request or condition, e.g., a court order authorizing the entity to monitor the communications of a user suspected of unlawful activity, the trustees reveal to the entity the shares of the secret key of such user to enable the entity to reconstruct the secret key and monitor the suspect user's communications.
The method can be carried out whether or not the identity of the suspect user is known to the trustees, and even if less than all of the shares of the suspect user's secret key are required to be revealed in order to reconstruct the secret key. The method is robust enough to be effective if a given minority of trustees have been compromised and cannot be trusted to cooperate with the entity. In addition, the suspect user's activities are characterized as unlawful if the entity, after reconstructing or having tried to reconstruct the secret key, is still unable to monitor the suspect user's communications.
According to another more generalized aspect of the invention, a method is described for using a public-key cryptosystem for enabling a predetermined entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users. The method comprises the step of "verifiably secret sharing" each user's secret key with a plurality of trustees so that each trustee can verify that the share received is part of a secret key of some public key.
The foregoing has outlined some of the more pertinent objects of the present invention. These objects should be construed to be merely illustrative of some of the more prominent features and applications of the invention. Many other beneficial results can be attained by applying the disclosed invention in a different manner or modifying the invention as will be described. Accordingly, other objects and a fuller understanding of the invention may be had by referring to the following Detailed Description of the preferred embodiment.
For a more complete understanding of the present invention and the advantages thereof, reference should be made to the following Detailed Description taken in connection with the accompanying drawings in which:
FIG. 1 is a simplified diagram of a communications system over which a government entity desires to monitor communications of users suspected of unlawful activities;
FIG. 2 is a block diagram of a preferred hierarchy of entities that may use the methods of the present invention to monitor communications of users suspected of unlawful activities.
FIG. 1 represents a simple communications system 10 comprising a telephone network connected between a calling station 12 and a called station 14. One or more local central offices or telephone switches 16 connect telephone signals over the network in a well-known fashion. Referring now also to FIG. 2, assume that a government entity, such as local law enforcement agency 18, desires to monitor communications to and/or from calling station 12 because the user of such calling station is suspected of unlawful activity. Assume further that the user of the calling station 12 communicates using a PKC. Following accepted legal practices, the agency 18 obtains a court order from court 20 to privately monitor the line 15. According to the present invention, the agency's is able to monitor the line 15 while at the same time the privacy rights of other law-abiding users of the network are maintained. This is accomplished as will be described by requiring that each user "secret share" the user's secret key (of the PKC) with a plurality of trustees 22a . . . 22n.
According to the invention, a "fair" PKC is a special type of public-key cryptosystem. Every user can still choose his own keys and keep secret his private one; nonetheless, a special agreed-upon party (e.g., the government), and solely this party, under the proper circumstances envisaged by the law (e.g., a court order), and solely under these circumstances, is authorized to monitor all messages sent to a specific user. A fair PKC improves the security of the existing communication systems (e.g., the telephone service 10) while remaining within the constraints of accepted legal procedures.
In one embodiment, fair PKC's are constructed in the following general way. Referring now to FIGS. 1-2, it is assumed that there are five (5) trustees 22a . . . 22e and that the government desires, upon receiving a court order, to monitor the telephone communications to or from the calling station 12. Although the above-description is specific, it should be appreciated that users of the communications system and trustees may be people or computing devices. It is preferable that the trustees are chosen to be trustworthy. For instance, they may be judges (or computers controlled by them), or computers specially set up for this purpose. The trustees, together with the individual users, play a crucial role in deciding which encryption keys will be published in the system.
Each user independently chooses his own public and secret keys according to a given double-key system (for instance, the public key consists of the product of two primes, and the secret key one of these two primes). Since the user has chosen both of his keys, he can be sure of their "quality" and of the privacy of his decryption key. He then breaks his secret decryption key into five special "pieces" (i.e., he computes from his decryption key 5 special strings/numbers) possessing the following properties:
(1) The private key can be reconstructed given knowledge of all five, special pieces;
(2) The private key cannot be guessed at all if one only knows (any) 4, or less, of the special pieces;
(3) For i-1, . . . 5, the i-th special piece can be individually verified to be correct.
Given all 5 special pieces or "shares", one can verify that they are correct by checking that they indeed yield the private decryption key. According to one feature of the invention, property (3) insures that each special piece can be verified to be correct (i.e., that together with the other 4 special pieces it yields the private key) individually, i.e., without knowing the secret key at all and without knowing the value of any of the other special pieces.
The user then privately (e.g., in encrypted form) gives trustee 22i his own public key and the i-th piece of its associated secret key. Each trustee 22 individually inspects his received piece, and, if it is correct, approves the public key (e.g. signs it) and safely stores the piece relative to it. These approvals are given to a key management center 24, either directly by the trustees, or (possibly in a single message) by the individual user who collects them from the trustees. The center 24, which may or may not coincide with the government, itself approves (e.g., signs) any public key that is approved by all trustees. These center-approved keys are the public keys of the fair PKC and they are distributed and used for private communication as in an ordinary PKC.
Because the special pieces of each decryption key are privately given to the trustees, an adversary who taps the communication line of two users possesses the same information as in the underlying, ordinary PKC. Thus if the underlying PKC is secure, so is the fair PKC. Moreover, even if the adversary were one of the trustees himself, or even a cooperating collection of any four out of five of the trustees, property (2) insures that the adversary would still have the same information as in the ordinary PKC. Because the possibility that an adversary corrupts five out of five judges is absolutely remote, the security of the resulting fair PKC is the same as in the underlying PKC.
When presented with a court order, for example, the trustees 22 reveal to the government 20 the pieces of a given decryption key in their possession. According to the invention, the trustees may or may not be aware of the identity of the user who possesses the given decryption key. This provides additional security against "compromised" trustees who might otherwise tip off the suspect user once a request for that user's decryption key share is received by the trustee.
Upon receiving the shares, the government reconstructs the given decryption key. By property (3), each trustee previously verified whether he was given a correct special piece of a given decryption key. Moreover, every public key was authorized by the key management center 24 only if it was approved by all trustees 22. Thus, the government is guaranteed that, in case of a court order, it will be given all special pieces of any decryption key. By property (1), this is a guarantee that the government will be able to reconstruct any given decryption key if necessary to monitor communications over the network.
Several types of fair PKC's are now described in more detail.
The Diffie and Hellman public-key cryptosystem is known and is readily transformed into a fair PKC by the present invention. In the Diffie and Hellman scheme, each pair of users X and Y succeeds, without any interaction, in agreeing upon a common, secret key Sxy to be used as a conventional single-key cryptosystem. In the ordinary Diffie-Hellman PKC, there are a prime p and a generator (or high-order element) g common to all users. User X secretly selects a random integer Sx in the interval 1, p-1! as his private key and publicly announces the integer Px=gSx mod p as his public key. Another user, Y, will similarly select Sy as his private key and announce Py=gSy mod p as his public key. The value of this key is determined as Sxy =gSxSy mod p. User X computes Sxy by raising Y's public key to his private key mod pX, and user Y by raising X's public key to his secret key mod p. In fact:
(g.sup.Sx).sup.Sy =g.sup.SxSy =Sxy=g.sup.SySx =(g.sup.Sy).sup.Sx mod p.
While it is easy, given g, p and x, to compute y=gx mod p, no efficient algorithm is known for computing, given y and p, x such that gx =y mod p when g has high enough order. This is the discrete logarithm problem. This problem has been used as the basis of security in many cryptosystems. The Diffie and Hellman's PKC is transformed into a fair one in the following manner.
Each user X randomly chooses 5 integers Sx1, . . . Sx5 in the interval 1, p-1! and lets Sx be their sum mod p. It should be understood that all following operations are modulo p. User X then computes the numbers:
t1=g.sup.Sx 1. . . , t5=g.sup.Sx5 and Px=g.sup.Sx.
Px will be User X's public key and Sx his private key. The ti's will be referred to as the public pieces of Px, and the Sxi's as the private pieces. It should be noted that the product of the public pieces equals the public key Px. In fact:
t1. . . t5=g.sup.Sx1. . . g.sup.Sx5 =g.sup.(Sx1+. . .+Sx5) =g.sup.Sx.
Let T1, . . . T5 be the five trustees. User X now gives Px, the public pieces and Sx1 to trustee T1, Px, the public pieces and Sx2 to trustee T2, and so on. Piece Sxi is privately given to trustee Ti. Upon receiving public and private pieces ti and Sxi, trustee Ti verifies whether gSxi =Ti. If so, the trustee stores the pair (Px, Sxi), signs the sequence (Px,t1,t2,t3,t4,t5) and gives the signed sequence to the key management center 24 (or to user X, who will then give all of the signed public pieces at once to the key management center). Upon receiving all the signed sequences relative to a given public key Px, the key management center verifies that these sequences contain the same subsequence of public pieces t1 . . . t5 and that the product of the public pieces indeed equals Px. If so, center 24 approves Px as a public key and distributes it as in the original scheme (e.g., signs it and gives it to user X). The encryption and decryption instructions for any pair of users X and Y are exactly as in the Diffie and Hellman scheme (i.e., with common, secret key Sxy).
This way of proceeding matches the previously-described way of constructing a fair PKC. A still fair version of the Diffie-Hellman scheme can be obtained in a simpler manner by having the user give to each trustee Ti just the public piece ti and its corresponding private piece Sxi, and have the user give the key management center the public key Px. The center will approve Px only if it receives all public pieces, signed by the proper trustee, and the product of these public pieces equals Px. In this way, trustee Ti can verify that Sxi is the discrete logarithm of public piece ti. Such trustee cannot quite verify that Sxi is a legitimate share of Px since the trustee has not seen Px or the other public pieces. Nonetheless, the result is a fair PKC based on the Diffie-Hellman scheme because properties (1)-(3) described above are still satisfied.
Either one of the above-described fair PKC has the same degree of privacy of communication offered by the underlying Diffie-Hellman scheme. In fact, the validation of a public key does not compromise the corresponding private key. Each trustee Ti receives, as a special piece, the discrete logarithm, Sxi, of a random number, ti. This information is clearly irrelevant for computing the discrete logarithm of Px. The same is actually true for any 4 of the trustees taken together, since any four special pieces are independent of the private decryption key Sx. Also the key management center does not possess any information relevant to the private key; i.e., the discrete logarithm of Px. All the center has are the public pieces respectively signed by the trustees. The public pieces simply are 5 random numbers whose product is Px. This type of information is irrelevant for computing the discrete logarithm of Px; in fact, any one could choose four integers at random and setting the fifth to be Px divided by the product of the first four. The result would be integral because division is modulo p. As for a trustee's signature, this just represents the promise that someone else has a secret piece.
Even the information in the hands of the center together with any four of the trustees is irrelevant for computing the private key Sx. Thus, not only is the user guaranteed that the validation procedure will not betray his private key, but he also knows that this procedure has been properly followed because it is he himself that computes his own keys and the pieces of his private one.
Second, if the key management center validates the public key Px, then its private key is guaranteed to be reconstructable by the government in case of a court order. In fact, the center receives all 5 public pieces of Px, each signed by the proper trustee. These signatures testify that trustee Ti possesses the discrete logarithm of public piece ti. Since the center verifies that the product of the public pieces equals Px, it also knows that the sum of the secret pieces in storage with the trustees equals the discrete logarithm of Px; i.e, user X's private key. Thus the center knows that, if a court order were issued requesting the private key of X, the government is guaranteed to obtain the needed private key by summing the values received by the trustees.
The following describes a fair PKC based on the known RSA function. In the ordinary RSA PKC, the public key consists of an integer N product of two primes and one exponent e (relatively prime with f(N), where F is Euler's quotient function). No matter what the exponent, the private key may always be chosen to be N's factorization. By way of brief background, the RSA scheme has certain characteristics that derive from aspects of number theory:
Fact 1. Let ZN * denote the multiplicative group of the integers between 1 and N and relatively prime with N. If N is the product of two primes N=pq (or two prime powers: N=pa pb), then
(1) a number s in ZN * is a square mod N if and only if it has four distinct square-roots mod N: x, -x mod N, y, and -y mod N (i.e., x2 =y2 =s mod N). Moreover, from the greatest common divisor of +-x+-y and N, one easily computes the factorization of N. Also;
(2) one in four of the numbers in ZN * is a square mod N.
Fact 2. Among the integers in ZN * is defined a function, the Jacobi symbol, that evaluates easily to either 1 or -1. The Jacobi symbol of x is denoted by (s/N). The Jacobi symbol is multiplicative; i.e., (x/N)(Y/N)=(xy/N). If N is the product of two primes N=pq (or two prime powers: N=pa pb), the p and 1 are congruent to 3 mod 4. Then, if +-x and +-y are the four square roots of a square mod N (s/N)=(-x/N)=+1 and (y/N)=(-y/N)=-1. Thus, because of Fact 1, if one is given a Jacobi symbol 1 root and a Jacobi symbol -1 root of any square, he can easily factor N.
With this background, the following describes how the RSA cryptosystem can be made fair in a simple way. For simplicity again assume there are five trustees and that all of them must collaborate to reconstruct a secret key, while no four of them can even predict it. The RSA cryptosystem is easily converted into a fair PKC by efficiently sharing with the trustee's N's factorization. In particular, the trustees are privately provided information that, perhaps together with other given common information, enables one to reconstruct two (or more) square roots x and y (x different from ±y mod N) of a common square mod N. The given common information may be the -1 Jacobi symbol root of X2, which is equal to y.
A user chooses P and Q primes congruent to 3 mod 4, as his private key and N=PQ as his public key. Then he chooses 5 Jacobi 1 integers X1, X2, X3, X4 and X5 (preferably at random) in ZN * and computes their product, X, and Xi 2 mod N for all i=1, . . . , 5. The product of the last 5 squares, Z, is itself a square. One square root of Z mod N is X, which has Jacobi symbol equal to 1 (since the Jacobi symbol is multiplicative). The user computes Y, one of the Jacobi -1 roots mod N. X1, . . . X5 will be the public pieces of public key N and the Xi 's the private pieces. The user gives trustee Ti private piece Xi (and possibly the corresponding public piece, all other public pieces and Px, depending on whether it is desired that the verification of the shares so as to satisfy properties (1)-(3) is performed by both trustees and the center, or the trustees alone). Trustee Ti squares Xi mod N, gives the key management center his signature of Xi 2, and stores Xi.
The center first checks that (-1/N)=1, i.e., for all x: (x/N)=(-x/N). This is partial evidence that N is of the right form. Upon receiving the valid signature of the public pieces of N and the Jacobi -1 value Y from the user, the center checks whether mod N the square of Y equals the product of the five public pieces. If so, it checks, possibly with the help of the user, that N is the product of two prime powers. If so, the center approves N.
The reasoning behind the scheme is as follows. The trustees' signatures of the Xi 2 's (mod N) guarantee the center that every trustee Ti has stored a Jacobi symbol 1 root of Xi 2 mod N. Thus, in case of a court order, all these Jacobi symbol 1 roots can be retrieved. Their product, mod N, will also have Jacobi symbol 1, since this function is multiplicative, and will be a root of X2 mod N. But since the center has verified that Y2 =X2 mod N, one would have two roots X and Y of a common square mod N. Moreover, Y is different from X since it has different Jacobi symbol, and Y is also different from -x, since (-x/N)=(s/N) because (a) (-1/N) has been checked to be 1 and (b) the Jacobi symbol is multiplicative. Possession of such square roots, by Facts 1 and 2, is equivalent to having the factorization of N, provided that N is product of at most two prime powers. This last property has also been checked by the center before it has approved N.
Verification that N is the product of at most two prime powers can be performed in various ways. For instance, the center and user can engage in a zero-knowledge proof of this fact. Alternatively, the user may provide the center with the square root mod N for roughly 1/4 of the integers in a prescribed and random enough sequence of integers. For instance, such a sequence could be determined by one-way hashing N to a short seed and then expanding it into a longer sequence using a psuedo-random generator. If a dishonest user has chosen his N to be the product of three or more prime powers, then it would be foolish for him to hope that roughly 1/4of the integers in the sequence are squares mod N. In fact, for his choice of N, at most 1/8 of the integers have square roots mod N.
The above schemes can be modified in many ways. For instance, the proof that N is product of two prime powers can be done by the trustees (in collaboration with the user), who then inform the center of their findings. Also, the scheme can be modified so that the cooperation of the majority of the trustees is sufficient for reconstructing the secret key, while any minority cannot gain any information about the secret key. Also, as with all fair cryptosystems, one can arrange that when the government asks a trustee for his piece of the secret key of a user, the trustee does not learn about the identity of the user. The variations are discussed in more detail below.
In particular, the schemes described above are robust in the sense that some trustees, accidentally or maliciously, may reveal the shares in their possession without compromising the security of the system. However, these schemes rely on the fact that the trustees will collaborate during the reconstruction stage. In fact, it was insisted that all of the shares should be needed for recovering a secret key. This requirement may be disadvantageous, either because some trustees may reveal to be untrustworthy and refuse to give the government the key in their possession, or because, despite all file backups, the trustee may have genuinely lost the information in its possession. Whatever the reason, in this circumstance the reconstruction of a secret key will be prevented. This problem is also solved by the present invention.
By way of background, "secret sharing" (with parameters n,T,t) is a prior cryptographic scheme consisting of two phases: in phase one a secret value chosen by a distinguished person, the dealer, is put in safe storage with n people or computers, the trustees, by giving each one of them a piece of information. In phase two, when the trustees pool together the information in their possession, the secret is recovered. Secret sharing has a major disadvantage--it presupposes that the dealer gives the trustees correct shares (pieces of information) about his secret value. "Verifiable Secret Sharing" (VSS) solves this "honesty" problem. In a VSS scheme, each trustee can verify that the share given to him is genuine without knowing at all the shares of other trustees of the secret itself. Specifically, the trustee can verify that, if T verified shares are revealed, the original secret will be reconstructed, no matter what the dealer or dishonest trustees might do.
The above-described fair PKC schemes are based on a properly structured, non-interactive verifiable secret sharing scheme with parameters n=5, T=5 and t=4. According to the present invention, it may be desirable to have different values of these parameters, e.g., n=5, T=3 and t=2. In such case, any majority of the trustees can recover a secret key, while no minority of trustees can predict it all. This is achieved as follows (and be simply generalized to any desired values of n, T and t in which T>t).
After choosing a secret key Sx in 1, p-1!, user X computes his public key Px=gSx mod p (with all computations below being mod p). User X now considers all triplets of numbers between 1 and 5: (1,2,3), (2,3,4) etc. For each triplet (a,b,c), user X randomly chooses three integers S1abc, . . . S3abc in the interval 1, p-1! so that their sum mod p equals Sx. Then he computes the numbers:
t1abc=g.sup.S1abc, t2abc=g.sup.S2abc, t3abc=g.sup.S3abc
The tiabc's will be referred to as public pieces of Px, and the Siabc's as private pieces. Again, the product of the public pieces equals the public key Px. In fact,
t1abc-t2abc-t3abc=g.sup.S1abc ·g.sup.S 2abc·gS3abc=g (.sup.S1abc +-+.sup.S3abc)=g.sup.Sx =Px
User X then gives trustee Ta t1abc and S1abc, trustee Tb t2abc and S2abc, and trustee Tc t3abc and S3abc, always specifying the triplet in question. Upon receiving these quantities, trustee Ta (all other trustees do something similar) verifies that t1abc=gS1abc, signs the value (Px, t1abc, (a,b,c)) and gives the signature to the management center.
The key management center, for each triple (a,b,c), retrieves the values t1abc, t2abc and t3abc from the signed information received from trustees, Ta, Tb and Tc. If the product of these three values equals Px and the signatures are valid, the center approves Px as a public key.
The reason the scheme works, assuming that at most 2 trustees are untrustworthy, is that all secret pieces of a triple are needed for computing (or predicting) a secret key. Thus no secret key in the system can be retrieved by any 2 trustees. On the other hand, after a court order at least three trustees reveal all the secret pieces in their possession about a given public key. The government then has all the necessary secret pieces for at least one triple, and thus can compute easily the desired secret key.
Alternatively, each trustee is replaced by a group of new trustees. For instance, instead of a single trustee Ta, there may be three trustees: Ta1, Ta2 and Ta3. Each of these trustees will receive and check the same share of trustee Ta. In this way it is very unlikely that all three trustees will refuse to surrender their copy of the first share.
After having insured that a few potentially malicious trustees cannot prevent reconstruction of the key, there are still further security issues to address, namely, a trustee--requested by a court order to surrender his share of a given secret key--may alert the owner of that key that his communications are about to be monitored. This problem is also solved by the invention. A simple solution arises if the cryptosystem used by the trustees possess certain algebraic properties. This is illustrated for the Diffie-Hellman case, though the same result occurs for the RSA scheme. In the following discussion, for simplicity it is assumed that all trustees collaborate in the reconstruction of the secret key.
Assume that all trustees use deterministic RSA for receiving private messages. Thus, let Ni be the public RSA modulus of trustee Ti and ei his encryption exponent (i.e., to send Ti a message m in encrypted form, one would send mei mod Ni).
User U prepares his public and secret key, respectively Px and Sx (thus Px=gSx mod p), as well as his public and secret pieces of the secret key, respectively ti and Sxi's (thus Px=t1, t2 . . . t5 mod p and ti=gSxi mod p for all i). Then, the user gives to the key management center Px, all of the ti's and the n values Ui=(Sxi)3 mod Ni; i.e., he encrypts the i-th share with the public key of trustee Ti. Since the center does not know the factorization of the Ni's, this is not useful information to predict Sx, nor can the center verify that the decryption of the n ciphertexts are proper shares of Sx. For this, the center will seek the cooperation of the n trustees, but without informing them of the identity of the user as will be described.
The center stores the values tj's and Uj's relative to user U and then forwards Ui and ti to trustee Ti. If every trustee Ti verified that the decryption of Ui is a proper private piece relative to ti, the center approves Px.
Assume now that the judicial authority decides to monitor user U's communications. To lawfully reconstruct secret key Sx without leaking to a trustee the identity of the suspected user U, a judge (or another authorized representative) randomly selects a number Ri mod Ni and computes yi=Ri ei mod Ni. Then, he sends trustee Ti the value zi=Ui-yi mod Ni, asking with a court order to compute and send back wi, the ei-th root of zi mod Ni. Since zi is a random number mod Ni, no matter what the value of Ui is, trustee Ti cannot guess the identity of the user U in question. Moreover, since zi is the product of Ui and yi mod Ni the ei-th root of zi is the product mod Ni of the ei-th root of Ui (i.e., Sxi) and the ei-th root of yi (i.e., Ri). Thus, upon receiving wi, the judge divides it by yi mod Ni, thereby computing the desired Sxi. The product of these Sxi's equals the desired Sx.
In other variations of the invention, in case of a court order, the government is only authorized to understand the messages concerning a given user for a limited amount of time. The collective approval of all trustees may stand for the government approval. Also, trustees need not store their piece of the private key. The encryption of this piece--in the trustee's public key and signed by the trustee--can be made part of the user's public key. In this way, the public key carries the proof of its own authenticity and verification. In the latter case it may be advantageous to break the trustee's private keys into pieces.
If the user is an electronic device, such as an integrated circuit chip, the basic process of key selection and public-key validation can be done before the device leaves the factory. In this case, it may be advantageous that a "copy" of the trustee can be maintained within the factory. A copy of a trustee is a physically secure chip--one whose data cannot be read--containing a copy of the trustee's decryption key. The trustee (i.e., the party capable of giving the piece of a private key under a court order) need not necessarily coincide with this device.
In another variation, it may be arranged that the trustees each a have piece of the government private key, and that each user's private key is encrypted with the public key of the government.
While the use of a fair PKC in a telecommunications network (and under the authority of the government) has been described, such description is not meant to be taken by way of limitation. A fair PKC can be used in private organizations as well. For example, in a large organization where there is a need for privacy, assume there is an established "superior" but not all employees can be trusted since there are too many of them. The need for privacy requires the use of encryption. Because not all employees can be trusted, using a single encryption key for the whole company is unacceptable, as is using a number of single-key cryptosystems (since this would generate enormous key-distribution problems). Having each employee use his own double-key system is also dangerous, since he or she might conspire against the company with great secrecy, impunity and convenience.
In such application of a fair PKC, numerous advantages are obtained. First, each employee is in charge of choosing his own keys. While enjoying the advantages of a more distributed procedure, the organization retains absolute control because the superior is guaranteed to be able to decrypt every employee's communications when necessary. There is no need to change keys when the superior changes because the trustees need not be changed. The trustees' storage places need less surveillance, since only compromising all of them will give an adversary any advantage.
For making fair a private key cryptosystem, but also for a PKC, it is desirable that each trustee first deposits an encrypted version or otherwise committed version of his share, so that, when he is asked to reveal what his share was, he cannot change his mind about its value. Also, it is desirable that the user gives his shares to the trustees signed; such signatures can be relative to a different public key (if they are digital signatures) or to the same new public key if the new key can be used for signing as well. In this way, the share revealed by the trustee clearly proves that it way originated. Better still, the user may sign (with the trustee's key) the encryption of the share given to a trustee, and the signature can be revealed together with the share. This approach insures that one can both be certain that what was revealed was a share approved by the user and also that the trustees and the user cannot collaborate later on in changing its value.
It should be appreciated by those skilled in the art that the specific embodiments disclosed above may be readily utilized as a basis for modifying or designing other techniques and processes for carrying out the same purposes of the present invention. It should also be realized by those skilled in the art that such equivalent constructions do not depart from the spirit and scope of the invention as set forth in the appended claims.
Claims (21)
1. A method, using a public-key cryptosystem, for enabling a predetermined entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users, wherein each user is assigned a pair of matching secret and public keys, comprising the steps of:
breaking each user's secret key into shares;
providing trustees pieces of information enabling the trustees to verify that the pieces of information include shares of a secret key of some given public key; and
upon a predetermined request, having the trustees reveal the shares of the secret key of a user suspected of unlawful activity to enable the entity to attempt reconstruction of the secret key for monitoring communications to the suspect user.
2. The method as described in claim 1 wherein the predetermined entity is a government agency and the predetermined request is a court order.
3. The method as described in claim 1 wherein the identity of the suspect user is known to the trustees.
4. The method as described in claim 1 wherein the identity of the suspect user is unknown to the trustees.
5. The method as described in claim 1 further including the step of:
characterizing the suspect user's activities as unlawful if the entity is unable to monitor the suspect user's communications.
6. The method as described in claim 1 wherein less than all of the shares of the suspect user's secret key are required to be revealed in order to reconstruct the secret key.
7. The method as described in claim 1 wherein the shares are revealed to the entity upon the predetermined request.
8. The method as described in claim 1 wherein a given minority of trustees are unable to reconstruct the secret key.
9. The method as described in claim 1 wherein each trustee can verify that the pieces of information provided include a share of the secret key without interaction with any other trustee.
10. A method, using a public-key cryptosystem, for enabling a predetermined entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users, wherein each user is assigned a pair of matching secret and public keys, comprising the steps of:
breaking each user's secret key into shares;
providing trustees pieces of information that include shares of a secret key of some give public key.Iadd., trustees being distinct from the predetermined entity,.Iaddend.; and
upon a predetermined request, having the trustees reveal the shares of the secret key of auser suspected of unlawful activity to enable the entity to reconstruct the secret key and monitor communications to the suspect user.
11. A method, using a public-key cryptosystem . .into a cryptosystem.!., for enabling a predetermined entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users, comprising the step.Iadd.s .Iaddend.of:
. .verifying.!. .Iadd.verifiably .Iaddend.secret sharing each user's secret key with a plurality of trustees so that each trustee can verify that the share received is part of a secret key of some public key.Iadd.; and
upon a predetermined request, having at least some of the trustees reveal the shares of the secret key of a user to enable the entity to reconstruct the secret key and monitor communications to the user.Iaddend..
12. The method as described in claim 11 further including the step of:
characterizing the suspect user's activities as unlawful if the entity is unable to monitor the suspect user's communications.
13. The method as described in claim 11 wherein a given minority of trustees are unable to reconstruct the secret key.
14. The method as described in claim 11 wherein each trustee can verify that the pieces of information provided include a share of the secret key without interaction with any other trustee.
15. A method, using a cryptosystem, for enabling a predetermined entity to monitor communications of users suspected of unlawful activities while protecting the privacy of law-abiding users, wherein a group of users has a secret key, comprising the steps of:
breaking the secret key into shares;
providing trustees pieces of information that include shares of the secret key.Iadd., trustees being distinct from the predetermined entity.Iaddend.; and
upon a predetermined request, having the trustees reveal the shares of the secret key of a user suspected of unlawful activity to enable the entity to reconstruct the secret key and monitor communications to the suspect user.
16. The method as described in claim 15 further including the step of:
characterizing the suspect user's activities as unlawful if the entity is unable to monitor the suspect user's communications.
17. The method as described in claim 15 wherein a given minority of trustees are unable to reconstruct the secret key.
18. The method as described in claim 15 wherein each trustee can verify that the pieces of information provided include a share of the secret key without interaction with any other trustee. .Iadd.19. A method, using a public-key cryptosystem, for enabling a predetermined entity to monitor communications of users, wherein each user is assigned a pair of matching secret and public keys, comprising the steps of:
breaking each user's secret key into shares;
providing trustees pieces of information enabling the trustees to verify that the pieces of information include shares of a secret key of some given public key; and
upon a predetermined request, having the trustees reveal the shares of the secret key of a user to enable the entity to attempt reconstruction of the
secret key for monitoring communications to the user..Iaddend..Iadd.20. The method of claim 19, for monitoring communications of certain users while protecting the privacy of other users..Iaddend..Iadd.21. A method, using a public-key cryptosystem, for enabling a predetermined entity to monitor communication of users, wherein each user is assigned a pair of matching secret and public keys, comprising the steps of:
breaking each user's secret key into shares;
providing trustees pieces of information that include shares of a secret key of some given public key, trustees being distinct from the predetermined entity; and
upon a predetermined request, having the trustees reveal the shares of the secret key of a user to enable the entity to reconstruct the secret key and monitor communications to the user..Iaddend..Iadd.22. The method of claim 21, for monitoring communications of certain users while protecting
the privacy of other users..Iaddend..Iadd.23. A method, using a public-key cryptosystem, for enabling a predetermined entity to monitor communications of users, comprising the steps of:
verifiably secret sharing each user's secret key with a plurality of trustees so that each trustee can verify that the share received is part of a secret key of some public key; and
upon a predetermined request, having at least some of the trustees reveal the shares of the secret key of a user to enable the entity to reconstruct the secret key and monitor communications to the user..Iaddend..Iadd.24. The method of claim 23, for monitoring communications of certain users while protecting the privacy of other users..Iaddend..Iadd.25. A method, using a cryptosystem, for enabling a predetermined entity to monitor communications of users, wherein a group of users has a secret key, comprising the steps of:
breaking the secret key into shares;
providing trustees pieces of information that include shares of the secret key, trustees being distinct from the predetermined entity; and
upon a predetermined request, having the trustees reveal the shares of the secret key of a user to enable the entity to reconstruct the secret key
and monitor communications to the user..Iaddend..Iadd.26. The method of claim 23, for monitoring communications of certain users while protecting the privacy of other users..Iaddend.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/526,977 USRE35808E (en) | 1992-04-20 | 1995-09-12 | Fair cryptosystems and methods of use |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US07870935 US5276737B1 (en) | 1992-04-20 | 1992-04-20 | Fair cryptosystems and methods of use |
US08/526,977 USRE35808E (en) | 1992-04-20 | 1995-09-12 | Fair cryptosystems and methods of use |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US07870935 Reissue US5276737B1 (en) | 1992-04-20 | 1992-04-20 | Fair cryptosystems and methods of use |
Publications (1)
Publication Number | Publication Date |
---|---|
USRE35808E true USRE35808E (en) | 1998-05-26 |
Family
ID=25356364
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US07870935 Ceased US5276737B1 (en) | 1992-04-20 | 1992-04-20 | Fair cryptosystems and methods of use |
US08/526,977 Expired - Lifetime USRE35808E (en) | 1992-04-20 | 1995-09-12 | Fair cryptosystems and methods of use |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US07870935 Ceased US5276737B1 (en) | 1992-04-20 | 1992-04-20 | Fair cryptosystems and methods of use |
Country Status (6)
Country | Link |
---|---|
US (2) | US5276737B1 (en) |
EP (1) | EP0637413B1 (en) |
KR (1) | KR0151217B1 (en) |
AT (1) | ATE224619T1 (en) |
DE (1) | DE69332305D1 (en) |
IL (1) | IL105471A (en) |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2000074298A1 (en) * | 1999-05-26 | 2000-12-07 | Ascom Hasler Mailing Systems, Inc. | Technique for split knowledge backup and recovery of a cryptographic key |
US20020165824A1 (en) * | 1995-10-02 | 2002-11-07 | Silvio Micali | Scalable certificate validation and simplified PKI management |
US20040237031A1 (en) * | 2003-05-13 | 2004-11-25 | Silvio Micali | Efficient and secure data currentness systems |
US20050010783A1 (en) * | 1995-10-24 | 2005-01-13 | Phil Libin | Access control |
US20050154918A1 (en) * | 2003-11-19 | 2005-07-14 | David Engberg | Distributed delegated path discovery and validation |
US6973571B2 (en) | 2001-07-03 | 2005-12-06 | Bank Of America Corporation | System, apparatus, and method for performing cryptographic validity services |
US7205882B2 (en) | 2004-11-10 | 2007-04-17 | Corestreet, Ltd. | Actuating a security system using a wireless device |
US7337315B2 (en) | 1995-10-02 | 2008-02-26 | Corestreet, Ltd. | Efficient certificate revocation |
US7353396B2 (en) | 1995-10-02 | 2008-04-01 | Corestreet, Ltd. | Physical access control |
US7529928B2 (en) | 1995-10-24 | 2009-05-05 | Corestreet, Ltd. | Certificate revocation system |
US7600129B2 (en) | 1995-10-02 | 2009-10-06 | Corestreet, Ltd. | Controlling access using additional data |
US7698557B2 (en) | 2003-12-22 | 2010-04-13 | Guardtime As | System and method for generating a digital certificate |
US7716486B2 (en) | 1995-10-02 | 2010-05-11 | Corestreet, Ltd. | Controlling group access to doors |
US7822989B2 (en) | 1995-10-02 | 2010-10-26 | Corestreet, Ltd. | Controlling access to an area |
US7966487B2 (en) | 2004-01-09 | 2011-06-21 | Corestreet, Ltd. | Communication-efficient real time credentials for OCSP and distributed OCSP |
US8015597B2 (en) | 1995-10-02 | 2011-09-06 | Corestreet, Ltd. | Disseminating additional data used for controlling access |
US8261319B2 (en) | 1995-10-24 | 2012-09-04 | Corestreet, Ltd. | Logging access attempts to an area |
Families Citing this family (117)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10361802B1 (en) | 1999-02-01 | 2019-07-23 | Blanding Hovenweep, Llc | Adaptive pattern recognition based control system and method |
US5903454A (en) | 1991-12-23 | 1999-05-11 | Hoffberg; Linda Irene | Human-factored interface corporating adaptive pattern recognition based controller apparatus |
US6850252B1 (en) * | 1999-10-05 | 2005-02-01 | Steven M. Hoffberg | Intelligent electronic appliance system and method |
US6400996B1 (en) | 1999-02-01 | 2002-06-04 | Steven M. Hoffberg | Adaptive pattern recognition based control system and method |
US8352400B2 (en) | 1991-12-23 | 2013-01-08 | Hoffberg Steven M | Adaptive pattern recognition based controller apparatus and method and human-factored interface therefore |
US6418424B1 (en) | 1991-12-23 | 2002-07-09 | Steven M. Hoffberg | Ergonomic man-machine interface incorporating adaptive pattern recognition based control system |
USRE36918E (en) * | 1992-04-20 | 2000-10-17 | Certco Llc | Fair cryptosystems and methods of use |
US5315658B1 (en) * | 1992-04-20 | 1995-09-12 | Silvio Micali | Fair cryptosystems and methods of use |
CA2169449A1 (en) * | 1993-08-13 | 1995-02-23 | Frank Thomson Leighton | Secret key exchange |
US20020013898A1 (en) * | 1997-06-04 | 2002-01-31 | Sudia Frank W. | Method and apparatus for roaming use of cryptographic values |
AU705473B2 (en) * | 1994-01-13 | 1999-05-20 | Certco Inc | Cryptographic system and method with key escrow feature |
US5825880A (en) * | 1994-01-13 | 1998-10-20 | Sudia; Frank W. | Multi-step digital signature method and system |
UA41387C2 (en) * | 1994-01-13 | 2001-09-17 | Сертко, Інк | Method for setting of true communication being checked, method for protected communication, method for renewal of micro-software, method for execution of enciphered communication and method for giving to device checked on identity of right on electron transaction |
US5537475A (en) * | 1994-02-01 | 1996-07-16 | Micali; Silvio | Efficient digital signature algorithm and use thereof technical field |
US5712913A (en) * | 1994-02-08 | 1998-01-27 | Digicash Incorporated | Limited-traceability systems |
US5481613A (en) * | 1994-04-15 | 1996-01-02 | Northern Telecom Limited | Computer network cryptographic key distribution system |
US5748735A (en) * | 1994-07-18 | 1998-05-05 | Bell Atlantic Network Services, Inc. | Securing E-mail communications and encrypted file storage using yaksha split private key asymmetric cryptography |
US5838792A (en) * | 1994-07-18 | 1998-11-17 | Bell Atlantic Network Services, Inc. | Computer system for centralized session key distribution, privacy enhanced messaging and information distribution using a split private key public cryptosystem |
US5905799A (en) * | 1994-07-20 | 1999-05-18 | Bell Atlantic Network Services, Inc. | Programmed computer for identity verification, forming joint signatures and session key agreement in an RSA public cryptosystem |
US5588061A (en) * | 1994-07-20 | 1996-12-24 | Bell Atlantic Network Services, Inc. | System and method for identity verification, forming joint signatures and session key agreement in an RSA public cryptosystem |
DE69534192T2 (en) * | 1994-07-29 | 2006-02-16 | Canon K.K. | A method for sharing secret information, generating a digital signature, and performing authentication in a communication system having a plurality of information processing devices and communication system for applying this method |
US5557765A (en) * | 1994-08-11 | 1996-09-17 | Trusted Information Systems, Inc. | System and method for data recovery |
US5557346A (en) * | 1994-08-11 | 1996-09-17 | Trusted Information Systems, Inc. | System and method for key escrow encryption |
JPH10511471A (en) * | 1994-08-12 | 1998-11-04 | リートン,フランク、タムスン | Fail-safe key marking system |
US5499296A (en) * | 1994-08-22 | 1996-03-12 | Micali; Silvio | Natural input encryption and method of use |
US5737419A (en) * | 1994-11-09 | 1998-04-07 | Bell Atlantic Network Services, Inc. | Computer system for securing communications using split private key asymmetric cryptography |
US6237096B1 (en) | 1995-01-17 | 2001-05-22 | Eoriginal Inc. | System and method for electronic transmission storage and retrieval of authenticated documents |
US5748738A (en) * | 1995-01-17 | 1998-05-05 | Document Authentication Systems, Inc. | System and method for electronic transmission, storage and retrieval of authenticated documents |
US7743248B2 (en) * | 1995-01-17 | 2010-06-22 | Eoriginal, Inc. | System and method for a remote access service enabling trust and interoperability when retrieving certificate status from multiple certification authority reporting components |
US7162635B2 (en) * | 1995-01-17 | 2007-01-09 | Eoriginal, Inc. | System and method for electronic transmission, storage, and retrieval of authenticated electronic original documents |
US5615268A (en) * | 1995-01-17 | 1997-03-25 | Document Authentication Systems, Inc. | System and method for electronic transmission storage and retrieval of authenticated documents |
US6272632B1 (en) | 1995-02-21 | 2001-08-07 | Network Associates, Inc. | System and method for controlling access to a user secret using a key recovery field |
US5564106A (en) * | 1995-03-09 | 1996-10-08 | Motorola, Inc. | Method for providing blind access to an encryption key |
US6141750A (en) * | 1995-03-21 | 2000-10-31 | Micali; Silvio | Simultaneous electronic transactions with subscriber verification |
US5553145A (en) * | 1995-03-21 | 1996-09-03 | Micali; Silvia | Simultaneous electronic transactions with visible trusted parties |
US6134326A (en) * | 1996-11-18 | 2000-10-17 | Bankers Trust Corporation | Simultaneous electronic transactions |
US6137884A (en) * | 1995-03-21 | 2000-10-24 | Bankers Trust Corporation | Simultaneous electronic transactions with visible trusted parties |
WO1996029795A1 (en) * | 1995-03-21 | 1996-09-26 | Silvio Micali | Simultaneous electronic transactions |
IL113259A (en) * | 1995-04-05 | 2001-03-19 | Diversinet Corp | Apparatus and method for safe communication handshake and data transfer |
CA2223305A1 (en) * | 1995-06-05 | 1996-12-12 | Certco Llc | Multi-step digital signature method and system |
US5978053A (en) * | 1995-07-07 | 1999-11-02 | New Mexico State University Technology Transfer Corporation | Characterization of collimation and beam alignment |
US5684545A (en) * | 1995-07-07 | 1997-11-04 | New Mexico State University Technology Transfer Corp. | Adaptive optics wave measurement and correction system |
US5631961A (en) * | 1995-09-15 | 1997-05-20 | The United States Of America As Represented By The Director Of The National Security Agency | Device for and method of cryptography that allows third party access |
US6026163A (en) * | 1995-12-13 | 2000-02-15 | Micali; Silvio | Distributed split-key cryptosystem and applications |
US5764772A (en) * | 1995-12-15 | 1998-06-09 | Lotus Development Coporation | Differential work factor cryptography method and system |
US5812670A (en) * | 1995-12-28 | 1998-09-22 | Micali; Silvio | Traceable anonymous transactions |
US5787169A (en) * | 1995-12-28 | 1998-07-28 | International Business Machines Corp. | Method and apparatus for controlling access to encrypted data files in a computer system |
US5615269A (en) * | 1996-02-22 | 1997-03-25 | Micali; Silvio | Ideal electronic negotiations |
US5768388A (en) * | 1996-03-01 | 1998-06-16 | Goldwasser; Shafi | Time delayed key escrow |
US5666414A (en) * | 1996-03-21 | 1997-09-09 | Micali; Silvio | Guaranteed partial key-escrow |
US5815573A (en) * | 1996-04-10 | 1998-09-29 | International Business Machines Corporation | Cryptographic key recovery system |
US5903651A (en) | 1996-05-14 | 1999-05-11 | Valicert, Inc. | Apparatus and method for demonstrating and confirming the status of a digital certificates and other data |
US6901509B1 (en) | 1996-05-14 | 2005-05-31 | Tumbleweed Communications Corp. | Apparatus and method for demonstrating and confirming the status of a digital certificates and other data |
US5638447A (en) * | 1996-05-15 | 1997-06-10 | Micali; Silvio | Compact digital signatures |
US5901227A (en) * | 1996-06-20 | 1999-05-04 | Novell, Inc. | Method and apparatus for implementing partial and complete optional key escrow |
US5796830A (en) * | 1996-07-29 | 1998-08-18 | International Business Machines Corporation | Interoperable cryptographic key recovery system |
CA2261947C (en) * | 1996-08-07 | 2008-11-18 | Silvio Micali | Simultaneous electronic transactions with visible trusted parties |
AU716797B2 (en) * | 1996-08-19 | 2000-03-09 | Ntru Cryptosystems, Inc. | Public key cryptosystem method and apparatus |
US5937066A (en) * | 1996-10-02 | 1999-08-10 | International Business Machines Corporation | Two-phase cryptographic key recovery system |
US5949882A (en) * | 1996-12-13 | 1999-09-07 | Compaq Computer Corporation | Method and apparatus for allowing access to secured computer resources by utilzing a password and an external encryption algorithm |
US6400823B1 (en) | 1996-12-13 | 2002-06-04 | Compaq Computer Corporation | Securely generating a computer system password by utilizing an external encryption algorithm |
US5960084A (en) * | 1996-12-13 | 1999-09-28 | Compaq Computer Corporation | Secure method for enabling/disabling power to a computer system following two-piece user verification |
US5953422A (en) * | 1996-12-31 | 1999-09-14 | Compaq Computer Corporation | Secure two-piece user authentication in a computer network |
US6581162B1 (en) | 1996-12-31 | 2003-06-17 | Compaq Information Technologies Group, L.P. | Method for securely creating, storing and using encryption keys in a computer system |
US5887131A (en) * | 1996-12-31 | 1999-03-23 | Compaq Computer Corporation | Method for controlling access to a computer system by utilizing an external device containing a hash value representation of a user password |
US5907618A (en) * | 1997-01-03 | 1999-05-25 | International Business Machines Corporation | Method and apparatus for verifiably providing key recovery information in a cryptographic system |
US6260145B1 (en) * | 1997-02-14 | 2001-07-10 | Fujitsu Limited | System and method of authentication of digital information |
US5920630A (en) * | 1997-02-25 | 1999-07-06 | United States Of America | Method of public key cryptography that includes key escrow |
JP3656688B2 (en) * | 1997-03-31 | 2005-06-08 | 栄司 岡本 | Cryptographic data recovery method and key registration system |
US6335972B1 (en) | 1997-05-23 | 2002-01-01 | International Business Machines Corporation | Framework-based cryptographic key recovery system |
US6389136B1 (en) | 1997-05-28 | 2002-05-14 | Adam Lucas Young | Auto-Recoverable and Auto-certifiable cryptosystems with RSA or factoring based keys |
US6243466B1 (en) | 1997-08-29 | 2001-06-05 | Adam Lucas Young | Auto-escrowable and auto-certifiable cryptosystems with fast key generation |
US6122742A (en) * | 1997-06-18 | 2000-09-19 | Young; Adam Lucas | Auto-recoverable and auto-certifiable cryptosystem with unescrowed signing keys |
US6202150B1 (en) | 1997-05-28 | 2001-03-13 | Adam Lucas Young | Auto-escrowable and auto-certifiable cryptosystems |
US6282295B1 (en) | 1997-10-28 | 2001-08-28 | Adam Lucas Young | Auto-recoverable and auto-certifiable cryptostem using zero-knowledge proofs for key escrow in general exponential ciphers |
US6314190B1 (en) | 1997-06-06 | 2001-11-06 | Networks Associates Technology, Inc. | Cryptographic system with methods for user-controlled message recovery |
US6058188A (en) * | 1997-07-24 | 2000-05-02 | International Business Machines Corporation | Method and apparatus for interoperable validation of key recovery information in a cryptographic system |
US6038317A (en) * | 1997-12-24 | 2000-03-14 | Magliveras; Spyros S. | Secret key cryptosystem and method utilizing factorizations of permutation groups of arbitrary order 2l |
FI105987B (en) * | 1998-01-13 | 2000-10-31 | Nokia Networks Oy | A mobile communication system for short messages |
WO2000019652A1 (en) * | 1998-10-01 | 2000-04-06 | University Of Maryland | Distributed shared key generation and management using fractional keys |
US6535607B1 (en) | 1998-11-02 | 2003-03-18 | International Business Machines Corporation | Method and apparatus for providing interoperability between key recovery and non-key recovery systems |
JP2000165373A (en) * | 1998-11-25 | 2000-06-16 | Toshiba Corp | Enciphering device, cryptographic communication system, key restoration system and storage medium |
US6473508B1 (en) | 1998-12-22 | 2002-10-29 | Adam Lucas Young | Auto-recoverable auto-certifiable cryptosystems with unescrowed signature-only keys |
US7966078B2 (en) | 1999-02-01 | 2011-06-21 | Steven Hoffberg | Network media appliance system and method |
US6823070B1 (en) | 2000-03-28 | 2004-11-23 | Freescale Semiconductor, Inc. | Method for key escrow in a communication system and apparatus therefor |
US20040073617A1 (en) * | 2000-06-19 | 2004-04-15 | Milliken Walter Clark | Hash-based systems and methods for detecting and preventing transmission of unwanted e-mail |
US7181017B1 (en) | 2001-03-23 | 2007-02-20 | David Felsher | System and method for secure three-party communications |
WO2002100022A2 (en) * | 2001-06-01 | 2002-12-12 | No Magic, Inc. | Electronic information and cryptographic key management system |
US7093133B2 (en) * | 2001-12-20 | 2006-08-15 | Hewlett-Packard Development Company, L.P. | Group signature generation system using multiple primes |
US7146009B2 (en) * | 2002-02-05 | 2006-12-05 | Surety, Llc | Secure electronic messaging system requiring key retrieval for deriving decryption keys |
US9818136B1 (en) | 2003-02-05 | 2017-11-14 | Steven M. Hoffberg | System and method for determining contingent relevance |
US7289629B2 (en) * | 2004-02-09 | 2007-10-30 | Microsoft Corporation | Primitives for fast secure hash functions and stream ciphers |
US8874477B2 (en) | 2005-10-04 | 2014-10-28 | Steven Mark Hoffberg | Multifactorial optimization system and method |
US20080126808A1 (en) * | 2006-07-05 | 2008-05-29 | Cms Products, Inc. | Encrypted dataset access by custodians |
EP2078274B1 (en) | 2006-11-02 | 2015-09-09 | NDS Limited | Privacy-aware content protection system |
US20100172501A1 (en) * | 2009-01-06 | 2010-07-08 | Tian Weicheng | Secure key system |
US20100174653A1 (en) * | 2009-01-07 | 2010-07-08 | Tian Weicheng | Secure method and device of financial transaction |
US8856879B2 (en) | 2009-05-14 | 2014-10-07 | Microsoft Corporation | Social authentication for account recovery |
US9124431B2 (en) | 2009-05-14 | 2015-09-01 | Microsoft Technology Licensing, Llc | Evidence-based dynamic scoring to limit guesses in knowledge-based authentication |
RU2496239C1 (en) * | 2012-02-09 | 2013-10-20 | Государственное казенное образовательное учреждение высшего профессионального образования Академия Федеральной службы охраны Российской Федерации (Академия ФСО России) | Method for steganographic transmission of information through main optical channel and apparatus for implementing said method |
US11057210B1 (en) | 2015-09-30 | 2021-07-06 | Apple Inc. | Distribution and recovery of a user secret |
US10693639B2 (en) * | 2017-02-28 | 2020-06-23 | Blackberry Limited | Recovering a key in a secure manner |
US11056981B2 (en) | 2018-07-07 | 2021-07-06 | Intelesol, Llc | Method and apparatus for signal extraction with sample and hold and release |
US11671029B2 (en) | 2018-07-07 | 2023-06-06 | Intelesol, Llc | AC to DC converters |
US11581725B2 (en) | 2018-07-07 | 2023-02-14 | Intelesol, Llc | Solid-state power interrupters |
US11205011B2 (en) | 2018-09-27 | 2021-12-21 | Amber Solutions, Inc. | Privacy and the management of permissions |
US11334388B2 (en) | 2018-09-27 | 2022-05-17 | Amber Solutions, Inc. | Infrastructure support to enhance resource-constrained device capabilities |
US10985548B2 (en) | 2018-10-01 | 2021-04-20 | Intelesol, Llc | Circuit interrupter with optical connection |
US11349296B2 (en) | 2018-10-01 | 2022-05-31 | Intelesol, Llc | Solid-state circuit interrupters |
US11115207B2 (en) | 2018-12-05 | 2021-09-07 | Sidewalk Labs LLC | Identity systems, methods, and media for auditing and notifying users concerning verifiable claims |
EP3900487A4 (en) | 2018-12-17 | 2022-09-21 | Intelesol, LLC | Ac-driven light-emitting diode systems |
US11373831B2 (en) | 2019-05-18 | 2022-06-28 | Amber Solutions, Inc. | Intelligent circuit breakers |
JP7554272B2 (en) | 2020-01-21 | 2024-09-19 | アンバー セミコンダクター,インク. | Intelligent Circuit Breaker |
EP4197086A4 (en) | 2020-08-11 | 2024-09-04 | Amber Semiconductor Inc | Intelligent energy source monitoring and selection control system |
US20220271933A1 (en) * | 2021-02-19 | 2022-08-25 | Samsung Electronics Co., Ltd. | System and method for device to device secret backup and recovery |
CN113347009B (en) * | 2021-08-05 | 2022-01-07 | 成都飞机工业(集团)有限责任公司 | Certificateless threshold signcryption method based on elliptic curve cryptosystem |
US12113525B2 (en) | 2021-09-30 | 2024-10-08 | Amber Semiconductor, Inc. | Intelligent electrical switches |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4375579A (en) * | 1980-01-30 | 1983-03-01 | Wisconsin Alumni Research Foundation | Database encryption and decryption circuit and method using subkeys |
US4933970A (en) * | 1988-01-19 | 1990-06-12 | Yeda Research And Development Company Limited | Variants of the fiat-shamir identification and signature scheme |
US5005200A (en) * | 1988-02-12 | 1991-04-02 | Fischer Addison M | Public key/signature cryptosystem with enhanced digital signature certification |
US5018196A (en) * | 1985-09-04 | 1991-05-21 | Hitachi, Ltd. | Method for electronic transaction with digital signature |
US5136643A (en) * | 1989-10-13 | 1992-08-04 | Fischer Addison M | Public/key date-time notary facility |
US5150411A (en) * | 1990-10-24 | 1992-09-22 | Omnisec | Cryptographic system allowing encrypted communication between users with a secure mutual cipher key determined without user interaction |
-
1992
- 1992-04-20 US US07870935 patent/US5276737B1/en not_active Ceased
-
1993
- 1993-04-20 DE DE69332305T patent/DE69332305D1/en not_active Expired - Lifetime
- 1993-04-20 EP EP93910653A patent/EP0637413B1/en not_active Expired - Lifetime
- 1993-04-20 IL IL10547193A patent/IL105471A/en not_active IP Right Cessation
- 1993-04-20 AT AT93910653T patent/ATE224619T1/en not_active IP Right Cessation
- 1993-04-20 KR KR1019940703724A patent/KR0151217B1/en not_active IP Right Cessation
-
1995
- 1995-09-12 US US08/526,977 patent/USRE35808E/en not_active Expired - Lifetime
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4375579A (en) * | 1980-01-30 | 1983-03-01 | Wisconsin Alumni Research Foundation | Database encryption and decryption circuit and method using subkeys |
US5018196A (en) * | 1985-09-04 | 1991-05-21 | Hitachi, Ltd. | Method for electronic transaction with digital signature |
US4933970A (en) * | 1988-01-19 | 1990-06-12 | Yeda Research And Development Company Limited | Variants of the fiat-shamir identification and signature scheme |
US5005200A (en) * | 1988-02-12 | 1991-04-02 | Fischer Addison M | Public key/signature cryptosystem with enhanced digital signature certification |
US5136643A (en) * | 1989-10-13 | 1992-08-04 | Fischer Addison M | Public/key date-time notary facility |
US5150411A (en) * | 1990-10-24 | 1992-09-22 | Omnisec | Cryptographic system allowing encrypted communication between users with a secure mutual cipher key determined without user interaction |
Cited By (27)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7337315B2 (en) | 1995-10-02 | 2008-02-26 | Corestreet, Ltd. | Efficient certificate revocation |
US20020165824A1 (en) * | 1995-10-02 | 2002-11-07 | Silvio Micali | Scalable certificate validation and simplified PKI management |
US8732457B2 (en) | 1995-10-02 | 2014-05-20 | Assa Abloy Ab | Scalable certificate validation and simplified PKI management |
US7716486B2 (en) | 1995-10-02 | 2010-05-11 | Corestreet, Ltd. | Controlling group access to doors |
US7822989B2 (en) | 1995-10-02 | 2010-10-26 | Corestreet, Ltd. | Controlling access to an area |
US7600129B2 (en) | 1995-10-02 | 2009-10-06 | Corestreet, Ltd. | Controlling access using additional data |
US8015597B2 (en) | 1995-10-02 | 2011-09-06 | Corestreet, Ltd. | Disseminating additional data used for controlling access |
US7353396B2 (en) | 1995-10-02 | 2008-04-01 | Corestreet, Ltd. | Physical access control |
US8261319B2 (en) | 1995-10-24 | 2012-09-04 | Corestreet, Ltd. | Logging access attempts to an area |
US7529928B2 (en) | 1995-10-24 | 2009-05-05 | Corestreet, Ltd. | Certificate revocation system |
US7660994B2 (en) | 1995-10-24 | 2010-02-09 | Corestreet, Ltd. | Access control |
US20050010783A1 (en) * | 1995-10-24 | 2005-01-13 | Phil Libin | Access control |
US20080031460A1 (en) * | 1999-05-26 | 2008-02-07 | Brookner George M | Technique for split knowledge backup and recovery of a cryptographic key |
WO2000074298A1 (en) * | 1999-05-26 | 2000-12-07 | Ascom Hasler Mailing Systems, Inc. | Technique for split knowledge backup and recovery of a cryptographic key |
US7916871B2 (en) | 1999-05-26 | 2011-03-29 | Neopost Technologies | Technique for split knowledge backup and recovery of a cryptographic key |
US6973571B2 (en) | 2001-07-03 | 2005-12-06 | Bank Of America Corporation | System, apparatus, and method for performing cryptographic validity services |
US7657751B2 (en) | 2003-05-13 | 2010-02-02 | Corestreet, Ltd. | Efficient and secure data currentness systems |
US20040237031A1 (en) * | 2003-05-13 | 2004-11-25 | Silvio Micali | Efficient and secure data currentness systems |
US20050154918A1 (en) * | 2003-11-19 | 2005-07-14 | David Engberg | Distributed delegated path discovery and validation |
US8707030B2 (en) | 2003-11-19 | 2014-04-22 | Corestreet, Ltd. | Distributed delegated path discovery and validation |
US20100199087A1 (en) * | 2003-12-22 | 2010-08-05 | Guardtime As | System and method for generating a digital certificate |
US20100199342A1 (en) * | 2003-12-22 | 2010-08-05 | Guardtime As | System and method for generating a digital certificate |
US7698557B2 (en) | 2003-12-22 | 2010-04-13 | Guardtime As | System and method for generating a digital certificate |
US8312528B2 (en) | 2003-12-22 | 2012-11-13 | Guardtime Ip Holdings Limited | System and method for generating a digital certificate |
US8347372B2 (en) | 2003-12-22 | 2013-01-01 | Guardtime Ip Holdings Limited | System and method for generating a digital certificate |
US7966487B2 (en) | 2004-01-09 | 2011-06-21 | Corestreet, Ltd. | Communication-efficient real time credentials for OCSP and distributed OCSP |
US7205882B2 (en) | 2004-11-10 | 2007-04-17 | Corestreet, Ltd. | Actuating a security system using a wireless device |
Also Published As
Publication number | Publication date |
---|---|
DE69332305D1 (en) | 2002-10-24 |
KR950701481A (en) | 1995-03-23 |
IL105471A (en) | 1996-08-04 |
KR0151217B1 (en) | 1998-11-02 |
ATE224619T1 (en) | 2002-10-15 |
EP0637413A4 (en) | 1997-08-20 |
EP0637413A1 (en) | 1995-02-08 |
EP0637413B1 (en) | 2002-09-18 |
US5276737B1 (en) | 1995-09-12 |
US5276737A (en) | 1994-01-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
USRE35808E (en) | Fair cryptosystems and methods of use | |
AU670587B2 (en) | Verifying secret keys in a public-key cryptosystem | |
US5315658A (en) | Fair cryptosystems and methods of use | |
USRE36918E (en) | Fair cryptosystems and methods of use | |
US5481613A (en) | Computer network cryptographic key distribution system | |
US7860243B2 (en) | Public key encryption for groups | |
US5313521A (en) | Key distribution protocol for file transfer in the local area network | |
US7502467B2 (en) | System and method for authentication seed distribution | |
US6970562B2 (en) | System and method for crypto-key generation and use in cryptosystem | |
US6072876A (en) | Method and system for depositing private key used in RSA cryptosystem | |
US7359507B2 (en) | Server-assisted regeneration of a strong secret from a weak secret | |
US5124117A (en) | Cryptographic key distribution method and system | |
US6377688B1 (en) | Cryptographic communication method and system | |
US20020078345A1 (en) | System and method for authentication in a crypto-system utilizing symmetric and asymmetric crypto-keys | |
Micali | Fair cryptosystems | |
US20020078353A1 (en) | High security cryptosystem | |
WO1993021708A1 (en) | Verifying secret keys in a public-key cryptosystem | |
KR20010013155A (en) | Auto-recoverable auto-certifiable cryptosystems | |
JPH08506217A (en) | Fair encryption system and how to use it | |
Sakuraii et al. | A key escrow system with protecting user's privacy by blind decoding | |
Cryptosystems et al. | FAIR PUBLIC-KEY CRYPTOSYSTEMS |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: CERTCO, LLC, NEW YORK Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BANKERS TRUST COMPANY;REEL/FRAME:008328/0152 Effective date: 19961030 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
FPAY | Fee payment |
Year of fee payment: 12 |
|
AS | Assignment |
Owner name: MICALI, SILVIO, MASSACHUSETTS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CERTCO LLC;REEL/FRAME:019084/0704 Effective date: 19990127 |