Help spread awareness for build reproducibility
Please help us spread the word discussing build reproducibility with KoinKeep via their Twitter!
Do your own research!
Try out searching for "lost bitcoins", "stole my money" or "scammers" together with the wallet's name, even if you think the wallet is generally trustworthy. For all the bigger wallets you will find accusations. Make sure you understand why they were made and if you are comfortable with the provider's reaction.
If you find something we should include, you can create an issue or edit this analysis yourself and create a merge request for your changes.
The Analysis ¶
Product Description
A list of KoinKeepâs features.
Public Key Cryptography
- 32 byte secp256k1 keys are used exclusively.
- All keys are stored in as few places as possible. Keys on the hardware device never go to the phone and vice versa.
Multi-sig
- Any number of KoinKeep hardware wallets can be combined into a multi-sig arrangement.
- When using multiple devices, two-thirds of the collection are required to unlock funds.
Local Transaction Signing
- Transaction payloads are transferred between devices, signed and passed back.
- Transactions are taken to hardware wallets individually, so they never need to be in the same location.
On-chain Two-factor Authentication (2FA)
- KoinKeeps use a unique bitcoin script format that allows for on-chain 2FA
- The key for this 2FA is stored in the userâs phone and is never transferred to the device.
- This key is required but not sufficient to unlock funds.
The unique input script format is: [Signature] OP_CHECKSIGVERIFY [Signature] [Signature] OP_2 [Public Key] [Public Key] [Public Key] OP_3 OP_CHECK
Bluetooth
- Nothing sensitive is ever sent over Bluetooth (ie. no keys).
- All communication over Bluetooth is encrypted AES_CBC anyway.
- All encryption keys are 32 bytes.
- Initial setup performs diffie key exchange. After which the device will only ever recognize that single key forever.
- Nonces are used to prevent replay attacks.
Encrypted Storage
- All device storage is encrypted.
- Encryption is done with AES_CBC.
- The encryption key is 32 bytes.
- The encryption key is never stored in permanent memory.
- The encryption key is instead stored on the userâs phone and given to the device during signing.
- Learn more about KoinKeepâs storage encryption strategy
- Direct-access SPV Bitcoin Wallet
- KoinKeepâs phone application connects directly to the Bitcoin network as an SPV (Simple Payment Verification) wallet.
- Bloom filters are used in a privacy-increasing fashion.
- When a bloom filter is updated all currently connected nodes are disconnected. New nodes receive the updated bloom filter. This prevents nodes from being able to âdiffâ the bloom filters and reduce your privacy.
Whitelist Nodes
- You can specify nodes to always connect to.
- You can specify nodes to only connect to by marking them as âmaster nodes.â This is helpful if you run your own node to further increase your privacy.
Built in Block Explorer
- Using online block explorers decreases privacy, because their servers can track you.
- KoinKeepâs phone app has a built-in basic block explorer, which shows all transactions relevant to your wallet.
KoinKeep has a companion app in the Apple Store.
Analysis
The website is no longer online. Its twitter accountâs last post was made in December 21, 2020. It is highly likely the device is no longer for sale. Apart from that, it has no display interface. It claims to mitigate the âtrusted screen problemâ through this:
KoinKeepâs come in sets of three allowing for easy multi-key setup (hide each in different locations).
— Keeper (@KoinKeep) April 12, 2020
Gatekeeper solves the âtrusted screenâ problem.
We believe together this is the best over the counter Bitcoin storage solution on the market.
Gatekeeper is available on GitHub:
GateKeeper is a tool for verifying withdrawal transactions and more. It will verify that your Bitcoin wallet is not lying or stealing from you.
GateKeeper should be used:
- After a withdrawal transaction is created.
- Before a transaction is published.
- To ensure the transaction is not published, make your withdrawal transaction in an offline environment.
The basic idea is that the user instead of using an online companion app to interface with his hardware wallet, the user uses yet another offline device to read and interpret the tx before it reaches an internet-connected device which indeed can solve the security issue of all our Bad Interface! devices but at a huge cost:
Normally:
- Create unsigned transaction on companion app on internet connected machine
- Verify details on hardware wallet
- Approve - Signed transaction gets sent back to companion app
- Companion app broadcasts
Here:
- Create unsigned transaction on companion app on internet connected machine
- Blindly approve - Signed transaction gets sent to third device?
- Third device displays details. If those are ok, transfer the signed transaction to companion app
- Companion app broadcasts
So here it is not clear if that third device sits between companion app and hardware wallet. If that is the case - the unsigned transaction is passed through the third device to the hardware wallet - the user is susceptible to that third device being compromised and showing X while getting signed and broadcast Y. If it does not see the transaction prior to HW signing it, the information flow gets even more complicated but the chances of a compromised âGateKeeperâ doing harm vanish.
All in all GateKeeper is a neat idea but doesnât save this product from a negative verdict regarding the lack of a display.
(dg)
Verdict Explained
The design of the device does not allow to verify what is being signed!
As part of our Methodology, we ask:
Can the user verify and approve transactions on the device?
If the answer is "no", we mark it as "Bad Interface".These are devices that might generate secure private key material, outside the reach of the provider but that do not have the means to let the user verify transactions on the device itself. This verdict includes screen-less smart cards or USB-dongles.
The wallet lacks either an output device such as a screen, an input device such as touch or physical buttons or both. In consequence, crucial elements of approving transactions is being delegated to other hardware such as a general purpose PC or phone which defeats the purpose of a hardware wallet.
Another consquence of a missing screen is that the user is faced with the dilemma of either not making a backup or having to pass the backup through an insecure device for display or storage.
The software of the device might be perfect but this device cannot be recommended due to this fundamental flaw.
Share on
Twitter Facebook LinkedInOr embed a widget in your website
<iframe
src="https://walletscrutiny.com/widget/#appId=hardware/koinkeep&theme=auto&style=short" name="_ts"
style="min-width:180px;border:0;border-radius:10px;max-width:280px;min-height:30px;">
</iframe>
and
<iframe
src="https://walletscrutiny.com/widget/#appId=hardware/koinkeep&theme=auto&style=long"
style="max-width:100%;width:342px;border:0;border-radius:10px;min-height:290px;">
</iframe>