- Any person can run any software they want on their computer.
- Any person running such software can choose to validate or ignore transactions from any account(s).
- Any user of the software can approve or unapprove any validator at any time by using their own stake.
- When a majority (soft forks) or a super-majority (hard forks) of validators is running the same software, then that software is what is “accepted” as the current chain by validators and stakeholders.
- At any time, any other group of validators can run a different version of the software and those validators can then “fork” the chain and run their own version of it, separate from the original chain.
- Each user participating in 1-5 is using their own property in the way they see fit. None of the steps in 1-5 contradict or counteract DPoS.
None of this is untrue. Some things may not be desirable but that does not invalidate the facts above.
To your point - yes, it could be bad for a blockchain if a group of validators ignored transactions. But I don’t think the “bad” can be universally applied. And ignoring/rejecting transactions is certainly not an action that is unique to DPoS. This can occur on any chain.
They give you a mathematical, game theory explanation of how, under specific circumstances, you can guarantee, 100%, the outcome.
There is no 100% guarantee of any outcome, which is why networks can be “attacked” and have mitigation protocols or system designs that help avoid such attacks. With DPoS, that mitigation exists through the election of trusted witnesses by stakeholders. This is why I stated that you can’t just cherry-pick one or two points from above and state that the system or its security would be invalidated.
If you need examples of how attacks and mitigation can play out - or how accounts can be protected - just observe what has happened with Steem and Hive.
There was a threat of centralization, the threat was temporarily neutralized (soft fork 22.2), an “attack” occurred (exchange collusion), and then a fork (HF23 - Hive) was deployed to get rid of the attack and to protect the tokens of those not involved in or supporting the attack.
What better example do you need? This confirms that all of the enumerated points in my post are indeed correct.
The question of “harm” when it comes to block production would appear to be based on harming the system. If the “censorship” involved is in fact an attempt to mitigate an attack meant to centralize block production, which is actually more harmful to the chain? The few “censored” transactions or the centralization of the entire transaction validation process?
I appreciate this perspective as a lesser of two evils. I still think listing it among your criteria for what DPoS allows is inappropriate. There are many, many other forms of harm we could come up with that network participants could use. We didn't list those, so why list this? Is it to justify actions taken as if they are normal, every day occurrences that any witness "can" do?
A witness can shoot themselves in the head, shut down their server before disabling their witness account, run multiple nodes as a sybil attack, etc, etc... there are many things which we can call "facts" and say witnesses "can" do them. Of the items in your list, I only see #2 out of place because it is a form of harm against the network.
I think it would be more accurate list the protection mechanisms in a war-time scenario that DPoS can use to defend itself and what level of harm each of those create.
Either way, thank you for the respectful dialogue.