this post was submitted on 19 Aug 2024
346 points (97.5% liked)

Fediverse

28042 readers
520 users here now

A community to talk about the Fediverse and all it's related services using ActivityPub (Mastodon, Lemmy, KBin, etc).

If you wanted to get help with moderating your own community then head over to !moderators@lemmy.world!

Rules

Learn more at these websites: Join The Fediverse Wiki, Fediverse.info, Wikipedia Page, The Federation Info (Stats), FediDB (Stats), Sub Rehab (Reddit Migration), Search Lemmy

founded 1 year ago
MODERATORS
 

We had a really interesting discussion yesterday about voting on Lemmy/PieFed/Mbin and whether they should be private or not, whether they are already public and to what degree, if another way was possible. There was a widely held belief that votes should be private yet it was repeatedly pointed out that a quick visit to an Mbin instance was enough to see all the upvotes and that Lemmy admins already have a quick and easy UI for upvotes and downvotes (with predictable results ). Some thought that using ActivityPub automatically means any privacy is impossible (spoiler: it doesn't).

As a response, I’m trying this out: PieFed accounts now have two profiles within them - one used for posting content and another (with no name, profile photo or bio, etc) for voting. PieFed federates content using the main profile most of the time but when sending votes to Mbin and Lemmy it uses the anonymous profile. The anonymous profile cannot be associated with its controlling account by anyone other than your PieFed instance admin(s). There is one and only one anonymous profile per account so it will still be possible to analyze voting patterns for abuse or manipulation.

ActivityPub geeks: the anonymous profile is a separate Actor with a different url. The Activity for the vote has its “actor” field set to the anonymous Actor url instead of the main Actor. PieFed provides all the usual url endpoints, WebFinger, etc for both actors but only provides user-provided PII for the main one.

That’s all it is. Pretty simple, really.

To enable the anonymous profile, go to https://piefed.social/user/settings and tick the ‘Vote privately’ checkbox. If you make a new account now it will have this ticked already.

This will be a bit controversial, for some. I’ll be listening to your feedback and here to answer any questions. Remember this is just an experiment which could be removed if it turns out to make things worse rather than better. I've done my best to think through the implications and side-effects but there could be things I missed. Let's see how it goes.

top 50 comments
sorted by: hot top controversial new old
[–] imaqtpie@sh.itjust.works 71 points 1 month ago* (last edited 1 month ago) (1 children)

Cool solution. It's great to have multiple projects in the fediverse that can experiment with different features/formats.

For those who are concerned about possible downsides, I think it's important to understand that

  • PieFed has a small userbase
  • Rimu is an active admin, so if you are attempting to combat brigading or other bad behavior and this makes it more difficult, just send them a DM and they will be happy to help out

This is a good environment to test this feature because Rimu can keep a close watch over everything. We can't become paralyzed by the hypothetical ways that bad actors might abuse new features or systems. The only way forward is through trial and error, and the fact that PieFed exists makes that process significantly faster and less disruptive.

This is an attempt to add more privacy to the fediverse. If the consequences turn out for the worse, then we can either try something else, or live with the lack of privacy. Either way, we'll be better off than having never tried anything at all.

[–] imaqtpie@piefed.social 23 points 1 month ago* (last edited 1 month ago) (4 children)

Just upvoted myself but nobody else knows 🤫

Edit: Actually I forgot to toggle the setting before voting on my own comment, so admins will see my @imaqtpie@piefed.social account upvoted the parent comment. Worth noting that it needs to be manually enabled.

Then I turned the setting on and voted on a bunch of other comments in this post. My anonymized voting account appears as @hED5TzoZomb@piefed.social, admins should be able to see it by checking the votes in this thread.

Point being, you can still track serial downvoters and harassment just as easily. But now you will need to take an extra step and message the instance admin (Rimu) and ask that they either reveal the identity of the linked profile or deal with it themselves. And that's a good thing, imho.

[–] arcuru@lemmy.world 22 points 1 month ago (1 children)

Point being, you can still track serial downvoters and harassment just as easily. But now you will need to take an extra step and message the instance admin (Rimu) and ask that they either reveal the identity of the linked profile or deal with it themselves. And that’s a good thing, imho.

This puts the privacy shield in the hands of a users instance admin. I like that approach, but I'm sure others will disagree.

load more comments (1 replies)
load more comments (3 replies)
[–] shnizmuffin@lemmy.inbutts.lol 40 points 1 month ago (2 children)

Hey, Lemmy admin here. If I ban an anonymous account, does the account it's tethered to also get banned?

[–] rimu@piefed.social 23 points 1 month ago (5 children)

No but perhaps it should!

PieFed lacks an API, making it an unattractive tool for scripting bots with. I don't think you'll see any PieFed-based attacks anytime soon.

[–] shnizmuffin@lemmy.inbutts.lol 6 points 1 month ago (1 children)

What about PieFed-based shitty humans?

[–] rimu@piefed.social 22 points 1 month ago (1 children)

PieFed tracks the percentage of downvotes vs upvotes (calling it "Attitude" in the code and admin UI ), making it easy to spot people who downvote excessively and easy to write functionality that deals with them. Perhaps anonymous voting should only be available to accounts with a normal attitude (within a reasonable tolerance).

[–] shnizmuffin@lemmy.inbutts.lol 7 points 1 month ago (5 children)

Wow your documentation is so much better than ours.

[–] rimu@piefed.social 8 points 1 month ago

That's nice of you to say. I've tried to focus well on certain areas that seem important but I really admire the breadth of https://join-lemmy.org/docs/ which I could never hope to cover.

load more comments (4 replies)
load more comments (4 replies)
[–] can@sh.itjust.works 15 points 1 month ago (4 children)

Do you ben based on voting behaviour?

[–] shnizmuffin@lemmy.inbutts.lol 21 points 1 month ago (6 children)

If the same account is voting in the same direction on every single post and comment in an entire community in a matter of seconds while contributing neither posts nor comments? Yes, vote manipulation.

If one user is following another around, down voting their content across a wide range of topics? Yes, targeted harassment.

[–] perviouslyiner@lemmy.world 13 points 1 month ago* (last edited 1 month ago) (7 children)

Would banning the voting half of the pseudonymous account not mitigate the immediate issue? Then asking their instance admin to later lookup and ban the associated commentating account.

load more comments (7 replies)
load more comments (5 replies)
load more comments (3 replies)
[–] inlandempire@jlai.lu 38 points 1 month ago

This is quite a smart solution, good job !

[–] it_depends_man@lemmy.world 30 points 1 month ago

You're a hero for making this happen in... 24 hours? 48?

The issue won't go away, we'll see how well everyone else deals with it, but this is a super strong argument for your system / server.

(Advertise it. Advertise it HARD. "piefed, we have private votes".)

[–] mozz@mbin.grits.dev 25 points 1 month ago* (last edited 1 month ago) (1 children)

Dude this is genius

I am interested to see how it plays out but the idea of the instance admin being able to pierce the veil and investigate things that seem suspect (and being responsible for their instance not housing a ton of spam accounts just as now) seems like a perfect balance at first reading

Edit: Hahaha now I know Rimu’s alter ego because he upvoted me. Gotcha!

[–] rimu@piefed.social 8 points 1 month ago

It wasn't me, haha

[–] echolalia@lemmy.ml 18 points 1 month ago* (last edited 1 month ago) (3 children)

While not a perfect solution, this seems very smart. It’s a great mitigation tactic to try to keep user’s privacy intact.

Seems to me there’s still routes to deanonymization:

  1. Pull posts that a user has posted or commented in
  2. Do an analysis of all actors in these posts. The poster’s voting actor will be over represented (if they act like I assume most users do. I upvote people I reply to etc)
  3. if the results aren’t immediately obvious, statistical analysis might reveal your target.

Piefed is smaller than lemmy, right? So if only one targeted posting account is voting somewhat consistently in posts where few piefed users vote/post/view, you got your guy.

Obviously this is way harder than just viewing votes. Not sure who would go to the trouble. But a deanonymization attack is still possible. Perhaps rotate the ids of the voting accounts periodically?

load more comments (3 replies)
[–] ada@lemmy.blahaj.zone 17 points 1 month ago* (last edited 1 month ago) (4 children)

I use people upvoting bigoted and transphobic content to help locate other bigoted and transphobic accounts so I can instance ban them before they post hate in to our communities.

This takes away a tool that can help protect vulnerable communities, whilst doing nothing to protect them.

It's a step backwards

[–] smeg@feddit.uk 23 points 1 month ago (6 children)

whilst doing nothing to protect them

Well it also takes away a tool that harassers can use for their harassing of individuals, right? This does highlight the often-requested issue of Lemmy needs better/more moderation tools though.

[–] maegul@lemmy.ml 10 points 1 month ago (1 children)

If public voting data becomes a thing across the threadiverse, as some lemmy people want.

Which is why I think the appropriate balance is private votes visible to admins/mods.

[–] doctortran@lemm.ee 10 points 1 month ago* (last edited 1 month ago) (1 children)

Admins only. Letting mods see it just invites them to share it on a discord channel or some shit. The point is the number of people that can actually see the votes needs to be very small and trusted, and preferably tied to a internal standard for when those things need acted upon.

The inherent issue is public votes allow countless methods of interpreting that information, which can be acted on with impunity by bad actors of all kinds, from outside and within. Either by harassment or undue bans. It's especially bad for the instances that fuck with vote counts. Both are problems.

load more comments (1 replies)
load more comments (5 replies)
[–] rimu@piefed.social 15 points 1 month ago (2 children)

I'm going to have to come up with set criteria for when to de-anonomize, aren't I. Dammit.

In the meantime, get in touch if you spot any bigot upvotes coming from PieFed.social and we'll sort something out.

[–] ada@lemmy.blahaj.zone 7 points 1 month ago (2 children)

The problem is, it's more than just the upvote. I don't ban people for a single upvote, even on something bigoted, because it could be a misclick. What I normally do is have a look at the profiles of people who upvote dogwhistle transphobia, stuff that many cis admins wouldn't always recognise. And those upvotes point me at people's profiles, and if their profile is full of dog whistles, then they get pre-emptively instance banned.

[–] rimu@piefed.social 11 points 1 month ago (1 children)

Ahh, right, got it.

Let's keep an eye on this. I am hopeful that with PieFed being unusually strong on moderation in other respects that we don't harbor many people like that for long.

load more comments (1 replies)
load more comments (1 replies)
load more comments (1 replies)
[–] maegul@lemmy.ml 6 points 1 month ago (1 children)

Yea, which is why I think the obvious solution to the whole vote visibility question is to have private votes that are visible to admins and mods for moderation purposes. It seems like the right balance.

[–] rimu@piefed.social 8 points 1 month ago (2 children)

It will be difficult to get the devs of Lemmy, Mbin, Sublinks, FutureProject, SomeOtherProject, etc to all agree to show and hide according to similar criteria. Different projects will make different decisions based on their values and priorities.

load more comments (2 replies)
load more comments (1 replies)
[–] Socsa@sh.itjust.works 12 points 1 month ago

Awesome! This is the exact stopgap implementation I was arguing for, and I'm surprised how many people kept insisting it was impossible. You should try and get this integrated into mainline Lemmy asap. Definitely joining piefed in the meantime though.

[–] brbposting@sh.itjust.works 12 points 1 month ago* (last edited 1 month ago) (1 children)

Nice, @A_A@lemmy.world, we feeling heard? 😉

Link


Great trial! Will see if you end up feeling a need to iterate sometime later!

load more comments (1 replies)
[–] subignition@fedia.io 11 points 1 month ago

Very interesting development, I'll be curious to see how it ends up working out.

[–] Max_P@lemmy.max-p.me 11 points 1 month ago (2 children)

The problem with this approach is trust. It works for the users, but not admins. If I run a PieFed instance with this on, how can lemmy.world for example can trust my tiny instance to be playing by the rules? I went over more details in this other comment.

Sure, right now admins can contact you, for your instance. But you can't really do that with dozens of instances and hundreds of instances. There's a ton of instances we tolerate the users, but would you trust the admin with anonymous votes? Be in constant contact with a dozen instance admins on a daily basis?

It's a good attempt though. Maybe we're all pessimistic and it will work just fine!

[–] rimu@piefed.social 14 points 1 month ago* (last edited 1 month ago) (4 children)

I can only respond in general terms because you didn't name any specific problems.

Firstly, remember than each piefed account only has one alt account and it's always the same alt account doing the votes with the same gibberish user name. If the person is always downvoting or always voting the same as another person you'll see those patterns in their alt and the alt can be banned. It's an open source project so the mechanics of it cannot be kept secret and they can be verified by anyone with intermediate Python knowledge.

Regardless, at any kind of decent scale we're going to have to use code to detect bots and bad actors. Relying on admins to eyeball individual posts activity and manually compare them isn't going to scale at all, regardless whether the user names are easy to read or not.

load more comments (4 replies)
load more comments (1 replies)
[–] catloaf@lemm.ee 8 points 1 month ago (5 children)
load more comments (5 replies)
[–] indomara@lemmy.world 7 points 1 month ago

I missed the discussion on voting the other day it seems, but for what it's worth, I like the voting system. In real life discussions happen in open air, and don't hang there in posterity for people to stumble upon after. When we come to a consensus in conversation it is then left at that and we move on.

When online, these discussions stay as they are, and I think voting gives a way of people to come to a consensus, to leave a mark upon the conversation such that the people who come behind understand how everyone felt about it.

This is helpful I think, because it does not hide the down votes on nasty comments or ideas that hurt others.

One of the most interesting and horrible things about the internet is that every village has a "crazy Bob" but because they were the minority the good of the people outnumbered their outlandish or hateful ideas.

Now they can and do find each other online, forming a vocal and damaging minority. Without the majority able to show their dislike, human nature means more will fall in line with them and their ideals.

[–] Churbleyimyam@lemm.ee 7 points 1 month ago (2 children)

Is it possible for an instance to send out false vote data that can't be verified? Lemmy doesn't seem like a plausible target for it at the moment (and i dont pretend to know how this works beyond a conceptual level) but I can imagine a bad actor at some point seeking to manipulate voting.

[–] smeg@feddit.uk 10 points 1 month ago

I guess that can happen now anyway as the bad actor can just create their own instance with as many fake accounts as they like. Ultimately it's still on other instance admins to block the dodgy ones either way.

load more comments (1 replies)
[–] Ice@piefed.social 7 points 1 month ago

That's super cool and amazing that you implemented it so quickly.

So now I have a PieFed account :)

[–] Jilanico@lemmy.world 6 points 1 month ago

Interesting solution 👍 Curious to see how this plays out!

load more comments
view more: next ›