TorCoin The power of distributed consensus on the Blockchain leveraged for Tor 1. Abstract 2. Introduction 3. Background 3.1. Tor Scaling Challenges 3.2. Leveraging the Blockchain 3.2.1. Distributed Consensus 3.2.2. Proof of Work 4. Design of TorCoin 4.1. Defining the Transaction 4.2. Validating the Transaction 4.4. Feasibility 5. Security of TorCoin 5.1. 51% Attack 5.2. Denial of Service 5.2.1. Tor DoS Vectors 5.2.2. Blockchain DoS Vectors 5.3. Timejacking 5.4 Sybil Attack 6. Further Work 6.1. P2P Voting 6.2. Hidden Services 6.3. Limited Network Knowledge 7. Conclusions 8. Acknowledgements 9. References 10. Our Code 1. Abstract In this paper we introduce TorCoin, a distributed consensus protocol based on the Bitcoin block chain. This protocol will be used to establish new nodes on the network, and to determine node validity and bandwidth. TorCoin will run in collaboration with TorFlow, an existing code designed to determine bandwidth and monitor node behavior, using an RPC interface. To handle the computational costs of mining, we propose to partially outsource these costs to the Bitcoin network using the existing work sharing protocol. We discuss our implementation and provide an analysis of security concerns. Finally, we provide proof of concept, along with potential directions for future work. 2. Introduction TorCoin is an altcoin used to achieve distributed consensus on the Tor network. It is designed to solve some of the scalability problems, specifically those related to the computational load on directory servers. In the current Tor protocol, the directory servers are trusted nodes which perform much of the administrative overhead, including regularly publishing a list of trusted nodes. As the size of the Tor network grows, it becomes increasingly more difficult for these nodes to make an accurate determination of which nodes are trusted on the time scale currently used. We propose using the Tor network to broadcast statements about their findings, and when something suspicious arises, the directory servers may intervene. Using the block chain inevitably involves extra computational work, as validating a transaction has nontrivial cost. This problem will be solved via shared work with the Bitcoin network, and will be discussed further on. Onion Routers only need to download block headers to determine current network state but may opt in to the mining pool to increase security. An important distinction between the Tor network and the Bitcoin network is that the Tor network contains implicitly trusted nodes. These nodes, titled directory servers, are assumed to be trusted at all times. These trusted nodes allow us to remove some of the potential vulnerabilities of Bitcoin, which will be discussed further in Section 5. 3. Background 3.1. Tor Scaling Challenges As the Tor network continues to grow, it is likely that the bandwidth, memory, or computational costs of keeping track of every node in the network will grow too large. TorCoin does not attempt to solve this problem. Instead, TorCoin solves problems related to specific resource bottlenecks: directory servers. Currently, directory servers keep track of all routers in the network and maintain this information is a constantly updated list. Additionally, these directory servers vote on the authenticity of each node in the network, and sign an agreed upon list, which is then routinely broadcast to the entire network. By using the collective resources of the network, the load on the directory servers can be drastically reduced. In addition, distributing the entire Tor network topology using a blockchain means that an onion proxy, while it may not be able to examine the entire network at once, can be sure it can verify the authenticity of a node by query the blockchain on disk. This means fully distributed circuit creating designs, such as SALSA, may be considered again as viable options for future work. We discuss this in Section 6.3. 3.2. Leveraging the Blockchain 3.2.1. Distributed Consensus The block chain is a ledger which maintains the full history of all transactions that have taken place on the network. This allows anyone to view the complete history of transactions at any time by requesting the block chain from the network and then simply reading through it. It does not, however, require that the entire block chain be in memory, which reduces network traffic and memory loads on nodes. The block chain is consistent across all nodes and therefore achieves consensus, even on a network of unknown size. 3.2.2. Proof of Work Every transaction that takes place on the network must be authenticated. This is done through what is called a ‘proof of work’. The proof of work involves calculating the hash of the signed transaction information along with a nonce, a node chosen set of bits, such that the hash takes a specific form. Our knowledge of hash functions tells us that we cannot know the output for a given input a priori, and so the nonce must be guessed continuously until the hash meets the requirements. This makes creating a transaction non trivial to add to the block chain, but also makes it difficult to undo previous transactions once authenticated. 4. Design of TorCoin 4.1. Defining the Transaction In our design of TorCoin, we modify the transaction format, as our consensus is unrelated to currency. Instead, we allow for three types of transactions: NODE_NEW, NODE_WARN, and NODE_AUDIT. The NODE_NEW transaction is broadcast whenever a router wants to join the Tor network as a node. The node will post its IP address, public key, Tor version, and advertised bandwidth. This node, assuming that the IP address has not been used before, will then be added to the block chain as a valid node. A new node can replace an old node on the same IP address by broadcasting a NODE_NEW transaction with a new public key after a set amount of time has passed since the previous broadcast. The NODE_WARN transaction is broadcast when a node suspects another node of providing false information or malicious behavior. A single warning transaction is not enough for any action to be taken, but given a sufficient amount of such transactions against a given node, the trusted directory servers will begin a node audit. The NODE_AUDIT transaction is broadcast only by a directory server after completing a node audit. This audit is signed, and is only accepted by the network once verified that it was sent by a directory server. The audit can either change the observed bandwidth of a node, or deem a node malicious and ban it. The following code snippet provides a pseudocode implementation of this transaction protocol. TorTx { SuperBlock { required public_key required TorBlock enum AdvertisementType { required BitcoinData NEW_NODE } NODE_AUDIT NODE_WARN } BitcoinData { required AdvertisementType // A Bitcoin format block header. required bytes header = 1; // params for NEW_NODE ip_address // The block’s first transaction tor_public_key required bytes coinbase_tx = 2; tor_version advertised_bandwidth // The merkle branch linking the // params for NODE_AUDIT // coinbase transaction to the signature // header. observed_bandwidth required bytes coinbase_merkle_branch node_validity = 3; // params for NODE_WARN // The coinbase scriptSig node_identity reason_code // Contains bits of data in order. } // Which one is our hash? required int coinbase_tx_index = 4; TorBlock { } torcoin_version prev_block_hash difficulty timestamp repeated TorTx required merkle_root required nonce } 4.2. Validating the Transaction When a node broadcasts a transaction message to be added to a block, the authenticity of the sender and the validity of the contents must be verified. Before adding a received transaction message broadcast to the current working block, the node will perform any checks required, including public key validation. 4.4. Feasibility In order to make this protocol viable, it must be the case that the additional computational costs are not excessive on Tor nodes, including those who opt­in to mining. Therefore, because mining is a computationally intensive activity, and because we do not plan to enforce participation by all nodes, the success of this protocol relies on the adoption of TorCoin in merged mining pools. Merged mining allows mining pools to opt­in to mining altcoins in addition to Bitcoin. This would outsource much of the computational cost to the Bitcoin network, and increase the available computational power of the TorCoin network. 5. Security of TorCoin Introducing the blockchain to Tor solves many scalability issues but, as with the introduction of any new codebase, brings with it all security vulnerabilities of the Bitcoin network. We will show that each of these vulnerabilities will not likely cause problems within the network. https://en.bitcoin.it/wiki/Weaknesses 5.1. 51% Attack This attack takes advantage of the fact that with over half of the power of the network, an adversary can effectively bully the network into submission. For TorCoin and the Tor network in general, the definition of power is important to define. There are two attack vectors here: node count, and node computational power. Possession of over 50% of the nodes in the Tor network is something that should be either dealt with by the Tor protocol, and so is not discussed here further. Possession of over 50% of the computational power in the Tor network is an entirely different issue. Tor is designed to provide anonymity in web browsing. The users and the node owners may be anyone, and the hardware is nonstandard. In the Bitcoin network, currency is at stake, and its inherent lucrative nature attracts users with powerful hardware. The TorCoin network needs to be able to handle the introduction of a computationally powerful adversary, something Tor does not necessarily worry about (although exceptionally high bandwidth capable nodes can cause some problems). Specifically, such an adversary should not be able to bully other nodes around or cause a DoS via the creation of excessive work for a node, in ways they were unable to do before.
Details
-
File Typepdf
-
Upload Time-
-
Content LanguagesEnglish
-
Upload UserAnonymous/Not logged-in
-
File Pages8 Page
-
File Size-