I don't know that much about python I've only studied it for a week or so. So bear with me if this is a stupid question. Is there a central database of all records? If people simply copy and past the code in Github and modify it to link to their steemit account, would it ensure that all data are synced? If I were for example, copy your code and put an initial 5M pocket to my account by modifying it, how would the system identify that as fake?
You are viewing a single comment's thread from:
Not a stupid question; actually a really important one - and nothing really to do with Python.
There's no central database, but there is an immutable decentralized database (@pocket-a has a copy of it and @tech-pocket has another copy of it), and that database can be computed by reading the Steem blockchain with my bot code. The Steem blockchain database contains all the information you need to figure out everyone's balances of Pocket. The confirmation bots know everyone's true balance because they've read through the entire Steem blockchain looking for Pocket messages.
If you tried to run your own confirmation bot with false balances, the honest bots would just ignore you as soon as you tried to spend it, because to them, you'd be spending tokens that you don't have. They would also ignore any of your confirmation messages that mention your balance, because they'd disagree on what it is.
But there does exist the possibility that you could try to fool people into believing that you have a balance that you don't have. The bots aren't yet able to prevent attempted fraud.
Thanks man clears up alot
What happens if say 4 bots confirm a transaction and they all award themselves 1 pocket token in fees? How is that discrepancy handled in the system? I'd assume most times that bots running your code (I haven't looked at it yet) would discover that another bot has already confirmed and then abort it's own confirmation. But I've seen some transactions where both your bot and @tech-pocket have confirmed it. How are situations like that handled?
No discrepancy, and all of these questions are accounted for in the protocol. Only the first bot to confirm gets the fee. Subsequent confirmations are ignored.
But the subsequent bots will have a different database than the one that made the first confirmation. They are awarding themselves 1 pocket fee that the first bot won't have in its database. How do they unwind that and return to a consensus database?
They're not awarding themself a fee when they submit the confirmation, they're awarding themself a fee when they read the confirmation in the blockchain. Only one of the confirmation messages can be valid. If the other bot beat them to it, then so be it. It's all in the protocol: https://steemit.com/pocket/@biophil/pocket-protocol
I don't really see that in the protocol. Perhaps it's in your code for the confirmation bot? In that case, it's not a standard, it's a specific implementation.
The fact that you can have multiple bots confirming the same transaction means that there is at least some disconnect between the state of the blockchain and the state of any particular confirmation bot's copy of the database. Assuming this disconnect is righted at some point, my question is how is this done? Are the confirmation bots required (can't see this in your protocol standard) to continually compare their database states with the actual state of the blockchain? If so, this makes sense, of course, and answers my question. The thing is, I can't see this anywhere in your protocol.
Yes, sort of. The blockchain is just a list of messages; it's not really useful to think of it having a "state." Notice that the protocol makes no mention of posting confirmations, only about validating confirmations. The pocket database is a function only of the Steem blockchain, which I believe is clear from the protocol. As such, the bot's database cannot be updated to reflect the fee until the confirmation message is discovered in a Steem block. Once it is discovered, if it is the first confirmation for the associated transaction, its owner is credited the fee. Then, any subsequent confirmation for the same transaction is invalid, because the fee has already been awarded.
A bot that posts confirmations is always running on top of a program that parses the blockchain to determine database state.