- Nov 19, 2015
- 94
- 191
https://github.com/priestc/MultiExplorer/blob/master/memo_server_spec.md
This is what I've been working on for the past few weeks. It's a system for saving memos encrypted so that only the private key holder can decrypt what the memo says.
I have a few questions:
1. Is AES the right algorithm to use here? Would HMAC be better?
2. I've noticed that all of the encrypted memos start with the chars "U2FsdGVkX1". I assume this is because all memos are prefixed with "BIPXXX" before AES encrypting. Is there a way to have the prefix to be something so that the resulting encrypted text starts with "BIPXXX" instead? BTW "BIPXXX" is just a place holder, once the specification gets added to some BIP/BUIP repo, that tag will change to reflect the actual BIP number.
A fully working implementation is live at http://multiexplorer.com/wallet. Also there is a mirror located at https://me.flightlogg.in. Those two memo servers are configured to pull from each other, so if multiexplorer happens to go down for whatever reason (such as a DDOS attack), your memo is backed up on another memo server and can always be retrieved. Hopefully more people will run more memo servers to add to the overall redundancy.
By the way, I don't really like the name "memo server". The system can be used for many other things, such as storing wallet settings. Maybe your have your wallet configured to show the balance converted to USD, and the crypto balance shown in mBTC units. Your wallet can write these preferences to the memo server. When you import your master seed into another wallet the importing wallet can get those preferences from the memo server network. Also, imported addresses (not derived from the master seed) can be encrypted and stored to this network as well. Maybe even smart contracts can read/write data to this network...
I've thought of calling it something like the "Public Blockchain Parallel Small Data Network" or PBPSDN (which doesn't really have any ring to it). Maybe other people can bikeshed over a better name?
This is what I've been working on for the past few weeks. It's a system for saving memos encrypted so that only the private key holder can decrypt what the memo says.
I have a few questions:
1. Is AES the right algorithm to use here? Would HMAC be better?
2. I've noticed that all of the encrypted memos start with the chars "U2FsdGVkX1". I assume this is because all memos are prefixed with "BIPXXX" before AES encrypting. Is there a way to have the prefix to be something so that the resulting encrypted text starts with "BIPXXX" instead? BTW "BIPXXX" is just a place holder, once the specification gets added to some BIP/BUIP repo, that tag will change to reflect the actual BIP number.
A fully working implementation is live at http://multiexplorer.com/wallet. Also there is a mirror located at https://me.flightlogg.in. Those two memo servers are configured to pull from each other, so if multiexplorer happens to go down for whatever reason (such as a DDOS attack), your memo is backed up on another memo server and can always be retrieved. Hopefully more people will run more memo servers to add to the overall redundancy.
By the way, I don't really like the name "memo server". The system can be used for many other things, such as storing wallet settings. Maybe your have your wallet configured to show the balance converted to USD, and the crypto balance shown in mBTC units. Your wallet can write these preferences to the memo server. When you import your master seed into another wallet the importing wallet can get those preferences from the memo server network. Also, imported addresses (not derived from the master seed) can be encrypted and stored to this network as well. Maybe even smart contracts can read/write data to this network...
I've thought of calling it something like the "Public Blockchain Parallel Small Data Network" or PBPSDN (which doesn't really have any ring to it). Maybe other people can bikeshed over a better name?