The present invention relates to a method and system for a trusted execution environment-based proof of stake protocol for distributed ledger systems.
Distributed ledger systems are a type of distributed database management system that allow for data (e.g., transactions, metadata, etc.) to be recorded, shared, and synchronized across a distributed network of different network participants (e.g., nodes). A blockchain is particular type of data structure used in some distributed ledger systems that facilitates the storage and distribution of data in packages called “blocks” that are digitally connected to each other in a “chain.” Blockchain technology provides a decentralized, open, Byzantine fault-tolerant transaction mechanism.
Distributed ledger systems, particularly those using blockchain technology, are becoming common for various types of Internet interactions, including anonymous online payments, remittance, and the transaction of digital assets (e.g., digital currencies). Cryptocurrencies (a type of digital currency), such as Bitcoin, Litecoin, Dogecoin, and Ethereum, are well-recognized examples of distributed ledger systems implemented with blockchain technology.
In spite of much skepticism, cryptocurrencies have experienced significant attention and market adoption, with Bitcoin in particular garnering the widest adoption and attention compared to other cryptocurrencies proposed to date. Indeed, Bitcoin currently holds the largest market share among existing cryptocurrencies, with a market capitalization in the tens of billions of U.S. dollars. One of the (many) reasons that led to the sustainability of the Bitcoin system was the large investments made by several mainstream companies in large data centers that are equipped with dedicated Proof of Work (PoW) mining capabilities.
PoW is a technique used to establish consensus in distributed ledger systems. For example, in some blockchain systems (e.g., Bitcoin, Litecoin, Dogecoin, and Ethereum), in order to add a new block to the chain (i.e., a new set of transactions to the ledger), a PoW is required. A PoW is a computational challenge that is hard to solve (in terms of computing power and processing time) but easy to verify. In some distributed ledger systems, the process of generating the PoW is called “mining.”
Most of the existing blockchain protocols rely on the concept of PoW to prevent Sybil attacks in permissionless networks (e.g., where the attacker subverts the reputation system of a peer-to-peer network by creating a large number of pseudonymous identities and uses them to gain a disproportionately large influence). Unfortunately, PoW-based blockchains require miners to invest large amounts of computing power for reaching agreement in the network, resulting in a comparable amount of energy waste; for instance, it is estimated that Bitcoin miners can consume as much electricity as Australia in 2018.
To remedy the problem of wasteful computation which is inherent in PoW, a promising alternative is to make the mining process dependent on virtual resources rather than computation. The most prominent example of this paradigm considers as mining resource the stake owned by users, giving rise to energy-efficient consensus Proof of Stake (PoS) protocols.
Although several PoS protocols have been proposed in the recent years, PoS blockchains are not widely deployed, yet. Indeed, despite offering greatly improved performance and scalability compared to their PoW counterparts, PoS protocols still account for less than 2% of the market capitalization of existing digital currencies. This is due to existing PoS proposals being vulnerable to a number of security threats which do not arise, or are automatically taken care of, in the context PoW blockchains. In particular, in the PoS scenario it is hard to offer protection against long-range attacks, in which adversaries re-write the history of the blockchain starting from some block generated far in the past. The most devastating type of long-range attacks—and also the hardest to mitigate—exploits posterior corruption of users: the adversary obtains the secret keys of honest users who jointly held majority of stake at some point the past, and uses the stake associated to these keys (which now can be administrated by the adversary) to build an alternative, valid blockchain.
Most existing PoS proposals that explicitly aim at mitigating long-range attacks use checkpoints, which instruct nodes to reject any blockchain that differs from the local one more than a given number of blocks (meaning that no modification is allowed prior to the checkpoint). While checkpoints do mitigate long-range attacks under the assumption that all users are online and receive messages quickly, they provide no protection in the realistic blockchain scenario in which new users may join the network at any time and/or may be available only sporadically. For instance, a new user that retrieves two different blockchains, one maintained by a honest node and one by the adversary, has no way to discern which one they should trust.
An embodiment of the present invention provides, a method that prevents posterior-corruption long-range attacks in a proof of stake blockchain protocol on a blockchain network. The method includes: generating, by a blockchain node, a fresh key pair, having a fresh public key to be included into a transaction and a fresh private key to be used for signing a next transaction; generating, by the blockchain node, the transaction having as an input an overall stake associated to an account of the blockchain node, and as an output a transfer stake to be transferred to a second node's public key, and a remaining account stake to be transferred to the fresh public key; signing, by the blockchain node, the transaction with a previous private key; and broadcasting, by the blockchain node, the generated transaction to the blockchain network.
The present invention will be described in even greater detail below based on the exemplary figures. The invention is not limited to the exemplary embodiments. All features described and/or illustrated herein can be used alone or combined in different combinations in embodiments of the invention. The features and advantages of various embodiments of the present invention will become apparent by reading the following detailed description with reference to the attached drawings which illustrate the following:
Embodiments of the present invention provide a Proof of Stake (PoS) blockchain protocol that relies on trusted execution environments (TEEs) for mining, and offers strong security even if some of the TEE devices are compromised. The present invention includes multiple embodiments addressing the problem of long-range attacks in the presence of compromised TEEs.
This invention includes two preferred embodiments having novel mechanisms to prevent long-range attacks based on posterior corruption of users. Embodiments of the present invention leverage trusted execution environments (TEEs) to guarantee sufficiently honest behavior of validators, and additionally seek protection against a powerful adversary that manages to compromise some of the TEE devices. Each of the preferred embodiments address the same security threat, namely preventing an adversary from exploiting the accounts of corrupt validators who held majority of stake in the past.
The first preferred embodiment includes a novel key-evolving mechanism to prevent an adversary, who corrupts users in the present, from transferring the stake held by these users in the past. The second preferred embodiment includes a new mining process for PoS to prevent an adversary from exploiting the stake held by validators in the past. Other embodiments of the present invention may use one or both techniques of the preferred embodiments.
In a blockchain system according to an embodiment, users issue transactions to exchange digital currency, and sign these transactions with account-specific keys to prevent tampering. Validators (a.k.a. “miners” in PoS) instead have the role of confirming transactions by regularly producing blocks. Everybody must register as a user prior to becoming a validator and being eligible to generate blocks. In contrast, users do not need to become validators in order to issue transactions.
In this blockchain system, validators are equipped with mining devices offering a trusted execution environment (TEE), such as Intel SGX. The validators implement a PoS protocol. The TEE devices provide trusted block signing, and offer remote attestation and sealing services. Should a TEE device be compromised, however, these features can no longer be guaranteed for that device.
The specifics of the mining protocol executed by validators, and in particular the operations executed within the TEE, are not essential to the present invention, and a person of ordinary skill in the art would readily understand how to implement them. For the sake of presentation, it is assumed that each validator may execute the mining process by passing as input a list of transactions TX=(TX1, . . . , TXt), the blockchain BC=(B0, . . . , Br-1) they wish to extend, and obtaining as output a candidate “next block” Br or an indication of ineligibility. However, embodiments of the present invention are not so limited.
Advantageously, embodiments of the present invention limit the effect of posterior corruption in Proof of Stake (PoS) protocols. Most existing PoS protocols promise protection against long-range attacks by employing checkpoints, but for that checkpoint method to work, it relies on high network synchronicity and continuous participation of validators. Embodiments of the present invention avoid checkpoints, and their associated issues, and thus offer an enhancement over the state of the art PoS protocol systems.
A first preferred embodiment of the present invention improves, for example, the underlying PoS protocol by introducing a key-evolving mechanism for users. The key-evolving method does not rely on any existing forward-secure cryptographic building block, but uses the blockchain as a medium to make the (public) key-updates visible to other nodes, resulting in a more efficient and flexible solution than those based on forward-secure cryptographic primitives.
A second preferred embodiment of the present invention, utilizing a modification of the notion of stake as mining resource, offers, for example, protection against compromised TEEs with no performance overhead: it effectively only requires validators to maintain two kinds of stake information per user, the currency stake and the mining stake (rather than just the currency stake).
Both preferred embodiments independently provide an improved PoS protocol by also offering security against long-range attacks in case an adversary compromises TEE devices and manages to obtain the corresponding signing keys. While described separately, embodiments of the present invention (or features thereof) may be used together as well as separately.
In an embodiment, a blockchain user performs a method for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol on a blockchain network that includes: generating an initial key pair, having an initial public key and initial private key, for signing transactions; generating a fresh key pair, having a fresh public key and a fresh private key, for signing transactions; generating a transaction having as an input an overall stake associated to an account of the block, and as output the stake to be transferred to a validator's public key, an appropriate transaction fee, and the remaining account stake to be transferred to the fresh public key; broadcasting the generated transaction to the blockchain network; receiving an indication that the broadcast transaction is confirmed; and deleting the initial key pair based upon receiving the indication that the broadcast transaction is confirmed.
After generating the initial key pair, the blockchain user can purchase digital currency and issue a corresponding transaction on the blockchain network indicating that the blockchain user with that initial public key has an initial stake corresponding to the purchased digital currency.
The blockchain user can generate a new fresh key pair for every transaction the block chain user issues and can delete the previous fresh key pair when a current broadcast transaction is confirmed.
An embodiment of the present invention includes a blockchain node having a processor and a memory, the memory containing processor executable instructions that, when executed by the processor, cause the processor to perform the following operations for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol in a blockchain network: generating an initial key pair, having an initial public key and initial private key, for signing transactions; generating fresh key pair, having a fresh public key and a fresh private key, for signing transactions; generating a transaction having as an input an overall stake associated to an account of the block, and as output the stake to be transferred to a validator's public key, an appropriate transaction fee, and the remaining account stake to be transferred to the fresh public key; broadcasting the generated transaction to the blockchain network; receiving an indication that the broadcast transaction is confirmed; and deleting the initial key pair based upon receiving the indication that the broadcast transaction is confirmed.
Alternatively or additionally, an embodiment of the present invention may include a method, performed by a blockchain validator, for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol in a blockchain network that includes: initializing and registering a trusted execution environment (TEE) device; generating a block on a local blockchain branch of the blockchain validator; and validating an alternative blockchain of the blockchain network based on public keys of TEE devices associated with each block leader. The PoS block chain protocol includes two kinds of stake information, the currency stake and the mining stake.
The initializing and registering operation can include: generating a signing key pair, including a public key and a private key; remotely-attesting the trusted enclave application, including generating an attestation certificate; and issuing a registration transaction to distribute the attestation certificate. The registration transaction can specify an amount of mining stake purchased by the blockchain validator. Once the registration transaction is confirmed, the TEE device becomes capable of mining blocks in the blockchain network.
The generating a block operation can include: generating an eligibility proof within the trusted enclave application; determining that the blockchain validator is eligible to generate the block for a considered round, preparing, based on determining the blockchain validator is eligible to generate the block, a block header and requesting a corresponding block signature from the trusted application enclave; signing the block with the block signature; and broadcasting the signed block to the blockchain network.
The validating the alternative blockchain operation can include: receiving the alternative blockchain; and verifying a consistency of a latest block's timestamp of the alternative blockchain against a local time. If the verifying fails, the alternative blockchain is rejected. Otherwise the blockchain validator performs the following verification operations for all blocks of the alternative blockchain, starting with the latest block: verifying that a block signature is valid with respect to the public key of the TEE device associated to the block leader; verifying that the block leader was eligible for the corresponding round with respect to the block leader's mining stake; verifying that the header is well-formed and points to a previous block; and verifying that transactions included in the block are valid.
In an embodiment, a blockchain node that includes a processor and a memory, the memory containing processor executable instructions that, when executed by the processor, cause the processor to perform the following operations for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol in a blockchain network: initializing and registering a trusted execution environment (TEE) device; generating a block on a local blockchain branch of the blockchain validator; and validating an alternative blockchain of the blockchain network based on public keys of TEE devices associated with each block leader.
In an embodiment, there is provided a method that includes: generating, by a blockchain node, (a sequence of) key pairs for signing and allowing verification of transactions. In an embodiment, the private key is for signing and the public one is for allowing verification.
A method of an embodiment prevents posterior-corruption long-range attacks in a proof of stake blockchain protocol on a blockchain network. The method includes: generating, by a blockchain node, a fresh key pair, having a fresh public key to be included into a transaction and a fresh private key to be used for signing a next transaction; generating, by the blockchain node, the transaction having as an input an overall stake associated to an account of the blockchain node, and as an output a transfer stake to be transferred to a second node's public key, and a remaining account stake to be transferred to the fresh public key; signing, by the blockchain node, the transaction with a previous private key; and broadcasting, by the blockchain node, the generated transaction to the blockchain network.
The method may further include: receiving, by the blockchain node, an indication that the broadcasted transaction is confirmed; and deleting, by the blockchain node, the private key associated with the broadcasted transaction based upon receiving the indication that the broadcasted transaction is confirmed.
The transaction may be signed with a most recent non-fresh private key.
The blockchain node may generate a new fresh key pair for every transaction the blockchain node issues and may delete a previous fresh key pair when a previously broadcasted transaction is confirmed.
Another embodiment of the present invention provides a blockchain node, which includes a processor and a memory. The memory includes processor executable instructions that, when executed by the processor, cause the processor to perform the following operations for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol in a blockchain network: generate a fresh key pair, having a fresh public key to be included into a transaction and a fresh private key, to be used for signing a next transaction; generate a transaction having as an input an overall stake associated to an account of the blockchain node, and as output a transfer stake to be transferred to a second node's public key, and a remaining account stake to be transferred to the fresh public key; sign the transaction with a previous private key; and broadcast the generated transaction to the blockchain network.
The instructions can be configured to further cause the processor to perform the following operations: receive an indication that the broadcasted transaction is confirmed; and delete the private key associated with the broadcasted transaction based upon receiving the indication that the broadcasted transaction is confirmed.
The transaction can be signed with a most recent non-fresh private key.
In an embodiment, the blockchain node generates a new fresh key pair for every transaction the blockchain node issues and deletes a previous fresh key pair when a previously broadcasted transaction is confirmed.
In an embodiment, the instructions are configured to further cause the processor to perform the following operations: generate an initial key pair; purchase digital currency and issue a corresponding transaction on the blockchain network indicating that the blockchain node with the initial public key has an initial stake corresponding to the purchased digital currency.
Another embodiment of the present invention provides a method for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol in a blockchain network. The method includes: generating, by a blockchain node associated with a TEE device, a signing key pair, including a public key and a private key; remotely-attesting, by the blockchain node, a trusted enclave application, including generating an attestation certificate; and issuing, by the blockchain node, a registration transaction to distribute the attestation certificate; the registration transaction specifying an amount of mining stake purchased by the blockchain validator. Once the registration transaction is confirmed, the TEE device becomes enabled for mining blocks in the blockchain network.
In an embodiment, the registration transaction is confirmed based on the registration transaction appearing in a block of the blockchain that is followed by a predetermined number of blocks.
In an embodiment, the registration transaction is confirmed further based on the blockchain node generating an eligibility proof within the trusted enclave application.
The method may further include: determining, by the blockchain node, that the blockchain node is eligible to generate the block for a considered round; preparing, by the blockchain node based on determining the blockchain node is eligible to generate the block, a block header and receiving a corresponding block signature from the trusted application enclave; signing, by the blockchain node, the block with the corresponding block signature; and broadcasting, by the blockchain node, the signed block to the blockchain network.
The method may further include a method of an offline node that connects to the blockchain network to confirm a version of the blockchain that includes: receiving, by the blockchain node, a blockchain, verifying, by the blockchain node, a consistency of a latest block's timestamp of the blockchain against a local time; and if the verifying fails, rejecting by the blockchain node, the blockchain, otherwise the blockchain node performs a verification operation for all blocks of the blockchain.
The verification operation may include, for each of the blocks and starting with a latest block of the blocks: verifying that a block signature is valid with respect to the public key of the TEE device associated with a corresponding block leader; verifying that the corresponding block leader was eligible for a corresponding round with respect to the corresponding block leader's mining stake; verifying that a corresponding header is well-formed and points to a previous block of the blocks; and verifying that transactions included are valid.
In an embodiment, blockchain nodes implement a method for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol in a blockchain network, the method includes the following operations:
In another embodiment, blockchain nodes, with a TEE device for mining, implement a method for preventing posterior-corruption long-range attacks in a proof of stake blockchain protocol in a blockchain network, the method includes the following operations:
Embodiments of the present invention are further described below in connection with the figures. The invention is not limited to the exemplary embodiments.
In the blockchain system 100, validators 106 are implemented with mining devices (e.g., computers) having a trusted execution environment (TEE), such as Intel SGX. The validators 106 implement a PoS protocol. The TEE of each validator 106 provides trusted block signing, and offer remote attestation and sealing services.
A first preferred embodiment will be explained further with reference to
The first preferred embodiment of the present invention includes a novel mechanism to update the account keys of blockchain users. A feature behind this method is to let users regularly delete old keys so that corruption of a user's account cannot be exploited to issue transactions in the past, as these transactions would have to be signed with old keys. The key-update mechanism only affects the format of transactions and does not imply any modification to the mining protocol for validators.
As described in technical detail below, the first preferred embodiment includes: (1) employing a key-evolving mechanism to limit the effect of key exposure in the context of posterior-corruption of users; and (2) leveraging the public-ledger functionality of the blockchain to make the key-update mechanism more efficient than traditional key-evolving cryptographic techniques.
Referring to
Upon joining the blockchain network 200b, the user U 200a generates an initial signing key-pair (pkU0, skU0) (S201).
The user U200a may optionally purchase a given amount of stake SU, otherwise their stake is set to SU=0. In an embodiment, the stake may be purchased as digital currency in exchange for other currency (e.g., fiat currency).
To purchase stake, the user U 200a issues a purchase-stake transaction Txpurchase. For example, the user U200a can broadcast the purchase-stake transaction TXpurchase to the blockchain network 200b (S202a).
After the user U200a broadcasts the purchase-stake transaction TXpurchase to the blockchain network 200b, at least one validator 200c will receive the purchase-stake transaction TXpurchase (S202b).
The validator 200c then confirms the purchase-stake transaction TXpurchase (S203). Once confirmed, the validator 200c will create a new block that includes the purchase-stake transaction TXpurchase (S204). The validator 200c will then add the new block to the blockchain (S205), and broadcast the updated blockchain to the blockchain network 200b (S206).
Because the purchase-stake transaction TXpurchase is confirmed and included in a block of the blockchain, the other blockchain nodes are effectively informed that a new user with account public-key pkU0 and initial stake SU joined the blockchain network 200b.
Whenever the user U 200a wishes to transfer a given amount of stake s≤SU, where SU is the current account balance of U, to some other user account V, U issues a corresponding transaction TX that, beyond respecting the transaction format of the underlying digital currency, shall indicate public key pkU as the source account, pkV as the destination account, and x as the amount of stake to be transferred. User U 200a also encapsulates into TX a second type of information, namely an updated account public-key.
Referring back to
The user U200a then broadcasts the resulting transaction TX to the blockchain network 200b (S209a).
At least one validator 200c can then receive the broadcast transaction TX (S209b). The validator 200c will then confirm the transaction TX (S210), generate a new block including the transaction TX (S211), add the new block to the blockchain (S212), and then broadcast the updated blockchain to the blockchain network (S213).
Subsequently, the transaction TX can be confirmed by another user W 200d. The user W 200d will receive the blockchain (S214), and then the user W 200d can confirm the transaction TX by checking to see if it appears in one of the blocks of the blockchain and is “sufficiently deep” in the blockchain (S215). If the transaction TX is confirmed, the user W 200d registers pk′U as the current public key of user U 200a (S216).
The issuer user U200a can also confirm the transaction TX. Here, the user U200a will receive the blockchain (S217) and confirm the transaction TX (S218). After the transaction TX is confirmed by the issuer user U 200a, the user U 200a will delete its outdated secret key skU and use (pk′U, sk′U) as its current key pair (S219).
Transactions are confirmed (or validated) against the (current) public key pkissuer of the issuer as well as their amount of stake held by them, according to the validation predicate specified by the digital currency. Transactions may be confirmed in this manner by a validator or a user. Furthermore, a validated transaction may also be confirmed that it is finalized or settled by determining whether the transaction is part of a block that is sufficiently deep.
The key-evolving mechanism of the present embodiment is based on forward-secure cryptography, which in-turn, is based on frequent key updates coupled with secure deletion of old keys. Forward-secure cryptography specifically aims at limiting the effect of key exposure, namely it guarantees that data protected in the past remains secure.
A blockchain user (e.g., via a device—such as computer device—used by a user of the blockchain network) can implement the first preferred embodiment. For example, the blockchain user my perform initialization and key update operations, such as described above, to prevent long-range attacks based on posterior corruption of users.
A second preferred embodiment includes a novel mining procedure for PoS blockchain protocols. The second preferred embodiment uses the concept of stake and introduces an abstraction of a PoS protocol in which the stake is decoupled into two resources: (1) one resource used exclusively for transferring value (stake as “digital currency”); and (2) the other resource used exclusively for generating blocks (stake as “mining resource”). The mining stake is assigned to each validator upon joining the mining protocol and cannot be transferred to other validators. In this way, an adversary cannot take advantage from corrupting validators owning majority of mining stake in the past, as the mining stake would have to be moved to the adversary's validator account, which is disallowed by the protocol.
For the description of the second preferred embodiment, it is assumed that a PoS scenario exists where any user who wishes to become a validator is be equipped with a TEE device and remote-attests it prior to registering it to the blockchain network as a new mining device. Also, a new node should be registered as a user in order to become a validator. Hence, as detailed below, it is assumed that a user U owns a stake Su at the moment of registering their TEE device for mining.
A blockchain node may implement a method according to the second preferred embodiment (e.g., via a blockchain node's device—such as a computer device—configured to execute the method) to prevent posterior-corruption long-range attacks in a proof of stake blockchain protocol. Here, the blockchain node may perform one or more of the following operations: (1) initialization and registration of the TEE device; (2) block generation; and (3) blockchain validation.
In the initialization and registration of the TEE device operation, the blockchain node: (1) generates a signing key pair within the trusted enclave application of the TEE device; and (2) remotely-attests the trusted application and issues a registration transaction to distribute the attestation certificate (this transaction specifies the amount of mining stake purchased by the validator). Once the registration transaction is confirmed, the TEE device can be used for mining.
In the block generation operation, the blockchain node: (1) generates the eligibility proof within the trusted application; (2) if eligible to generate a block for the considered round, prepares the block header and requests the corresponding block signature from the trusted application; and (3) broadcasts the signed block to the blockchain network.
In the block validation operation, the blockchain node, upon receiving an alternative chain, verifies the consistency of the latest block's timestamp against the local time. If the verification succeeds, the blockchain node validates the block of the blockchain according to its verification procedure.
An implementation of the method according to the second preferred embodiment is explained in detail below with reference to
As shown in
The user U 500a then generates a registration transaction TXreg (S503). The generated registration transaction TXreg includes the public key pkU of the user U500a, the public key pkUT associated with the TEE signing key, and the mining stake MSU, 0≤MSU≤min{SUMSmax}, to be allocated to the user U 500a's mining device. Here, MSmax is a protocol-specific threshold determining the maximum amount of mining stake that can be awarded to validators. The mining stake is effectively purchased in exchange of digital currency, hence it cannot exceed the balance of user U 500a.
The user U 500a can then register the TEE by issuing broadcasting the registration transaction TXreg to the blockchain network 500b (S504). However, the user U 500a does not become a recognized as a validator in the blockchain network 500b until the registration transaction TXreg is confirmed. According to an embodiment, the registration transaction TXreg is confirmed if it appears in a “sufficiently deep” block of the blockchain. A “sufficiently deep” block is one that is followed by N many blocks, where N is a parameter of the underlying PoS protocol.
Thus, to get the registration transaction TXreg on the blockchain—and to get it sufficiently deep in the blockchain—a current validator 500c will need to receive the registration transaction TXreg (S505), confirm the registration transaction TXreg (S506), generate a block that incorporates the registration transaction TXreg (S507), add the block to the blockchain (S508), and broadcast the new blockchain to the blockchain network 500b (S509). Depending on how the blockchain protocol defines the parameter for when a block is “sufficiently deep”, other blocks may need to be generated by a current validator (such has validator 500c or another validator) before the user U200a can be recognized as a validator.
Once the user U 200a is recognized as validator, it can start mining blocks of the blockchain (i.e., it will be eligible to execute the block generation operation). As part of the block generation operation, the user U 200a may itself first determine whether it is eligible to mine blocks (S511). The user U200a may initiate such self-determination after receiving a new transaction from the blockchain network 200b (S510).
To determine its eligibility, the user U200a may generate the eligibility proof within the trusted enclave application. The eligibility proof may include checking to see if its registration transaction TXreg is included in the blockchain, that its registration transaction TXreg is valid (e.g., by checking the signature against its keys), and checking to see that the registration transaction TXreg is included in a block of the blockchain that is sufficiently deep. The user U200a may check its eligibility before each attempt to generate a new block, or may check its eligibility only up to the time it first confirms that it is eligible to act on the blockchain network as a validator.
If the user U 200a is eligible to operate as validator in a given round r, it will generate a block Br following the procedure indicated by the underlying PoS protocol. The validator will receive a reward for contributing the mining process: part of it in digital currency (e.g., the overall amount of fees for the transactions included in the block), and part of it in mining stake (e.g., an amount corresponding to the block reward). To this end, the user U 200a can execute the underlying PoS mining protocol, such that the validators are weighed depending on their mining stake MSU rather than their currency stake SU.
Referring back to
The user U200a can then generate the block (S513), add the signed block to the blockchain (S514), and broadcast blockchain to the blockchain network 500b (S515).
According to a method implementing the second preferred embodiment, a blockchain validator may execute a block validation operation. The block validation operation closely follows the underlying PoS protocol, and includes checking the eligibility of an alleged block leader U against their mining stake MSU (rather than their currency stake SU).
For example, referring back to
As described in technical detail above, a method according to the second preferred embodiment includes: (1) Identifying a PoS abstraction that reflects the dual nature of stake as currency and as mining resource; (2) Binding mining resources to their owners for limiting the effect of posterior corruption of validators; and (3) Enforcing a single enclave per TEE platform to weaken the voting power of compromised TEE devices.
In the context of the envisioned PoS scenario, the protocol of embodiments of the present invention offers security in the presence of compromised TEE devices as long as each device can support at most one enclave at a time. Embodiments guarantee this through the remote-attestation procedure. More concretely, if the TEE is instantiated with Intel SGX or with TMP, the attestation quote includes an EPID or a DAA pseudo-name, respectively, which can be configured as linkable or un-linkable depending of the choice of the base-name. Using the linkable mode, all quotes produced by the same platform must use the same base-name, hence multiple enclaves running on the same platform result in the same EPID/DAA signature authenticating the quotes. The protocol of embodiments of the present invention enforces the linkable mode, and thus guarantees that an adversary launching different enclaves on the same TEE platform will be detected. Put differently, the only way for an adversary to obtain considerable voting power is to compromise several TEE devices (corresponding to majority of mining stake), which is essentially unfeasible.
While the invention has been illustrated and described in detail in the drawings and foregoing description, such illustration and description are to be considered illustrative or exemplary and not restrictive. It will be understood that changes and modifications may be made by those of ordinary skill within the scope of the following claims. In particular, the present invention covers further embodiments with any combination of features from different embodiments described above and below. Additionally, statements made herein characterizing the invention refer to an embodiment of the invention and not necessarily all embodiments.
The terms used in the claims should be construed to have the broadest reasonable interpretation consistent with the foregoing description. For example, the use of the article “a” or “the” in introducing an element should not be interpreted as being exclusive of a plurality of elements. Likewise, the recitation of “or” should be interpreted as being inclusive, such that the recitation of “A or B” is not exclusive of “A and B,” unless it is clear from the context or the foregoing description that only one of A and B is intended. Further, the recitation of “at least one of A, B and C” should be interpreted as one or more of a group of elements consisting of A, B and C, and should not be interpreted as requiring at least one of each of the listed elements A, B and C, regardless of whether A, B and C are related as categories or otherwise. Moreover, the recitation of “A, B and/or C” or “at least one of A, B or C” should be interpreted as including any singular entity from the listed elements, e.g., A, any subset from the listed elements, e.g., A and B, or the entire list of elements A, B and C.
The present application claims priority to U.S. Provisional Patent Application No. 62/737,987, filed on Sep. 28, 2018, the entire contents of which is hereby incorporated by reference
Number | Date | Country | |
---|---|---|---|
62737987 | Sep 2018 | US |