1. Introduction
With the emergence of the Internet of Things (IoT), innovative applications are rapidly increasing [
1]. Current IoT systems generally consist of designated lightweight devices with sensors. The devices collect data from the surrounding environment and exchange data with other devices, servers or platforms. In traditional IoT systems, the collected data are stored by centralized cloud servers, and users must trust these servers. Despite the indisputable benefits provided by these services, these centralized IoT systems face the following potential issues:
	  
Blockchain [
4], which was first proposed by Bitcoin [
5], may be a solution to the above issues of centralized IoT systems due to blockchain’s properties, such as tamper-resistance, confidentiality and decentralization. Moreover, blockchain offers the functionality of smart contracts [
6], which are programs recorded on the blockchain that can be triggered by events. Thereby, smart contracts can assist devices in being more intelligent since the behavior of an IoT device can be specified by a set of smart contracts.
Currently, blockchain-enabled IoT systems are a popular research area. However, most previous constructions have not solved the issue of leaking sensitive information to servers since servers can obtain plaintext data from devices. Furthermore, in some previous constructions, although servers can only obtain encrypted data, they cannot perform homomorphic computations on encrypted data from devices. Previous studies focused on five main aspects: data sharing [
7,
8], data storage [
9,
10], access control [
11,
12,
13], smart IoT [
1,
14,
15,
16,
17] and edge computing [
18,
19].
Recently, in [
20], we proposed a confidential blockchain-enabled IoT system called BeeKeeper 1.0, where servers cannot decrypt any encrypted data from devices but can perform homomorphic computations on the encrypted data. Consequently, although BeeKeeper 1.0 addressed the issue of leaking plaintext data to servers, it has the following limitations:
	  
- Servers can perform only one-degree homomorphic multiplication and any number of homomorphic additions on encrypted data from a device. 
- Pairing (an expensive computation) [ 21- ] is used to verify the correctness of responses sent by the servers. 
- Only one device can send encrypted data and requests to the servers. 
In this paper, we further study the confidential blockchain-enabled IoT system and propose a novel construction, BeeKeeper 2.0, which is much more functional and efficient than BeeKeeper 1.0 [
20]. Specifically, BeeKeeper 2.0 has the following improvements:
	  
- Servers can perform any-degree () homomorphic multiplications and any number of homomorphic additions on encrypted data from devices. 
- Pairing is not used to verify the correctness of the responses of the servers. 
- Devices can automatically start or restart the service protocol. 
- Each device can send encrypted data and requests to the servers. In this way, each device can share its data with other devices by sending encrypted data to the servers, and each device can use the data shared by all devices by sending requests to servers. 
- With more and more peers of blockchain willing to act as servers, the overall processing power of the system will gradually increase. 
A basic instance of BeeKeeper 2.0 includes a group of devices, servers and validators of the blockchain. The servers can help devices process encrypted data from other devices according to requests of the devices without leaking plaintext data to the servers. The devices and servers communicate with each other by using transactions of the blockchain. The validators of BeeKeeper 2.0 are almost the same as the validators of other blockchain platforms. The only difference is that the validators of BeeKeeper 2.0 have to check the validity of commitments (e.g., signature, verification key and commitments of secret data) included in the transaction payload, in addition to general verifications. Only transactions accepted by the validators can be recorded in the blockchain.
For the BeeKeeper 2.0 system, blockchain is necessary since it provides the following benefits:
	  
- Tamper-resistance. All verification algorithms use the verification key (VK) to check the validity of the data, so the validity and tamper-resistance of the VK should be guaranteed. Fortunately, storing the VK in the blockchain is a suitable solution. On the one hand, due to blockchain’s tamper-resistance, once data have been recorded in the blockchain, the data can be seen as immutable. On the other hand, the blockchain validators can help peers verify the VK before it is recorded in the blockchain, and only the VK accepted by the validators can be recorded. Consequently, once a VK has been recorded in the blockchain, it can be seen as valid and immutable. 
- Validators of the blockchain help devices and servers verify publicly verifiable data. In BeeKeeper 2.0, most data (e.g., verification key, commitments of core-shares and commitments of responses) are publicly verifiable. If these data can be verified by some trusted party and only data accepted by the trusted party can be seen by others, the devices and servers would not need to verify them. Fortunately, in the blockchain network, all publicly verifiable transaction data can be verified by the validators before these transactions are recorded in the blockchain, and only transactions accepted by the validators can be recorded. Consequently, the validators can help devices and servers verify publicly verifiable data. In this way, the verification computation of devices and servers can be substantially reduced. 
Our contributions. In summary, the contributions of this paper are as follows:
	  
- We propose a decentralized outsourcing computation (DOC) scheme based on blockchain, where servers can perform any-degree homomorphic multiplications and any number of homomorphic additions on encrypted data from the data owner. In the scheme, the servers cannot obtain any plaintext data, and if a server computes dishonestly, it will be detected by the validators of the DOC scheme and the data owner. To the best of our knowledge, this is the first work on a decentralized outsourcing computation scheme. 
- By applying the DOC scheme in the IoT scenario, we achieve a confidential blockchain-enabled IoT system with fully homomorphic computation, called BeeKeeper 2.0. We instantiate all building blocks of BeeKeeper 2.0. To the best of our knowledge, this is the first work in which: (i) devices can share their data with each other; (ii) servers can perform any-degree homomorphic multiplications and any number of additions on encrypted data from devices according to the requests of the devices; (iii) servers cannot obtain any plaintext data; and (iv) dishonest servers can be detected by the validators of the blockchain and the devices. 
- By using Hyperledger Fabric blockchain as the carrier of the BeeKeeper 2.0 system, a detailed performance evaluation of BeeKeeper 2.0 was obtained. Moreover, we used Hyperledger Caliper for performance testing. According to our tests, the time cost between the request stage and the recover stage is no more than 3.3 s, which theoretically meets the production needs. 
  2. Overview of BeeKeeper 2.0
By applying the DOC scheme, which is presented in 
Section 4, in the IoT scenario, we construct BeeKeeper 2.0, a confidential blockchain-enabled IoT system with fully homomorphic computation. BeeKeeper 2.0 can function on top of any blockchain platform (e.g., Bitcoin [
5], Ethereum [
6] and Hyperledger Fabric [
22]).
A basic instance of the BeeKeeper 2.0 system includes a group of devices, a certain number of servers and validators of the blockchain. The devices and servers are peers of the blockchain. Any peer can become a server of devices as long as the peer and owner of the devices desire. The validators are responsible for verifying all transactions before these transactions are recorded in the blockchain, and only transactions accepted by the validators can be recorded. The validators of BeeKeeper 2.0 are almost the same as the validators of other blockchain platforms. The only difference is that the validators of BeeKeeper 2.0 have to check the validity of commitments included in the transaction payload, in addition to general verifications. An overview of BeeKeeper 2.0 is shown in 
Figure 1.
A BeeKeeper 2.0 system consists of the following algorithms:
	  
The system also includes five new transactions: TX, TX, TX, TX and TX. Specifically, TX includes a verification key (VK); TX includes encrypted core-shares (each encrypted core-share is encrypted by using a different server’s public-key) and commitments of core-shares; TX includes encrypted numbers; TX includes a request; and TX includes an encrypted response (the response is encrypted by using a device’s public-key) and a response’s commitment.
In this paper, we hope to complete a scenario as follows:
	  
- Devices generate supplementary data for servers, and then send these data to servers secretly. By using the supplementary data, a server can process encrypted data from devices according to request of devices. 
- Devices send encrypted data to servers. In this way, devices can share their data with each other without leaking plaintext data to servers. 
- At some time, some device wants to get a result, which can be computed with data shared by devices. Then, it sends a request to servers. 
- According to the request sent by the device, a server can process encrypted data shared by devices with supplementary data and obtain a response. Then, the server sends its response to the request devices secretly. 
- If the request devices can collect a certain number of valid responses, it can obtain its desired result. 
- In this process, supplementary data and responses are verifiable. Moreover, by using the commitment technology, they can be publicly verifiable, and validators of blockchain can help users verify the related data. 
Similar to the above scenario, the BeeKeeper 2.0 system works as follows:
	  
- One device executes a  algorithm to generate TX and TX. TX includes a verification key, while TX includes encrypted core-shares (each encrypted core-share is encrypted by using a different server’s public-key) and commitments of core-shares. Then, the device sends these two transactions to the blockchain network. 
- Validators execute a _TX algorithm to verify TX. TX will be recorded in the blockchain iff _TX outputs 1. Otherwise, the process returns to Step 1. Besides, the validators also execute a _TX algorithm to verify TX. TX will be recorded in the blockchain iff _TX outputs 1. Otherwise, the process returns to Step 1. 
- Each server executes a  algorithm to check its encrypted core-share. The encrypted core-share is valid iff  outputs 1. 
- Each device executes an  algorithm to generate TX; then, it sends TX to the blockchain network. 
- Some device executes a  algorithm to generate TX; then, it sends TX to the blockchain network. 
- According to the transaction TX, a server executes a  algorithm to generate a TX, which includes an encrypted response (the response is encrypted by using the request device’s public-key) and this response’s commitment. Then, the server sends TX to the blockchain network. 
- The validators execute a _TX algorithm to verify TX. TX will be recorded in the blockchain iff _TX outputs 1. 
- The request device executes a  algorithm to check the encrypted responses recorded in the corresponding TXs. An encrypted response is valid iff  outputs 1. 
- When the request device has collected at least the threshold number of valid responses, it can execute a  algorithm to obtain the desired result. 
BeeKeeper 2.0 has the following properties:
	  
- Decentralization. Any peer of the blockchain can become a server of devices when desired by the peer and owner of the devices. 
- Scalability. With more and more peers of the blockchain willing to act as servers, the overall processing power of the BeeKeeper 2.0 system gradually increases. 
- Confidentiality. Servers cannot obtain any plaintext data. 
- Full homomorphism. Servers can perform any-degree homomorphic multiplications and any number of additions on encrypted data according to the requests of devices. 
- Public verifiability. Most verifiable data can be verified publicly. Therefore, the validators can help the devices and servers verify these publicly verifiable data. Moreover, these data can be verified efficiently. For instance, verifying a response of 10-degree polynomial of shared data takes approximately 0.0122 s; verifying a VK, which can be used to verify a response of 10-degree polynomial of shared data, takes approximately 1.33 s. 
- Non-interactive. Servers can perform high-degree homomorphic multiplications and additions on encrypted numbers without interaction. Furthermore, verifiable data can be verified without interaction. 
- Fault-tolerant. The BeeKeeper 2.0 system works as long as a threshold number of servers are honest and willing to serve devices. 
- Lightweight. On the one hand, devices and servers do not need to maintain large storage since encrypted data are recorded in the blockchain. On the other hand, devices do not need a high-performance processor since computation on the data is performed by servers and the vast majority of verification work is performed by the validators of the blockchain. 
- Data sharing. Devices can share their own data with other devices in a confidential way. Each device can utilize the whole data shared by other devices. 
  3. Background of Fully Homomorphic Non-Interactive Verifiable Secret Sharing
In our work, the main cryptographic primitive used is a fully homomorphic non-interactive verifiable secret (FHNVSS) sharing scheme [
23]. We use the FHNVSS scheme to achieve a decentralized outsourcing computation (DOC) scheme, which is presented in 
Section 4. In this section, we briefly provide the basic background of the FHNVSS scheme. Details of the FHNVSS scheme can be found in Ref. [
23].
A FHNVSS scheme includes a dealer, which is the data owner, and a certain number of servers. Concretely, the dealer confidentially shares numbers to servers by sending core-shares and encrypted numbers to the servers. When the dealer wants to obtain a result, which can be an any-degree polynomial of shared numbers, it sends a request to the servers. Then, the servers, without interaction, generate responses with encrypted numbers according to the request of the dealer. Once the dealer receives a threshold number of valid responses, it obtains the desired result. In this process, the VK, core-shares and responses are verifiable. Therefore, malicious participants and invalid data can be detected.
  3.1. Data of FHNVSS
A FHNVSS scheme has the following six types of data.
        
- VK. The verification key (VK) is generated by the dealer. First, the validity of the VK can be verified publicly and used to verify the validity of the core-shares and responses. 
- Core-shares. Core-shares are generated by the dealer and sent to the servers (each server will be given one set of core-shares). 
- Encrypted numbers. Encrypted numbers are generated by the dealer and sent to the servers. 
- Request. A request is generated by the dealer and sent to the servers. 
- Responses. Responses are generated by the servers and sent to the dealer. 
- Result. When the dealer collects a threshold number of valid responses, it can recover the desired result with these responses. 
  3.2. FHNVSS Algorithms
A FHNVSS scheme is a tuple of polynomial-time algorithms (A polynomial-time algorithm means that the time complexity of the algorithm is 
, where 
n is the size of input of the algorithm):
		
- (, t, n, IDs)→ (, n core-shares) - Upon input of a security parameter , the threshold t, the number of all shareholders n and all shareholders’ IDs,  randomly outputs a verification key (VK) and n core-shares for the n shareholders. 
- (VK) - Upon input of a VK, the verifier  outputs  iff the VK is valid. 
- (core-share, ID, VK, sk) - Upon input of a core-share, ID (a shareholder’s ID), VK and sk (a shareholder’s secret key), the verifier  outputs  iff the core-share is valid. 
- (core-share, request)→ a response - Upon input of a core-share and a request, the generator  outputs a response. 
- (response, ID, VK, sk) - Upon input of a response, ID (a shareholder’s ID), VK and sk (the dealer’s secret key), the verifier  outputs  if the response is valid. 
- (responses, IDs)→ a result - Upon input of the threshold number of responses and the senders’ IDs of these responses,  outputs a result. 
  3.3. Work Process of FHNVSS
We take a  FHNVSS scheme as an example to present the working process:
		
- Step 1: The dealer generates n sets of core-shares and a verification key (VK). Then, the dealer opens the VK. Anyone (including servers) can verify whether the VK is correctly computed by the dealer. If the VK is invalid, the dealer has to regenerate the core-shares and VK, else the participants join in the next step. 
- Step 2: The dealer secretly sends n sets of core-shares to n servers. After receiving a core-share, a server can verify whether his core-share is valid via the VK. If the server’s core-share is invalid, he can ignore it and request that the dealer resends it. 
- Step 3: The dealer encrypts secret numbers into encrypted numbers and then sends the encrypted numbers to the servers. 
- Step 4: When the dealer needs to obtain a result, which could be an any-degree polynomial of secret numbers, it sends a request to n servers. 
- Step 5: According to the request sent by the dealer, each active server will independently generate a response with its core-share (this process has no interaction with the other servers). Then, the server will send its response to the dealer securely. 
- Step 6: After receiving the responses, the dealer can verify whether the responses are correctly computed by the corresponding servers. These verifications do not require interaction with the servers. If a response is invalid, the dealer can ignore the response or request that the corresponding server resend a response. Finally, the dealer can recover the desired result if it collected at least t valid responses. 
  4. Decentralized Outsourcing Computation Scheme
In this section, we present a decentralized outsourcing computation (DOC) scheme based on blockchain and the FHNVSS scheme [
23]. A basic instance of the DOC scheme includes a dealer, a certain number of servers and validators of the blockchain. In this instance, the dealer and servers execute a FHNVSS scheme by sending transactions to the blockchain. The validators check all transactions, and only transactions accepted by the validators can be recorded in the blockchain. Specifically, the dealer uses transactions to publish the verification key (VK), send encrypted core-shares to servers and publish encrypted numbers to servers; servers use transactions to send encrypted responses to the dealer; and the validators of the blockchain check all these transactions before they are recorded in the blockchain. In the following, we present all data structures, algorithms and a detailed work process of the DOC.
  4.1. Data Structure
A DOC scheme has the following ten types of data structures:
Ledger. The DOC scheme can be applied on top of any blockchain (ledger) platform that is a sequence of transactions, such as Bitcoin, Ethereum and Hyperledger Fabric. At any given time T, all users have access to , that is, the ledger at time T. The ledger is append-only (i.e.,  implies that  is a prefix of ). The transactions in the ledger include Basecoin transactions and new types of transaction that are described below.
Address. Each peer in the blockchain network can generate an arbitrary number of key pairs. In the DOC scheme, a key pair is (
, 
), where 
 (
G is a base point of ECC [
24] and 
 is a 256-bit random number). Furthermore, 
 is also an address (ID).
Commitment. We use the point multiplication of ECC to compute a commitment of a private value as follows:
		
        where 
a is the private value and 
G is a base point of ECC.
Signature. We use a digital signature scheme :
		
- S(. Given a secret key  and a message m, S signs m to obtain a signature . 
- V. Given a public-key , message m and signature , V outputs  iff the signature  is valid for m; else, it outputs . 
Public-key encryption. We use a public-key encryption scheme Enc = (E, D):
		
- E(. Given a public-key  and a message m, E encrypts m to obtain a ciphertext c. 
- D. Given a secret key  and ciphertext c, D outputs a message m. 
The components of the DOC scheme include a dealer and a certain number of servers. The verification key, core-share, request, response and result are generated by the dealer and servers. The details of these five types of data can be found in Ref. [
23]. In the following, we briefly present these data structures.
Verification key. A verification key (VK) is a set of commitments of coefficients of polynomials that are randomly sampled by the dealer, and the VK is available to all users in the DOC scheme. A VK is generated by the dealer at the “start time” and can be used in all verification algorithms.
Core-shares. When calculating the VK, the dealer randomly samples a set of polynomials. Then, it inputs the ID of each server into these polynomials to generate a core-share for this server. Therefore, a core-share is a set of random numbers in , where q is the prime order of G.
Request. A request is a polynomial as follows:
		
        where 
 are symbols. 
 corresponds to 10 plaintext numbers that do not reveal plaintext numbers. According to this polynomial, the servers will know how to process their encrypted numbers.
 Response. After seeing a request sent by the dealer, a server will generate its response to this request, as well as its core-share and encrypted numbers. A response is a number in .
Result. After receiving a threshold number of valid responses, the dealer will use Lagrangian interpolation to recover the desired result, which is a number in .
New transactions. These five types of data will be recorded in the payload of transactions. Therefore, a DOC scheme has five new types of transactions (TX, TX, TX, TX, and TX).
        
- TX. A verification key transaction TX includes only a verification key (VK). 
- TX. A core-share transaction TX is a tuple (, , …,, , , …,), where  is the commitments of the core-share of the ith server and  is the encrypted core-share of the ith server, . 
- TX. An encrypted numbers transaction TX includes a set of encrypted numbers. 
- TX. A request transaction TX includes a request. 
- TX. A response transaction TX is a tuple (), where  is a commitment of a response and where  is an encrypted response. 
  4.2. Algorithms
A DOC scheme is a tuple of polynomial-time algorithms:
		
        with the following syntax and semantics.
        
- (, t, n, IDs)→ (, n core-shares, TX, TX). - Upon input of a security parameter , the threshold t, the number of all servers n and the IDs of the servers,  randomly outputs a verification key (VK), n core-shares of n servers, TX and TX. The  algorithm is executed by the dealer and is not reused until the dealer wants to restart the DOC scheme. TX includes VK, while TX includes commitments of core-shares and encrypted core-shares. 
- (numbers, key secret)→ (encrypted numbers, TX). - Upon input of numbers and the key secret,  outputs encrypted numbers and TX. The  algorithm is executed by the dealer. TX includes VK encrypted numbers. 
- (request)→ (TX). Upon input of a request,  outputs a TX. The  algorithm is executed by the dealer. TX includes only a request. 
- (request, encrypted numbers, core-share)→ (response, TX). - Upon input of a request, encrypted numbers, and core-share,  outputs a response and TX. The  algorithm is executed by the servers. TX is a tuple (), where  is a commitment of a response and  is the encrypted response. 
- (t responses, t IDs)→ (result). s Upon input of t responses and t IDs,  outputs a result. The  algorithm is executed by the dealer. 
Verify transactions. The algorithm  is used to check the validity of the commitments in a transaction, and it has three variants _TX, _TX and _TX), which are executed by the validators of the blockchain. Only transactions with valid commitments can be recorded in the blockchain. _TX checks the validity of the VK in the TX; VerifyTx_TX uses the VK to check the validity of the commitments of the core-shares in the TX; and VerifyTx_TX uses the VK to check the validity of the commitment of the response in the TX. The three algorithms output a bit b:  iff the corresponding transaction’s commitments are valid.
Check encrypted messages. The  algorithm checks the encrypted messages in a transaction payload, and it has two variants:  and .  is executed by the servers to check whether the commitment of a plaintext core-share equals the commitment of the core-share recorded in the TX.  is executed by the dealer to check whether the commitment of a plaintext response equals the commitment of the response recorded in the TX. The two algorithms output a bit b:b = 1 iff the commitment of plaintext data equals the commitment of data recorded in the corresponding transaction.
Remark 1. The security of DOC is based completely on the FHNVSS scheme [23]. The security analysis of the FHNVSS scheme can be found in Ref. [23].    4.3. Construction of a Decentralized Outsourcing Computation Scheme
In this subsection, we construct a (
) decentralized outsourcing computation (DOC) scheme, which includes 
 clients and a certain number of validators of the blockchain. Specifically, one of these 
 clients acts as a dealer, and the other 
n clients act as servers. In the following, the work process of DOC scheme is presented, and it is also illustrated in 
Figure 2.
        
- Step 1: The dealer executes the  algorithm to obtain two transactions TX and TX and then sends these two transactions to the validators. 
- Step 2:
             - –
- The validators execute algorithms _TX and _TX to verify TX and TX, respectively. If _TX outputs 1, the validators accept TX. If _TX outputs 1, the validators accept TX. The transactions accepted by the validators will be recorded in the blockchain. 
- –
- After TX is recorded in the blockchain, each server executes the  algorithm to check the encrypted core-share in TX. If  outputs 1, the server accepts this encrypted core-share in TX. 
 
- Step 3: The dealer executes the  algorithm to obtain a transaction TX and sends this transaction to the blockchain network. 
- Step 4: The dealer executes the  algorithm to obtain a transaction TX and sends this transaction to the blockchain network. 
- Step 5: According to TX, each server executes the  algorithm to obtain a transaction TX and sends this transaction to the validators. 
- Step 6:
             - –
- The validators execute the algorithm _TX to verify TX. If _TX outputs 1, the validators accept TX, and the accepted TX will be recorded in the blockchain. Otherwise, the validators will reject it. 
- –
- After TX is recorded in the blockchain, the dealer executes the  algorithm to check the encrypted response in TX. If  outputs 1, the dealer accepts this encrypted response in TX. 
 
- Step 7: When the dealer receives t valid responses, the  algorithm is executed to obtain the desired result. 
Remark 2. In this work, we hope to achieve that data recorded in the blockchain are credible. Therefore, publicly verifiable data (e.g., verification key, commitments of core-shares and responses, and encrypted numbers) should be stored in the blockchain and be verified by validators. These data can provide the credibility of the system. Thereby, these data are stored in the blockchain in this manuscript. Indeed, this will add certain burden of system storage since the storage space is one of the main limitations of blockchain. However, we know that the main part of the storage space is used by the encrypted numbers. Thereby, we can solve the storage issue by modifying the working mode. For instance, the dealer sends the encrypted numbers to servers off-chain, and it only stores a hash value of the encrypted numbers in the blockchain. In this way, servers can also check the integrity of encrypted numbers received, which reduces the storage burden of the system. Besides, validators cannot help the dealer verify the correctness of responses, and the dealer has to perform the response verification by itself. This modified working mode makes a compromise between credibility and storage issue.
   5. BeeKeeper 2.0
In this section, we first instantiate all the building blocks of DOC; then, the instantiated DOC scheme is deployed in the IoT scenario to achieve a confidential blockchain-enabled IoT system, called BeeKeeper 2.0. In BeeKeeper 2.0, the dealer is replaced by a group of devices, and the devices can share their data with each other and use other devices’ data in a confidential manner. The servers can help the devices perform fully homomorphic computations on encrypted data from other devices according to the request of a device, but they cannot obtain any plaintext data.
  5.1. Instantiation of Building Blocks
In this subsection, we instantiate all the building blocks of the DOC scheme. These building blocks are used in the BeeKeeper 2.0 system.
Instantiating large number computations. Algorithms 
, 
, 
, 
 and 
 are all executed with 256-bit large number computation and a 256-bit large prime field. We utilized the Python GNU Multiple Precision (GMP) Arithmetic Library [
25] to calculate the large number computations of 
.
 Instantiating commitments. Algorithms 
, 
 _TX
, 
_TX
, 
_TX
, 
 and 
 either compute with commitments or generate commitments. These commitments are the results of point multiplications of ECC. We used the high-speed Pairing-Based Cryptography (PBC) library [
26] to compute the point multiplications of ECC.
 Instantiating pairing. We also used the high-speed PBC library [
26] to compute pairing. TX
 has a set of commitments as follows:
		
        where 
 are points of ECC generated by 
G, which is the base point of ECC. 
 are commitments of 
 and no one can obtain 
 from 
. The validity of 
 is verified by using pairing 
. Specifically, 
 are valid iff the following formulas hold.
        
 Next, we explain why the above equations verify the validity of . Let the hidden value of  be s. If , it demonstrates that hidden value of  is ; if , it demonstrates that hidden value of  is ; etc. Similarly, if , it demonstrates that hidden value of  is .
Instantiating Signature. Every transaction should include the signature of the transaction’s generator. A transaction with an incorrect signature is invalid. We used secp256k1-based, which is an elliptic curve, and ECDSA [
27] as the signature scheme 
 to sign transactions.
 Instantiating Encryption. TX
 and TX
 include some encrypted core-shares and responses. We used secp256k1-based ECIES [
28], which is a public-key encryption scheme, as the encryption scheme 
 to encrypt the core-shares and responses. With this encryption scheme, only the holder of the corresponding secret key can decrypt the encrypted data.
 Instantiating the hash function. We used SHA-256 [
29] as the hash function H to compute the hash value.
 Instantiating the DOC scheme. We implemented all algorithms of the DOC scheme in Python on a Linux server with 16 GB RAM and a 3.1 GHz processor. Moreover, we deployed the instantiation of the DOC on the Hyperledger Fabric blockchain to construct the BeeKeeper 2.0 system as a blockchain-enabled intelligent lightweight IoT system.
  5.2. Construction of BeeKeeper 2.0
A basic instance of the BeeKeeper 2.0 system includes a group of devices and a certain number of servers. Specifically, in a basic instance of BeeKeeper 2.0, once the devices have been set, they will work automatically. In the following, we consider a basic instance to present the work process of the BeeKeeper 2.0 system. We omit the verification process since it is the same as that of DOC.
Setup. The devices select one device to execute the  algorithm to generate transactions TX and TX, and this selected device sends these two transactions to the blockchain network. If the devices want to update TX and TX, they reselect a device re-execute the  algorithm.
Share data. Each device can execute the  algorithm to generate TX and send this transaction to the blockchain network. This device can execute the  algorithm as many times as desired. All devices can independently and continuously run the  algorithm to share their data with each other in this way.
Request and respond. Each device can execute the  algorithm to generate TX, which is used to let the servers help the devices perform homomorphic computations on the encrypted data shared by all devices. Then, the device sends this transaction to the blockchain network. Next, servers execute the  algorithm to generate TX according to the requests recorded in the TX. At that time, they sends their own TXs to the blockchain network. Each device can execute  as many times as desired. Each device can independently and continuously use the encrypted data shared by all devices in this method.
Recover. When a device has received at least the threshold number of valid responses, the  algorithm is executed to recover the desired result.
In practical applications, algorithms belong to different participants (dealer and servers). The affiliation of these functions is shown in 
Table 1.
  6. Performance Evaluation
In this section, we present a performance evaluation of the BeeKeeper 2.0 system by deploying the system on the Hyperledger Fabric blockchain. Specifically, we deploy the BeeKeeper 2.0 system and Hyperledger Fabric on four Ubuntu 16.04 environment servers with 2 GB RAM and a 1 GHz processor. A series of measurements are made with respect to the blockchain performance and algorithm performance. The theoretical throughput of Hyperledger is about 2000 TPS (TPS denotes transactions per second) in actual production environment. Limited by the testing environment, the testing system’s throughput can only reach about 100 TPS, so we simply measured the success rate of the system as an example of what would happen when the invoke concurrency is fast outpacing the throughput of the blockchain. Once the system is deployed to production environment, no transactions would fail unless the concurrency is beyond the processing rate of the blockchain. In the following, the performance of the algorithms is presented.
  6.1. Performance of the BeeKeeper 2.0 Algorithms
In our experiments, we deployed a (3,4) BeeKeeper 2.0 system on our could servers, where (3,4) means that there are four servers and that the desired result can be recovered with at least three valid responses sent by the servers. We implemented all the algorithms of BeeKeeper 2.0 in Python. In this implementation, the high-speed Pairing-Based Cryptography (PBC) library [
26] was used to compute the point multiplication of ECC and pairing; the GNU Multiple Precision (GMP) Arithmetic Library [
25] was utilized to calculate the large number computations; and SHA-256 was used as the hash function. All large number computations were computed over a 256-bit large prime number that is the order of the base point of ECC. We tested the performance of all the algorithms by varying the maximum degree of the polynomial that the servers can calculate from 4 to 10. The performance of the algorithms is illustrated in 
Table 2.
  6.2. Large-Scale Network Simulation
In terms of the blockchain performance, we used Hyperledger Fabric [
22] as the carrier of the BeeKeeper 2.0 system and used Hyperledger Caliper [
30] for performance testing. The algorithms of BeeKeeper 2.0 were invoked in the blockchain. Because the throughput of Hyperledger Fabric on our test environment is nearly 100 TPS, we performed high-concurrency performance testing to simulate a high TPS scenario.
The main indicators include chaincode invoke latency, success rate, query latency and send rate. Specifically, chaincode invoke latency denotes the latency in a transaction being uploaded in the blockchain; success rate refers to the probability that the transactions were successfully recorded in the blockchain; query latency is the latency for a peer to query the blockchain; and send rate (TPS) denotes the number of transactions sent by peers per second.
In our tests, we varied the send rate from 50 to 300 TPS to observe how the other indicators change with the send rate. We then analyzed the efficiency of the system based on the results of these measurements.
The change in the 
chaincode invoke latency with the send rate is illustrated in 
Figure 3. According to 
Figure 3, the average chaincode invoke rate gradually increases as the send rate increases. When the send rate reaches 300 TPS, the chaincode invoke latency decreases slightly.
The change in the 
success rate with the send rate is illustrated in 
Figure 4. According to 
Figure 4, the average success rate gradually decreases as the send rate increases. When the send rate is 300 TPS, the success rate increases slightly.
The success rate shown in 
Figure 4 is the success rate measured around the bottleneck of the cluster’s total throughput. The bottleneck of a cluster’s bottleneck will vary with the processing speed of each server and the size of the entire cluster. If it can be deployed in a large enough cluster, throughput would theoretically increase to 2000 TPS. However, limited by the environment, we deployed on four dual-core cloud servers and measured that the throughput is about 100 TPS, so we selected several sets of send rates around the throughput bottleneck to show what would happen when the send rate fast outpaces the bottleneck of throughput. Once the system is deployed in the production environment, as long as the throughput bottleneck (i.e., around 2000 TPS) is not exceeded, the success rate of the algorithm execution will always be 100%.
The change in the 
query latency with the send rate is illustrated in 
Figure 5. According to 
Figure 5, the query average latency gradually increases as the send rate increases. The query speed is less affected by the throughput, and the success rate is stable at 100%. Therefore, we take the reading speed of 2.83 s measured at 500 TPS.
In our test environment, the throughput (send rate) of the system is approximately 100 TPS. According to our test results in 
Figure 3, 
Figure 4 and 
Figure 5, when the throughput reaches 100 TPS: (i) the average transaction time by the blockchain is approximately 2.51 s; (ii) the average success rate of transactions being recorded in the blockchain is approximately 73%; and (iii) the query latency is approximately 0.2 s. However, once the system be deployed in the real-world environment, the success rate of it would constantly be 100%.
To analyze the time consumed by each step of BeeKeeper 2.0 in practical applications, we deployed a (3,4) BeeKeeper 2.0 system in our test environment. Furthermore, we set the largest degree of polynomial that the servers can process to 10. Moreover, to ensure an adequate success rate for satisfactory user experience and operation in practice, we set the initial value of throughput to 100 TPS since the test environment throughput of our system is approximately 100 TPS. Therefore, BeeKeeper 2.0 includes seven steps, as mentioned in 
Figure 2, since the BeeKeeper 2.0 system process is similar to that of a DOC scheme. The time consumption of the steps in the actual process is shown in 
Figure 6. In the case that the network is not blocked, the processing speed is approximately 2.51 s, and the total time from the begin to the end of the process is less than 2.94 s, which is completely acceptable and even improves upon the processing speed of the current blockchain. Therefore, the encryption computing power required by this protocol can also be borne by a mobile terminal, and it is highly adaptable. If the blockchain is completely used as a medium for data sharing instead of as a smart contract platform, a small hash rate is required for an endorser node.
According to 
Figure 6, the protocol steps with the greatest time consumption in the whole test process are Steps 2 and 6 (4.2 s and 2.9 s, respectively), and the cost of these steps is allocated to the preparation stage and verification process before the on-chain operations. These two steps have no effect on obtaining a result quickly. Step 4 is the request stage; Steps 5 and 6 are the respond stage; and Step 7 is the recover stage. According to 
Figure 6, the time consumed between sending a request and recovering the final result is approximately 3.3 s. Therefore, the processing speed on the chain can theoretically reach 3.3 s. For the BeeKeeper 2.0 system, this speed will not result in any additional burden or delay, thus the actual test of the IoT blockchain system theoretically satisfies the production needs.
  7. Conclusions
We studied a blockchain-enabled IoT system. First, we proposed a decentralized outsourcing computation (DOC) scheme, where servers can perform homomorphic computations on encrypted data and users can verify whether the servers are honest. Second, we applied the DOC scheme in an IoT scenario to achieve a blockchain-enabled intelligent lightweight IoT system, called BeeKeeper 2.0. In the BeeKeeper 2.0 system, devices can share their own data without leaking plaintext data to the servers, and devices can use the data shared by all devices by sending requests to the servers. Finally, we conducted a detailed performance evaluation of the BeeKeeper 2.0 system. Specifically, we deployed the BeeKeeper 2.0 system on the Hyperledger Fabric blockchain and used the Hyperledger Caliper for performance testing. According to our tests, when the servers can process at most 10-degree polynomials of shared numbers with encrypted numbers, the time consumed between the request stage and the recover stage is approximately 3.3 s, which theoretically satisfies production needs.
   
  
    Author Contributions
Conceptualization, L.Z. and L.W.; Methodology, L.Z.; Software, T.A.; Validation, L.Z., L.W. and Y.S.; Formal Analysis, L.W.; Investigation, Y.S.; Resources, T.A.; Data Curation, T.A.; Writing—Original Draft Preparation, L.Z. and T.A.; Writing—Review and Editing, L.Z., Y.S. and T.A.; Visualization, T.A.; Supervision, L.W.; Project Administration, L.Z.; and Funding Acquisition, L.W.
Funding
This research received no external funding.
Acknowledgments
This work was supported by the National Key Research and Development Program (No. 2016YFB0800602), the National Natural Science Foundation of China (NSFC) (No. 61502048), and Shandong provincial Key Research and Development Program of China (2018CXGC0701, 2018GGX106005).
Conflicts of Interest
The authors declare no conflict of interest.
References
- Dorri, A.; Kanhere, S.S.; Jurdak, R. Towards an optimized blockchain for IoT. In Proceedings of the Second International Conference on Internet-of-Things Design and Implementation (IoTDI 2017), Pittsburgh, PA, USA, 18–21 April 2017; pp. 173–178. [Google Scholar]
- De Montjoye, Y.A.; Shmueli, E.; Wang, S.S.; Pentland, A.S. Openpds: Protecting the privacy of metadata through safeanswers. PLoS ONE 2014, 9, e98790. [Google Scholar] [CrossRef] [PubMed]
- Top Strategic Predictions for 2017 and beyond: Surviving the Storm Winds of Digital Disruption. Available online: https://www.gartner.com/doc/3471568?ref=unauthreader (accessed on 14 October 2016).
- Zheng, Z.; Xie, S.; Dai, H.-N.; Chen, X.; Wang, H. Blockchain Challenges and Opportunities: A Survey. Int. J. Web Grid Serv. 2017, 14, 352–375. [Google Scholar] [CrossRef]
- Nakamoto, S. Bitcoin: A Peer-to-Peer Electronic Cash System. 2008. Available online: https://bitcoin.org/bitcoin.pdf (accessed on 31 October 2008).
- Wood, G. Ethereum: A Secure Decentralised Generalised Transaction Ledger. 2018. Available online: http://gavwood.com/Paper.pdf (accessed on 3 February 2018).
- Rahulamathavan, Y.; Phan, R.C.-W.; Rajarajan, M.; Misra, S.; Kondoz, A.M. Privacy-preserving Blockchain based IoT Ecosystem using Attribute-based Encryption. In Proceedings of the 2017 IEEE International Conference on Advanced Networks and Telecommunications Systems (ANTS 2017), Bhubaneswar, India, 17–20 December 2017. [Google Scholar]
- Krishnan, M.A.; Shankar, C.G.; Raj, S.A.; Ragavan, A. Peer to Peer File Sharing by Blockchain Using IOT. 2017. Available online: http://ijsrset.com/IJSRSET173253 (accessed on 30 April 2017).
- Conoscenti, M.; Vetrò, A.; De Martin, J.C. Peer to Peer for Privacy and Decentralization in the Internet of Things. In Proceedings of the 39th International Conference on Software Engineering Companion, Buenos Aires, Argentina, 20–28 May 2017; pp. 288–290. [Google Scholar]
- Liu, B.; Yu, X.L.; Chen, S.; Xu, X.; Zhu, L. Blockchain Based Data Integrity Service Framework for IoT Data. In Proceedings of the 2017 IEEE International Conference on Web Services (ICWS), Honolulu, HI, USA, 25–30 June 2017; pp. 468–475. [Google Scholar]
- Wu, L.; Du, X.; Wang, W.; Lin, B. An Out-of-band Authentication Scheme for Internet of Things Using Blockchain Technology. In Proceedings of the 2018 International Conference on Computing, Networking and Communications (ICNC 2018), Maui, HI, USA, 5–8 March 2018. [Google Scholar]
- Ouaddah, A.; Elkalam, A.A.; Ouahman, A.A. Towards a novel privacy-preserving access control model based on blockchain technology in IoT. In Europe and MENA Cooperation Advances in Information and Communication Technologies; Springer: Cham, Switzerland, 2017; pp. 523–533. [Google Scholar]
- Sonnino, A.; Al-Bassam, M.; Bano, S.; Danezis, G. Coconut: Threshold Issuance Selective Disclosure Credentials with Applications to Distributed Ledgers. arXiv, 2018; arXiv:1802.07344. [Google Scholar]
- Huh, S.; Cho, S.; Kim, S. Managing IoT devices using blockchain platform. In Proceedings of the 2017 19th International Conference on Advanced Communication Technology (ICACT), Bongpyeong, Korea, 19–22 February 2017; pp. 464–467. [Google Scholar]
- Lamichhane, M. A smart waste management system using IoT and blockchain technology. Int. J. Adv. Eng. Res. Sci. 2017, 4, 93–95. [Google Scholar]
- Dorri, A.; Kanhere, S.S.; Jurdak, R.; Gauravaram, P. Blockchain for IoT security and privacy: The case study of a smart home. In Proceedings of the 2017 IEEE International Conference on Pervasive Computing and Communications Workshops (PerCom Workshops), Kona, HI, USA, 13–17 March 2017; pp. 618–623. [Google Scholar]
- Di Pietro, R.; Salleras, X.; Signorini, M.; Waisbard, E. A blockchain-based Trust System for the Internet of Things. In Proceedings of the 23nd ACM on Symposium on Access Control Models and Technologies (SACMAT 2018), Indianapolis, IN, USA, 13–15 June 2018. [Google Scholar]
- Sharma, P.K.; Chen, M.-Y.; Park, J.H. A Software Defined Fog Node Based Distributed Blockchain Cloud Architecture for IoT. IEEE Access 2018, 6, 115–124. [Google Scholar] [CrossRef]
- Pahl, C.; El Ioini, N.; Helmer, S. A Decision Framework for Blockchain Platforms for IoT and Edge Computing. In Proceedings of the 3rd International Conference on Internet of Things, Big Data and Security (IoTBDS 2018), Funchal, Portugal, 19–21 March 2018; pp. 105–113. [Google Scholar]
- Zhou, L.; Wang, L.; Sun, Y.; Lv, P. BeeKeeper: A Blockchain-based IoT System with Secure Storage and Homomorphic Computation. IEEE Access 2018, 6, 43472–43488. [Google Scholar] [CrossRef]
- PBC Library. Available online: https://crypto.stanford.edu/pbc/download.html (accessed on 14 June 2013).
- Androulaki, E.; Barger, A.; Bortnikov, V.; Cachin, C.; Christidis, K.; De Caro, A.; Enyeart, D.; Ferris, C.; Laventman, G.; Manevich, Y.; et al. Hyperledger Fabric: A Distributed Operating System for Permissioned Blockchains. In Proceedings of the Thirteenth EuroSys Conference (EuroSys 2018), Porto, Portugal, 23–26 April 2018; pp. 30:1–30:15. [Google Scholar]
- Zhou, L.; Wang, L.; Ai, T.; Sun, Y. AntNest: Fully Non-interactive Secure Multi-party Computation. Available online: https://eprint.iacr.org/2018/735.pdf (accessed on 20 September 2018).
- Barreto, P.S.; Naehrig, M. Pairing-friendly elliptic curves of prime order. In Proceedings of the 12th International Workshop on Selected Areas in Cryptography (SAC 2005), Kingston, ON, Canada, 11–12 August 2005; pp. 319–331. [Google Scholar]
- Join GitHub Today. Available online: https://github.com/aleaxit/gmpy (accessed on 15 April 2018).
- A Defunct and Ancient Set of Python Bindings for Pairing Based Cryptography. Available online: https://github.com/debatem1/pypbc (accessed on 8 November 2017).
- Johnson, D.; Menezes, A.; Vanstone, S.A. The elliptic curve digital signature algorithm (ECDSA). Int. J. Inf. Secur. 2001, 1, 36–63. [Google Scholar] [CrossRef]
- Smart, N.P. The exact security of ECIES in the generic group model. In Proceedings of the 8th IMA International Conference on Cryptography and Coding, Cirencester, UK, 17–19 December 2001; pp. 73–84. [Google Scholar]
- Gilbert, H.; Handschuh, H. Security Analysis of SHA-256 and Sisters. In Proceedings of the 10th Annual International Workshop on Selected Areas in Cryptography (SAC 2003), Ottawa, ON, Canada, 14–15 August 2003; pp. 175–193. [Google Scholar]
- Hyperledger Caliper. Available online: https://www.hyperledger.org/projects/caliper (accessed on 22 December 2016).
© 2018 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (http://creativecommons.org/licenses/by/4.0/).