Hey everyone.

I make Peersuite, an opensource free communication platform.

It’s private by default, there’s no sign-in or email collection.

It’s peer-to-peer, there’s no server, after discovery you are connected directly to your friends my AES-GCN encrypted WebRTC channels. It forms a mesh and identifies superpeers. Because there is no server, in order to save your data between sessions, you can download your workspace into a password encrypted file. Happy to answer any questions.

FEATURES: chat with images, PMs, channels, and file send group audio/video calling screensharing kanban board whiteboard for diagrams/flowchartswith PNG export collaborative document editing with formatted PDF export

The best way for self hosting is docker, its on dockerhub as openconstruct/peersuite. You can also download desktop versions from the github or use on the web at https://peersuite.space/

  • Ada@lemmy.blahaj.zone
    link
    fedilink
    English
    arrow-up
    0
    ·
    2 months ago

    A couple of questions. If I was trying to keep a consistent workspace to build a community around, would it be persistent after the host logs off, and are their tools to protect it from trolls etc who discover it a workspace?

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      It would not be persistent. You can download a workspace to an encrypted file. I have plans to make a node.js server for workspace permanence.

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      They would have to guess the roomcode and password, it’s pretty difficult to brute-force.

      I’m planning some sort of auth system, but not sure how I wanna do it yet.

  • secret300@lemmy.sdf.org
    link
    fedilink
    English
    arrow-up
    0
    ·
    edit-2
    2 months ago

    feel-ford-bean-base

    pass: poop

    workspace code ^^^ for anyone that wants to test it out with me. I don’t have friends to do so :(

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      I could package the electron version to flathub, I hadn’t considered that. I will read up on it.

  • TempermentalAnomaly@lemmy.world
    link
    fedilink
    English
    arrow-up
    0
    ·
    2 months ago

    My group recently switched to Matrix and so this would be a tough sell, but it seems interesting. I haven’t been a fan of Matrix and miss the ease of UI in discord, but was happy to leave with it’s direction. How would you sell it with a small group that has small, but mounting usability issues with Matrix?

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      Get everybody in to at least try it. I tried to make everything as intuitive as possible.

  • themachine@lemmy.world
    link
    fedilink
    English
    arrow-up
    0
    ·
    edit-2
    2 months ago

    Well hell I may stand this up tonight. My only question is does the voice chat support push-to-talk?

    Edit: Ok, gave it a spin. It does not support push-to-talk but being fully browser based I don’t think that’s a trivial thing to implement anyway.

    That said, this is pretty sweet though certainly still rudimentary. I was really looking forward to the screen sharing but my friend on the other end said the quality and framerate were pretty bad. Not sure what flexibility there is as far as adjustable bit rate and framerate with what you’re doing but I’ll definitely be keeping my eye on this project.

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      Push to talk is in testing now. WebRTC changes quality automatically based on bandwidth. Its usually really good. It runs at full quality in testing ( i have like 6 devices I hook up and test). If you guys normally have a good connection, try again?

      • themachine@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        ·
        2 months ago

        Perhaps talking about bitrate wasn’t correct of me. After looking at this again image quality itself is actually pretty good but the framerate is a different story.

        To provide context, I used it to share the video game I was playing as my friends that use discord tell me they primarily stick to it for its screen sharing capability which they use when gaming.

        I’m not sure how to best test this and provide metrics to you if this is improvable or even something you care about.

        To attempt to take the connection factor out of the equation I opened two browser windows and viewed my own screen share from a different username and even then the framerate is not great.

            • moonpiedumplings@programming.dev
              link
              fedilink
              English
              arrow-up
              0
              ·
              2 months ago

              There is literally no way to do performant e2ee at large scale. e2ee works by encrypting every message for every recipient, on the users device.

              At 1000 users, that’s basically a public room.

              • Andres@social.ridetrans.it
                link
                fedilink
                arrow-up
                0
                ·
                2 months ago

                @moonpiedumplings @jagged_circle I read your initial question as 1,000 active chat *rooms* (with some large number of users for each), which… seems excessive. That’s what I was referring to.

                1,000 individual private 1-on-1 chats (or group chats with 2-3 users), if that’s what you meant (and especially over a long period of time, with lots of inactive chats), seems like a more common scenario*. If that was your question, I apologize.

                • Andres@social.ridetrans.it
                  link
                  fedilink
                  arrow-up
                  0
                  ·
                  2 months ago

                  @moonpiedumplings @jagged_circle
                  * I can’t speak on behalf of the author, but I could imagine handling it by simply not decrypting _everything_ on startup, and only decrypting an older chat if you click on it or attempt to run a search on everything. Although for a search, I would expect some kind of hashed (and of course encrypted) database that allows a quick search of all prior messages.

              • jerry@lemmy.worldOP
                link
                fedilink
                English
                arrow-up
                0
                ·
                2 months ago

                I haven’t had a chance to test the limits of Peersuite, but since it’s a mesh network, I don’t think it would run well with even 100 people.

            • jerry@lemmy.worldOP
              link
              fedilink
              English
              arrow-up
              0
              ·
              2 months ago

              Chat is Peersuite is limited to workspaces. You can only talk to people inside your workspace. I didn’t want to add accounts, and sign-ins and all those things that collect data. So when you sign into peersuite, you are only talking to the people in the workspace with you. It works entirely different and your questions don’t really apply to how it works.

  • Andres@social.ridetrans.it
    link
    fedilink
    arrow-up
    0
    ·
    2 months ago

    @jerrimu A usability suggestion, having just tried it out - save the username and room password in the export file to make it more like a traditional chat experience. So when you import the chat file, the username and password are pre-populated along with the room name.

        • jerry@lemmy.worldOP
          link
          fedilink
          English
          arrow-up
          0
          ·
          2 months ago

          The export is password encrypted already. I’ll see if there’s a good way to do it.

          • martinb@lemmy.sdf.org
            link
            fedilink
            English
            arrow-up
            0
            ·
            2 months ago

            Fair enough, it lowers the risk. Are you doing key stretching? Ie. X rounds of pbkdf or whatever it’s called?

        • Andres@social.ridetrans.it
          link
          fedilink
          arrow-up
          0
          ·
          2 months ago

          @martinb @jerrimu I wrote the initial comment with the idea of saving just the username, but then figured “why not?” for the password. If the password is saved in browser memory (and based how I *think* the app functions, it would have to be), then it wouldn’t be much different than saving a password in firefox’s password manager (for example). Assuming reasonable crypto usage by the app, of course.

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      Group voice and video are working fine. I’ve only tested screen share with 3 computers but if works fine also.

      • alphabethunter@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        ·
        2 months ago

        I just realized it’s on the post. Sorry for that. This looks like a solid thing, for sure. Since we’re talking, do you ever worry about people making use of the privacy features for nefarious purposes?

        • jerry@lemmy.worldOP
          link
          fedilink
          English
          arrow-up
          0
          ·
          2 months ago

          I guess that could be an issue. I don’t think privacy makes you a criminal, but sure they want it. But so do tons of people who follow the rules. A Scottish Indepence group cloned it on github. That’s really coo to me, I love the idea of political dissidents using it, but the idea of it being used to hurt people does bother me.

  • jagged_circle@feddit.nl
    link
    fedilink
    English
    arrow-up
    0
    ·
    2 months ago

    Can I tick a box in settings to force it to only connect to Tor Onion Services for enhanced privacy?

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      Working on it, capacitor doesnt work because it’s webview doesnt work with WebRTC

  • iopq@lemmy.world
    link
    fedilink
    English
    arrow-up
    0
    ·
    edit-2
    2 months ago

    This space definitely needs competition

    I like Matrix, but I do run into issues, like messages not being decrypted even though I verified my session. The average user is not ready for it. Or rather, it’s not ready for the average user

    • jerry@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      EVERYTHING is encrypted in peersuite, it’s mandatory. I tried to make the UI intuitive and simple, but IDK if I’m great at it.

      • ladfrombrad 🇬🇧@lemdro.id
        link
        fedilink
        English
        arrow-up
        0
        ·
        edit-2
        2 months ago

        but IDK if I’m great at it.

        Simples is best, hands down. Maybe some tooltips wouldn’t go amiss on your demo page?

        But as someone else pointed out, a link to the GitHub either in the header or footer of your demo page would be ace too. It was the first thing I looked for this morning seeing your posts and had to come back to the comments to find it 🙈

        Keep up the great work, and I shared between our nerd group and they have eyeballs on it. Seems a no brainer for teams collaborating online where we’ve got used of shitty Slack 🤢 Dicksword whatever.

        ninjaedit: if you want some help Android app wise, give us a ping. I have a few bored devs lurking looking for app ideas ;)

        • jerry@lemmy.worldOP
          link
          fedilink
          English
          arrow-up
          0
          ·
          2 months ago

          I think I’m going to go the route of buildind a PWA first then using bubblewrap to generate an APK. I tried capacitor, but audio/video didn’t work, it has meh WebRTC support.