Skip Navigation

Lemmy v0.18.0 Release

What is Lemmy?

Lemmy is a self-hosted social link aggregation and discussion platform. It is completely free and open, and not controlled by any company. This means that there is no advertising, tracking, or secret algorithms. Content is organized into communities, so it is easy to subscribe to topics that you are interested in, and ignore others. Voting is used to bring the most interesting items to the top.

Major Changes

HTTP API instead of Websocket

Until now Lemmy-UI used websocket for all API requests. This has many disadvantages, like making the code harder to maintain, and causing live updates to the site which many users dislike. Most importantly, it requires keeping a connection open between server and client at all times, which causes increased load and makes scaling difficult. That's why we decided to rip out websocket entirely, and switch to HTTP instead. This change was made much more urgent by the sudden influx of new users. @CannotSleep420 and @dessalines have been working hard for the past weeks to implement this change in lemmy-ui.

HTTP on its own is already more lightweight than websocket. Additionally it also allows for caching of server responses which can decrease load on the database. Here is an experimental nginx config which enables response caching. Note that Lemmy doesn't send any cache-control headers yet, so there is a chance that private data gets cached and served to other users. Test carefully and use at your own risk.

Two-Factor Authentication

New support for two-factor authentication. Use an app like andOTP or Authenticator Pro to store a secret for your account. This secret needs to be entered every time you login. It ensures that an attacker can't access your account with the password alone.

Custom Emojis

Instance admins can add different images as emojis which can be referenced by users when posting.

Other changes

Progressive Web App

Lemmy's web client can now be installed on browsers that support PWAs, both on desktop and mobile. It will use an instance's icon and name for the app if they are set, making it look like a given instance is an app.

Note for desktop Firefox users: the desktop version of Firefox does not have built in support for PWAs. If you would like to use a Lemmy instance as a PWA, use use this extension.

Error Pages

Lemmy's web client now has error pages that include resources to use if the problem persists. This should be much less jarring for users than displaying a white screen with the text "404 error message here".

Route Changes

Pages that took arguments in the route now take query parameters instead. For example, a link to lemmy.ml's home page with a few options used to look like this:

 undefined
    
https://lemmy.ml/home/data_type/Post/listing_type/All/sort/Active/page/1

  

The new route would look like this:

 undefined
    
https://lemmy.ml?listingType=All


  

Note that you now only have to specify parameters you want instead of all of them.

Searchable select redesign

The searchable selects, such as those used on the search page, have a new look and feel. No more inexplicable green selects when using the lightly themes!

Share button

Posts on the web client now have a share button on supported browsers. This can be used to share posts to other applications quickly and easily.

Lemmy-UI Overall look and feel

lemmy-ui is now upgraded to bootstrap 5, and every component is now much cleaner.

Special thanks to sleepless, alectrocute, jsit, and many others for their great work on improving and re-organizing lemmy-ui.

Database optimizations

Special thanks to johanndt, for suggesting improvements to Lemmy's database queries. Some of these suggestions have already been implemented, and more are on the way.

Query speed is Lemmy's main performance bottleneck, so we really appreciate any help database experts can provide.

Captchas

Captchas are not available in this version, as they need to be reimplemented in a different way. They will be back in 0.18.1, so wait with upgrading if you rely on them.

Upgrade instructions

Follow the upgrade instructions for ansible or docker.

If you need help with the upgrade, you can ask in our support forum or on the Matrix Chat.

Support development

We (@dessalines and @nutomic) have been working full-time on Lemmy for almost three years. This is largely thanks to support from NLnet foundation.

If you like using Lemmy, and want to make sure that we will always be available to work full time building it, consider donating to support its development. No one likes recurring donations, but they've proven to be the only way that open-source software like Lemmy can stay independent and alive.

159 comments
  • Another addition that wasn't covered in the release notes, these will now automatically be linked to your local instance without having to do anything:

    Edit: Forgot about kbin support

    The markup is rendered as links when a valid format is detected without modifying the underlying text:

    • There was like 200 comments worth of discussion on this and it seems like it was implemented without much fanfare. What gives? This is one of the biggest gripes I had early on. I’m gonna shout this from the roof tops

      • I saw those giant threads where it was being discussed in circles and decided to take a crack at implementing it myself. Turns out it was not that difficult, I think I was just the first developer who found the threads and took action. Everyone else was focused on getting bug fixes into this release.

      • Updated my comment, I forgot to mention it also supports the kbin /m/ format for communities

  • Damn, big update! I see a lot of people are contributing, that's really the biggest gift from Reddit's poor decisions (well, presuming contributions did increase, which is a fair assumption).

    That's why I love open source software, it's truly a community effort!

  • Great, it seems that there's way less error message on Jerboa now with this update.

  • yay! thank you all!

    i have made a not-so-quick-but-dirty Dockerfile to build on arm64

     undefined
        
    FROM rust:1.70.0
    WORKDIR /app
    
    COPY . .
    
    RUN echo "pub const VERSION: &str = \"$(git describe --tag)\";" > "crates/utils/src/version.rs"
    RUN cargo build --release
    
    RUN apt update
    RUN apt -y install libpq5
    RUN cp /app/target/release/lemmy_server /app/lemmy
    
    CMD ["/app/lemmy"]
    
      

    later I am planning to improve it a bit, to make the image smaller if i can

  • Wow, can't wait until my instance upgrades. Great work! I don't think I will miss that alien site.

  • I’ve been noticing significantly less errors when using the API. Thanks for all the hard work I know you guys are putting in. Much appreciated to both of you and the other guys contributing to the project.

  • By Odin's beard!!! That's an absolute LIST of impressive and impactful enhancements!
    \ I feel like I owe you several drinks after reading all of that!

  • Will there be an ARM docker? I was hoping to start an instance on my RPi that’s laying around.

    Thank you

  • WOOO!!!

    Sounds like a great collection of needed changes, and a few QoL thrown in for good measure.

    Thank you devs! ❤️❤️❤️

  • Regarding

    Note that you now only have to specify parameters you want instead of all of them.

    That doesn't seem to apply to the search page. For example, putting https://lemmy.ml/search?q=test&sort=New will lead to The server returned this error: couldnt_find_object. This may be useful for admins and developers to diagnose and fix the error

    Copying the URL of a search (without stripping parameters) and opening it in a new tab so that it doesn't contains any referers also returns the same error.

    Also great work and congrats on the release 🙂

  • Nice!

    Your link to Authenticator Pro is broken, by the way.

159 comments