- cross-posted to:
- askchapo@hexbear.net
- lemmy@lemmy.world
- cross-posted to:
- askchapo@hexbear.net
- lemmy@lemmy.world
Probably better to post in the github issue rather than replying here.
Probably better to post in the github issue rather than replying here.
This is impossible. The underlying protocol, ActivityPub does not have the concept of private votes. It is not up to Lemmy to decide. You’d need to revise the protocol for this and good luck with that.
ActivityPub can’t evolve? Is there some insurmountable technical blocker?
I suspected this would be an issue and have avoided voting on controversial posts. But if everyone did as I do, there would be no open discussions about pressing topics.
It is possible that ActivityPub could add this feature. But it’s not certain you’d even want that. Private votes would mean private for admins and mods too, so no more analyzing votes to look for down vote bots or manipulation or down vote brigading and all that stuff. Votes could lose all meaning. Admins and mods are unlikely to say goodbye to those moderation tools.
Even if it could be added, it’s probably years away.
Fair points. I’m warming up to the idea of making votes public so that people don’t have a false sense of privacy. I wish votes were actually private, but maybe it’s not a big deal if your account can’t be easily traced back to you in real life.
Pseudonymous voting doesn’t mean a unique ID for every vote. It just means the user string itself is tokenized. You can still ban participation for that token without revealing the actual user. Literally the only thing this stops is easily seeing users who use the same name across several instances.
If the token is the same for the user across different posts, it would be easy to figure out who is actually behind the token by correlating voting patterns.
It would at least provide a means for obfuscating identity for users who care to make an effort. All you’d have to do is not vote when you comment and vice versa.
Evolving ActivityPub is not easy, any additions to the protocol take a lot of time and discussions between the various implementers.
You don’t even need to upstream the protocol changes imo. An instance could decide to participate with tokenized user IDs. Other instances could decide to defederate because this is out of spec behavior, but as far as I am concerned it is perfectly aligned with the core spec. Nothing says user activity cannot be anonymized.
How would this work in practice? I upvote a post and it sends the upvote via a token user to another instance. Then I remove my upvote or downvote instead. My instance would then need to send an undo or dislike for the token user too. How would you ensure you have enough token users to fill up all the votes on a single post? You’d need thousands if not tens of thousands of these token users. How does it work when I ban one of these users? How do I prevent a user from participating if they use these token users?
Also, this could be used to make vote manipulation easier I bet.
The simplest form of this is literally just a token which replaces the universal identity. So you ban the token, you ban the user. This only applies for voting anyway, since commenting and posting follows the plaintext user agent.
A more robust trust model with rotating tokens would fully move ban enforcement to the home instance, which I actually believe is already the case in some situations. Eg, when I am banned from a specific community on another instance it seems as if my host instance knows not to even display a vote on the UI, which suggests that it has knowledge of my federated ban. With this trust model it would be possible to fully enforce cryptographically secure forward security as well.