By Christopher Malon, Group Ring, Inc. (https://groupring.net)
Privacy requires an individual to perform transactions under many different identity tokens, which are not linked in any outside database. A principal may wish to establish his possession of a attestation, without revealing his complete identity. However, attestations should not be bearer instruments. An attestation must be issued in a way so that it is useless to anyone but the person to whom it was originally issued.
This proposal provides a "forking" mechanism to issue attestations and spawn new identities from parent identities, in a way that attestations can be attributed to the spawned identity individually.
The last section provides a federated mechanism for identities to establish their reputation data, both positive and negative, using a public blockchain. Forking is essential for this proposal, because this proposal gives a method to establish a complete history of a single identity’s actions, which could easily become public knowledge. A principal retains control only by spawning subidentities up to the finest level of activities that she wishes to be evaluated as a unit.
As implemented in Bitcoin's P2SH protocol, an M-of-N multisig address is implemented by a script address. When payment using the script address is verified, the script is revealed, including the addresses of the participating public keys.
However, some public key cryptosystems have a property that enables a composite signature scheme in which the participating keys can remain private. For example, in an elliptic curve digital signature algorithm (ECDSA) [1], a finite field F, an elliptic curve E with points taking cordinates in F, and a base point G on the curve E are fixed. In Bitcoin, E, F, and G are defined by the standard secp256k1 [2]. Private keys are integers x from 1 to n-1, where n is the order of the point G, and the corresponding public key is the scalar multiple Q = xG. Thus, if Q = xG and R = yG are two public keys, Q+R is a public key with private key x+y.
For Bob to confer an attestation upon Alice that she can present separately from her other attestations,
-
Alice generates an additional keypair, called Carol.
-
Alice sends her own public key and Carol's to Bob.
-
Bob decides that he wants to confer the attestation upon Alice, usually based on some prior knowledge of Alice.
-
Bob computes the public key Diana = Alice + Carol.
-
Bob signs a message conferring the attestation upon Diana, and sends it to Alice.
Note that Bob cannot simply issue the attestation to one of Alice's derived keypairs, per BIP 32 [3], in lieu of this procedure, because derived keys are recognizable based on knowledge of an ancestor public key.
To verify that Elizabeth has the attestation addressed to Diana, Frank may require Elizabeth to sign her messages using the composite key Diana + Elizabeth = (Alice + Carol) + Elizabeth.
Reputation is a concept that mixes positive and negative attestations,
or successes and failures.
An example of a positive attestation is a diploma, which certifies that someone
graduated from a certain college with a certain degree.
Typically, people are happy to present positive attestations on demand,
but they do not have an incentive to report all the
times they failed.
Publication to a blockchain allows an identity to establish the completeness of a series of actions whose ratings are being reported.
Each identity in our framework is identified by a globally unique string and possesses a public/private keypair. An identity refers simply to this set of attributes. A principal may utilize many different identities, with or without links or attestations among them. The principals generate at least one identity for participating in each group of activities whose reputation they may want to reveal separately.
Our system involves interactions between three kinds of roles, some of which may be shared by a single identity: raters, who assign ratings; ratees, who receive ratings; and bazaars, which operate services in which raters rate ratees.
A reputation claim consists of: a rater; a ratee; a bazaar; a timestamp; (optionally) a subject identifier; (optionally) comments from the rater; a unique action identifier; the rater’s rating (a real number); the ratee’s desired weighting of the action; and a signature from the bazaar. The bazaar simply asserts that the rater rated the ratee as indicated. Typically, the bazaar would be an online service mediating a transaction, but it could be the same as the rater.
In order to receive ratings for an action X, Elizabeth:
-
Publishes an authorization to be rated on X to a blockchain. The authorization establishes that the ratee identity took the action being rated, and designates where the ratings should come from. The authorization specifies: the action identifier (X); the ratee (Elizabeth); the bazaar to collect the rating from the rater(s); whether only a single rating is expected, or many; the rating delivery frequency, if many ratings are expected; the ratee’s desired weighting for the action; (optionally) a subject identifier string; and a multisig of the above data by the ratee and the bazaar.
-
Receives deliveries of reputation claims from the bazaar, which it also publishes on the blockchain.
Bitcoin’s transaction capacity would not provide enough space for every authorization and reputation event to be published directly to its blockchain. Additionally, transaction fees would be prohibitive. We suggest that a bazaar that deals with large volumes of reputation events consolidate its posts, by posting a tiny URL of the complete event list along with a hash of the list’s contents. Interested verification services may follow all these links and expand them into a database of identities and their authorizations and ratings.
[1] https://en.wikipedia.org/wiki/Elliptic_Curve_Digital_Signature_Algorithm
[2] http://www.secg.org/sec2-v2.pdf
[3] https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki