For those not familiar, there are numerous messages containing images being repeatedly spammed to many Threadiverse users talking about a Polish girl named “Nicole”. This has been ongoing for some time now.

Lemmy permits external inline image references to be embedded in messages. This means that if a unique image URL or set of image URLs are sent to each user, it’s possible to log the IP addresses that fetch these images; by analyzing the log, one can determine the IP address that a user has.

In some earlier discussion, someone had claimed that local lemmy instances cache these on their local pict-rs instance and rewrite messages to reference the local image.

It does appear that there is a closed issue on the lemmy issue tracker referencing such a deanonymization attack:

https://github.com/LemmyNet/lemmy/issues/1036

I had not looked into these earlier, but it looks like such rewriting and caching intending to avoid this attack is not occurring, at least on my home instance. I hadn’t looked until the most-recent message, but the image embedded here is indeed remote:

https://lemmy.doesnotexist.club/pictrs/image/323899d9-79dd-4670-8cf9-f6d008c37e79.png

I haven’t stored and looked through a list of these, but as I recall, the user sending them is bouncing around different instances. They certainly are not using the same hostname for their lemmy instance as the pict-rs instance; this message was sent from nicole92 on lemmy.latinlok.com, though the image is hosted on lemmy.doesnotexist.club. I don’t know whether they are moving around where the pict-rs instance is located from message to message. If not, it might be possible to block the pict-rs instance in your browser. That will only be a temporary fix, since I see no reason that they couldn’t also be moving the hostname on the pict-rs instance.

Another mitigation would be to route one’s client software or browser through a VPN.

I don’t know if there are admins working on addressing the issue; I’d assume so, but I wanted to at least mention that there might be privacy implications to other users.

In any event, regardless of whether the “Nicole” spammer is aiming to deanonymize users, as things stand, it does appear that someone could do so.

My own take is that the best fix here on the lemmy-and-other-Threadiverse-software-side would be to disable inline images in messages. Someone who wants to reference an image can always link to an external image in a messages, and permit a user to click through. But if remote inline image references can be used, there’s no great way to prevent a user’s IP address from being exposed.

If anyone has other suggestions to mitigate this (maybe a Greasemonkey snippet to require a click to load inline images as a patch for the lemmy Web UI?), I’m all ears.

  • Cypher@lemmy.world
    link
    fedilink
    English
    arrow-up
    15
    ·
    8 hours ago

    We used to do this on the EVE online forums until CCP caught on and banned inline images.

      • Cypher@lemmy.world
        link
        fedilink
        English
        arrow-up
        14
        ·
        6 hours ago

        We were using the IPs and post times to identify accounts, then checking IPs that connected to our VOIP servers so we could identify spies and either remove them or feed them false intel.

        Basic counter-intel work and all for a video game heh.

  • DFX4509B@lemmy.org
    link
    fedilink
    English
    arrow-up
    10
    ·
    edit-2
    8 hours ago

    I’ve been blocking and reporting these nicole accounts as spam bots lately. I hope this doesn’t become as bad as the spam bots in the YT comments.

  • can@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    10
    ·
    edit-2
    5 hours ago

    A while back someone mentioned something similar would be possible and as a proof of concept linked to an image that would generate on the fly to include your location.

    • forrgott@lemm.ee
      link
      fedilink
      English
      arrow-up
      4
      arrow-down
      2
      ·
      11 hours ago

      Yup. Especially with digital watermarking by modifying a pixel here or there - something you’d naturally need a computer to detect.

  • RaoulDook@lemmy.world
    link
    fedilink
    English
    arrow-up
    24
    ·
    10 hours ago

    Might be good to think about fediverse security similar to email security, as they are both federated information sharing systems. Email has spam blocking, allowing for reputation checks and other complex stuff. I wonder if Lemmy instances could collaborate on a SpamHaus type of bad host / bad user list to use and share.

  • LWD@lemm.ee
    link
    fedilink
    English
    arrow-up
    6
    ·
    10 hours ago

    I miss those old images that would show you your IP address and ISP name, which were generated dynamically based on the request. They were designed just to be a bit frightening. But, because they were rendered on the server side, there was definitely nothing stopping them from recording your IP address too.

    https://imgur.com/aYxadwg

  • drspod@lemmy.ml
    link
    fedilink
    English
    arrow-up
    13
    arrow-down
    1
    ·
    12 hours ago

    On my instance (.ml) all of the images are fetched through the image proxy.

    What version of lemmy is your instance running?

    • tal@lemmy.todayOP
      link
      fedilink
      English
      arrow-up
      5
      ·
      edit-2
      8 hours ago

      I mean, it (hopefully) shouldn’t let someone compromise a system remotely, but:

      • For those of you who have used IRC networks that didn’t mask IP addresses, people getting in flamewars proceeding to then DDoSing each other is a fundamental issue. If someone wants to do something at low latency, like play real-time video games, this is a particularly obnoxious way to disrupt them.

      • IP addresses can often be correlated across databases, even by random members of the public. I remember someone running another bot that would map IP addresses to BitTorrent downloads, for example.

      End of the day, the Lemmy security model is “someone can see the username you choose to expose, but not IP address”. If the IP address is intended to be exposed, then might as well just stick it right next to the username. If it isn’t, then one shouldn’t let users be able to trivially-obtain it by pulling a direct-message stunt.

      • Possibly linux@lemmy.zip
        link
        fedilink
        English
        arrow-up
        2
        arrow-down
        1
        ·
        edit-2
        6 hours ago

        You as a user can not just DDoS someone. Modern connections a way faster and modern network hardware with drop packets that are taking up to much bandwidth. You are also behind a firewall and probaby a NAT which will drop random incoming packets.

        The modern internet is full of bots scanning. If that doesn’t destroy your connection chances are some random internet person can’t either.

        • tal@lemmy.todayOP
          link
          fedilink
          English
          arrow-up
          1
          ·
          edit-2
          4 hours ago

          You as a user can not just DDoS someone. Modern connections a way faster and modern network hardware with drop packets that are taking up to much bandwidth.

          You know, I thought about responding to this point by point, but I just don’t have the energy.

          I’ll just say that I don’t agree, and I think that if you want to go looking, you’ll find that this certainly is not the case.

          • Possibly linux@lemmy.zip
            link
            fedilink
            English
            arrow-up
            1
            arrow-down
            1
            ·
            4 hours ago

            Honestly I would be very interested to know what you are talking about. If you are referencing the past or very old hardware I get it but for modern stuff that’s just not the case.

      • Possibly linux@lemmy.zip
        link
        fedilink
        English
        arrow-up
        3
        ·
        edit-2
        8 hours ago

        That’s fair

        However, a state actor probably has more effective means. It is really speculation at this point. It would be nice if someone did a full investigation.

      • Possibly linux@lemmy.zip
        link
        fedilink
        English
        arrow-up
        1
        arrow-down
        1
        ·
        8 hours ago

        It doesn’t provide much information since your IP address is probably not static. It rotates and thanks to NAT it is probably shared.

          • Possibly linux@lemmy.zip
            link
            fedilink
            English
            arrow-up
            1
            ·
            edit-2
            6 hours ago

            It boils down to the ISP. Also there is no way of knowing when a IP changes. At the end of the day there a much better ways of tracking.

            Someone can learn what city you are in