Why the Gordian Architecture?
Figuring out how to access full-node services through a mobile client has been a long-standing problem for Bitcoin users, resulting in the creation of multiple protocols intended for exactly this purpose. We believe that the simple method of accessing full-node RPC services through Tor slices right through this long-standing problem in Bitcoin development. It supports Independence, Openness, and Privacy, which are three of Gordian’s core principles.
Blockchain Commons is all about solving the knotty problems in blockchain infrastructure that are holding back our joint development. That’s why we have the Borromean Rings in our logo. One twist of the magician’s hands, and they’re split apart. We hope to similarly make other problems of blockchain infrastructure go away, with our “not for profit” open source and open development work. The Gordian architecture is just one such project (or rather: many such projects).
Why Run a Full Node?
Running a full node such as GordianServer supports many of the Gordian Principles and also offers other advantages.
- Validation is the most important reason to operate a Bitcoin full node. With a full node, Bitcoin users can check whether transactions are valid according to all of Bitcoin’s rules. Users can verify that any bitcoins they receive are legitimately mined, correctly signed, and more. This ensures your independence by maintaining Bitcoin as a trustless solution. Without your own full node you lose that because you are inherently trusting a third party to tell you how many bitcoins you own and to construct transactions correctly; with your own full node you can personally verify with certainty that your bitcoins are real, that they belong to you, and that they get sent to the intended recipient.
- Without a full node, you are relying on someone else’s server. Therefore, they know all your addresses and spending habits as well how much money you have. Obviously, this is not ideal. Utilizing your own node allows you to use Bitcoin in a much more private way whereby you do not need to leak your transaction patterns to a third party.
- A full node such as GordianServer can take advantage of a Torgap for enhanced privacy. When you use the clearnet, all of your devices’ network traffic is highly correlatable, making it trivial for third parties to track which websites you visit. They could easily see Bitcoin related traffic linked to your IP address, and since IP addresses can be tied to physical locations, this poses a risk. This is where Tor comes in: with GordianServer all remote RPC access to your GordianServer is obfuscated with Tor. For example, you may use the GordianWallet app over Tor to get information from your node and it would be very difficult for any third party to see that your device is speaking to a Bitcoin Core node, let alone what it is specifically doing.
- GordianServer installs Bitcoin Core, which is the reference implementation of Bitcoin. That means that you are utilizing one of the most highly peer reviewed and scrutinized pieces of software in the world. The vast majority of the functionality for the GordianWallet app also uses Bitcoin Core, extending these benefits. By using GordianServer and GordianWallet together, you can rest at ease that critical bugs should be minimized.
- Native Tor V3 client authentication is integrated into GordianServer. This is the most secure way of communicating with your node remotely, ensuring that only your device has access to your node, even if all other credentials were compromised by an attacker. In short, accessing your Bitcoin Core node with a remote client is most securely done over the Tor network.
- Having your own full-node server gives you an additional place to store private keys, which is how the Gordian architecture manages its two-of-three multisig, with one key stored on each of your GordianWallet and GordianServer.
- Generally: self custody can be scary, as running a node properly over Tor is not something that most people are comfortable with. The entire purpose of the Gordian suite of tools is to make this achievable for anyone who can click a mouse and scan a QR code.
- Access to funds is a critical component for storing your Bitcoin in a self-sovereign way, where you maintain control and agency. If you are not using your own node you may be encumbered by third-party software limitations, which may not allow you to export your seed or private keys or be interoperable with other Bitcoin software. With GordianServer, you can copy and paste a one-line command and recover your entire wallet using your own node, at any time, with guaranteed compatibility. You can also interlink with the GordianWallet app, which allows you to import seeds, permitting you to access your bitcoins stored on other wallets or apps.
5. Testing and Learning
- Utilizing your own node allows you to test the bitcoin network. Simply run the node over testnet and you can experiment with tutorials like Learning Bitcoin from the Command Line and you can experiment with fake money before committing any real funds. A ridiculous percentage of circulating bitcoins have been lost due to misuse or mistakes. GordianServer allows you test everything using your own node, ensuring you are comfortable with how it works (and that it does work) before utilizing mainnet.