My position on the soft fork - I am not running the changes on my witness node

in #witness-update5 years ago

A super-majority of the top witnesses have decided to proceed with a change to limit the use of the accounts belonging to Steemit, Inc. (which have been acquired by Tron as part of the purchase of Steemit, Inc.) To find out more about this, please read this post.

The decision to support the changes (or not) has weighed heavily on many witnesses including myself, and a lot of very healthy and productive conversation has taken place between many of the witnesses and Steem's stakeholders.

I fully acknowledge and appreciate the severity of the situation, and fully understand why the witnesses running this software have chosen to do so. Personally however, I have chosen NOT to apply the changes to my witness node.

Regardless of the messy situation that got us here, and the very real security risk that Tron currently poses to our chain - I see them as a stakeholder who acquired their stake through a legitimate over-the-counter purchase, and I am not OK forcing restrictions on the way a stakeholder uses their stake.

Note: From a technical perspective, this will have no impact on the restrictions put in place by the other witnesses. I am a single witness, and by myself I am not able to overthrow the will of a super-majority consensus (by design).

Despite the fact that I am not applying these changes to my node, I do support the overall mission that the top witnesses and community/stakeholders are trying to achieve: Finding a way for Steem to progress in a way where the security of our governance and blockchain is not under the constant threat of a single stakeholder.

In my view, there are really two paths forward:

  1. We find a way to work with Tron and come up with a mutually acceptable plan that allows Tron to keep and use their stake in a way that is acceptable to the community and stakeholders, and puts an end to the "ninja mine" dysfunction that has plagued Steem since day one.
  2. We create a fork of Steem (similar to Ethereum vs Ethereum Classic) in a way that voids out the ninja mined stake (or does something with it such as funding the DAO) and we let Tron proceed with the chain they have full control of, and we proceed with a new chain without them.

I am really hoping that we can find a way to achieve #1, because I truly believe that there is more potential for both Steem and Tron to be successful if we work together towards mutually beneficial goals. For the time being I see that as the best path forward, and I will continue to work towards that end.

Sort:  

Thanks Tim, this is sicking.

With zero evidence he had any intent to do anything to harm Steem we have greeted him with hostility.

Sad day

I am obviously not in direct support of what was done, but at the same time I can say that it was not a decision that was taken lightly, and the people making it perceived a very real and credible threat to the security of the blockchain.

Nothing has been done at this point that cannot be quickly undone (at least at a technical level). If however Tron had done something hostile (such as voting in a new majority to carry out their will), it would not have been possible to undo such an event without major changes. To that extent, I can at least understand the "precautionary" nature of the move.

That said, I do agree 100% with regards to the hostility part. My goal was (and still is) to try and achieve a mutually beneficial outcome, and I hope we have not backed ourselves into a corner where that is no longer possible.

you forget that what has been proven to everyone is that a small group of people can meet, change the code and execute it without a single public discussion.

Whether Justin turns out to be great or not, that can never be undone. And it is way more important than the circumstances used to justify why it happened.

There are limitations on what can be changed "in secret" in that if the consensus rules are changed, other entities in the ecosystem (exchanges, seeds, full nodes, etc.) have go "agree" to the changes and apply them to their nodes too, otherwise the witnesses will go off on their own and leave everyone else behind. The code changes that were made today did not change any consensus rules.

Witnesses always have the ability to "ignore" transactions. In 99% of the cases, if they do this - it is a very good way to get voted out by the stakeholders and replaced by new witnesses. That is esentially what all of the (other) top witnesses are doing with this "soft fork" - agreeing to ignore a set of transactions from certain accounts.

Ultimately, DPoS is a stake based governance system. Stakeholders are the ones who choose who to vote in, and witnesses who do not align with the interests of the stakeholders typically get voted out. If the stakeholders are not OK with the witnesses ignoring certain transactions, then they 100% have the ability to vote in witnesses who won't ignore them.

What I suspect you will find though is that in this case the witnesses do have the support from a large majority of our stakeholders. At least that's my read on it.

Exactly. This is representative democracy rather than direct democracy. We appoint senior witnesses to act on our behalf for our stake in Steem.

@whatsup True, but that small group of people has the community trust through their witness votes..

I fully respect your decision to be the black sheep in this case.

At the same time I agree that it was our best move so that Justin will be more inclined to find common ground with the existing community or he'll lose half of the users (and his investment).

It's indeed a hard measure but his words were quite threatening (and naive) at the same time.

We have years of evidence of what Justin Sun intends to do and does. He lies to, he cheats, he obfuscates and he exploits others to make himself richer. He is a master of the crypto shell game and a bad actor.

Life is too short to waste a second working with or investing into people you can identify as bad actors or untrustworthy. This should be a lesson we have all learned repeatedly over the years. It never ends well.

There is no evidence, there was concern.

Justin Sun has done nothing but provide evidence. He's not some random person, he has a track record of 4 years at this point. He is a bad actor, point blank.

Despite the fact that I am not applying these changes to my node, I do support the overall mission that the top witnesses and community/stakeholders are trying to achieve: Finding a way for Steem to progress in a way where the security of our governance and blockchain is not under the constant threat of a single stakeholder.

Hi @timcliff,

Isn't there already one or two stake holders in which hold a large say on who gets to be a top witnesses?

Regardless of that, I share your views. I think its going to be tough getting any big investors to take a look at STEEM due to this decision.

You have just become the 4th witnesses in which I vote for.

There are some that can take someone into the top 20 if they are already close, but not from zero to top on their own without any other stakeholders.

Thanks :)

Loading...

voted for you just because you were ready to stand to what you believe. i am not sure where i stand on this, but the thing i know is that his lack of communication is disrespectful to the steem community.

Thank you for sticking to your principles, Tim. This was one of the hardest decisions I've had to make as a witness. Depending on how the owner of the property responds, I will adjust accordingly. Ultimately, to me, this is property we're talking about. We've acknowledged a lien in place on that property enforced by social contract. That may not sound like much (it's certainly not legally binding, as far as I know), but when it comes to blockchains, consensus is everything.

I believe you meant lean lien ...

Posted using Partiko Android

Ah, thank you! Fixed.

I believe there is another option. I'd appreciate your consideration of the proposal.

You retain my witness vote, and if I could I'd up the weight, because it takes courage of conviction to oppose a supermajority.

Thanks!

Thank you.

I read the proposal. It is an interesting idea, but unfortunately it would not solve the current situation. The problem is with ratios of STEEM. The Steemit, Inc. accounts have more STEEM than all of the other actively voting stakeholders combined. If you cut those accounts voting power by 30x, you also cut the voting power of the other voters by 30x. Steemit could just divide their existing stake into 20 separate accounts and use each one to vote in one witness.

@smooth just also pointed out that problem of inactive and lost stake, which I had failed to reckon. However, the problem of inequity and it's centralizing influence remains, and so does the problem of tortuous harm presently ongoing.

The proposal may not solve the threat of influence the founder's stake represents, but it does solve inequity and tort, insofar as they can be solved. We are in the situation we are in, vis a vis the founder's stake, and sometimes it's best to pucker up and kiss the pig when the music plays.

Thanks!

Appreciate your stance Tim, as well as the overall consensus being what it is.

Has there been any discussion about simply decreasing the number of witness votes per account? I feel a hardfork of that nature would be the simplest way to immediately decentralize Steem further and lift undue restrictions on the Steemit Inc. stake.

I understand this idea has been going around but people are very confused about its effectiveness. @timcliff pointed out one simple scenario how it would fail but there are many others (the details of which vary according ot the specific voting rules) once you carefully think it through, pretty much no matter how you set up the voting rules. There is no plausible set of voting rules that is going to prevent a very dominant majority stake (current about 150% as much as all other actively voting stake put together) from effectively "being in charge". That ought to be pretty obvious from the very concept of "voting".

Furthermore any such change would require a hard fork, which means all nodes and exchanges updating. That is obviously very costly and disruptive, and generally (for good reason) those have been limited in frequency and number.

That isn't to say that some changes to the voting rules wouldn't be beneficial in some ways and perhaps those should be included in some future hard fork, but it isn't a solution to this issue.

That isn't to say that some changes to the voting rules wouldn't be beneficial in some ways and perhaps those should be included in some future hard fork...

This really is something that we should be working towards as the platform and community matures and the decentralised governance of STEEM evolves long term.

I'd actually be most in favor of a 1 SP=1 vote system wherein 100 million SP of stake would have to spread it across 30 witness votes, not get to vote 100 million on all 30, but limiting witness votes to say 5, accomplishes much the same thing and may be a simpler and more elegant solution to code. It does not prevent a massive stake from voting in witnesses, but it makes it extremely difficult for them to control consensus.

100 million SP with 5 witness votes could divvy it up to the point of optimizing 25 million SP of support on 20 witnesses, but that level still leaves room for actual community elected witnesses to remain in the top 20 and essentially give Steem classic seats at the table and keep any malicious hard forks from achieving consensus.

Of course 1 SP = 1 vote is the most extreme form of decentralizing the chain and honestly makes the most sense. In that kind of scenario, 100 million SP spread across 20 witnesses is equal to only 5 million SP of support per witness. Huge stake can control a number of witness seats, but certainly not all of them as is currently the case. SP being multiplied by a factor of 30 for witness voting is the flaw that needs addressed. If Tron wants to put their thumb on the scale and buy seats at the witness table, I think we could actually allow that provided they can't buy consensus, which the current system is allowing.

This assumes NO support from any other stake, which is unlikely and unrealistic, especially after any degree of marketing, campaigning, offering incentives, etc. In reality, a dominant stake would still be to override, say an 80-20 split of the rest of voters against what they want to do, just not 100%. That's a little better from that perspective and in that particular scenario, but nothing close to a panacea, and this also significantly weakens the chain because any malicious minority attacker can still push in a minority of witnesses who can cause harm in various ways, instead of being kept out by broad stake consensus as the current rules are intended to do.

I think people are being a little selective in thinking here. At the moment, "we" are in the minority therefore giving a minority more influence is "good" . But there are also plenty of situations when "we" won't be in the minority and giving a minority more influence would be bad. Once you put rules into place you can't pick and choose how they will be used.

Also, I think it might make sense to break out the policy voting and block producer voting roles (as I believe was the case in Bitshares, and was dropped from Steem without much explanation other than "simplfiication"). In the case of voting on forks and policy, I agree there benefit in not "amplifying" a majority and giving smaller voting blocs a seat at the table (though this still allows a malicious minority to block policy decisions i.e. hard forks which may in fact be beneficial), but in the case of block production, this really isn't true. Minority influence on block production is pretty much only bad. It can't create a longest chain and can only cause trouble (including outright failure).

I realize that ~1/3 of stake is going to have immense influence on the platform, but in fact it does not create a supermajority. Further I note that equitable distribution of influence over governance is appropriate, particularly to an investor that purchased their stake.

I don't see any other lawful way to potentially secure the decentralization of the blockchain, than the proposal I have linked in my reply to the OP.

Please prove me wrong.

It's not 1/3, it is about 150% of the currently active voting stake, meaning 71% of all actively voting stake, were it to vote.

Perhaps some more stake might vote but there will always be some held by dormant accounts/passive investors who literally aren't paying attention or aware of any governance decisions, by dead people, by accounts with lost keys, by custodians with a policy of not voting, etc.

Claiming that 29% having much of a say is a push for 'decentralization' is a stretch IMO.

The core problem is simply that the stake is too centralized, was too centralized to begin with, and people were led to accept this situation by a bunch of empty promises, misleading and outright false statements, and a misplaced sense of trust in the founder (even, somewhat inexplicably, after the other founder demonstrated one reason why one should not trust in a founder).

That being said, I've noted elsewhere that I think splitting block production and governance (as was the case in Bitshares before this was combined in Steem with no explanation beyond "simplification") might be best, and even your exact proposal might be good, as long as people recognize it for the tradeoff that it is.

I did indeed fail to reckon inactive stake, or stake lost to the vicissitudes of key management. I agree with all of your comment I understand.

Thanks!

There is definitely discussion about it although it does not nullify the current situation. They could just divide it up across two accounts and vote in 10 witnesses each.

Any reduction in number of witness votes still helps. Right now we have a system of governance wherein voting rights are equal to SP times 30. SP times 10 is still a massive improvement, but cutting witness votes to 5 or 6 is probably what would be needed to prevent the Steemit Inc. stake from being able to control consensus outright. Not saying they couldn't control 10+ seats still if they chose, but at least they'd probably need to negotiate with some community backed "spoilers" at that level.

It would cut other stakeholders votes by the same amount as well. The Steemit, Inc. accounts would still have proportionally the same amount of advantage.

No, because they wouldn't be able to enforce a witness supermajority. Even though they will still have an advantage, it won't be enough to centralize the chain.

They would still have enough to enforce a witness supermajority.

The problem with any account based proposal is sock puppets easily circumvent it.

This is why I have proposed an equity based solution, linked in my reply to the OP.

I've been dormant but checking on things every now and then for I suppose about a year at this point.

The question that occurs to me regarding this Soft Fork is:

We've seen how readily Justin spends money on things. Should he try to use his stake to vote in witnesses who will fall in line and this fork goes in to effect to "lock out" his stake, what is to keep him from going to the exchanges and buying every STEEM token out there to build a "legitimate stake" outside of the stake that is locked out.

I have no idea how much Steem is currently on exchanges, but I have to imagine it would be a drop in the bucket for him to buy it all and power it up. Would this be enough to cancel out the intent of this soft fork?

I don't know, but it is possible.

Hi @timcliff firstly I think your #2 option is plane ludicrous. I mean come on mate we all know what's going to happen everyone will abandon the tron steem chain for the new one it's not rocket science.

With that said let's re hash on option 1. Coming up with a mutual agreement with somebody who just purchased neds stake.. I mean yeah sure in a perfect world but unfortunately business is business and at the end of the day tron and Mr sun give no shit about you or your witness title.

Coin Marketplace

STEEM 0.18
TRX 0.16
JST 0.030
BTC 63077.53
ETH 2471.91
USDT 1.00
SBD 2.66