]> Untitled Git - lemmy.git/blob - RELEASES.md
Adding pre-release notes.
[lemmy.git] / RELEASES.md
1 # Lemmy v0.9.4 Pre-Release (2021-02-02)
2
3 ## Changes
4
5 - Fixed a critical bug with votes and comment unlike responses not being `0` for your user.
6 - Fixed a critical bug with comment creation not checking if its parent comment is in the post.
7 - Serving proper activities for community outbox.
8 - Added URL type for database fields.
9 - Added some active user counts, including `users_active_day`, `users_active_week`, `users_active_month`, `users_active_half_year` to `SiteAggregates` and `CommunityAggregates`.
10 - Made sure banned users can't follow.
11 - Added `FederatedInstances` to `SiteResponse`, to show allowed and blocked instances.
12 - Added a `MostComments` sort for posts.
13 - Added a scroll position restore to lemmy-ui.
14 - Reworked the combined inbox so incoming comments don't wipe out your current form.
15 - Fixed an updated bug on the user page.
16 - Fixed cross-post titles and body getting clipped.
17 - Fixing the post creation title height.
18 - Squashed some other smaller bugs.
19
20 # Lemmy v0.9.0 Release (2021-01-25)
21
22 ## Changes
23
24 Since our last release in October of last year, and we've had [~450](https://github.com/LemmyNet/lemmy/compare/v0.8.0...main) commits.
25
26 The biggest changes, as we'll outline below, are a re-work of Lemmy's database structure, a `v2` of Lemmy's API, and activitypub compliance fixes. The new re-worked DB is much faster, easier to maintain, and [now supports hierarchical rather than flat objects in the new API](https://github.com/LemmyNet/lemmy/issues/1275).
27
28 We've also seen the first release of [Lemmur](https://github.com/krawieck/lemmur/releases/tag/v0.1.1), an android / iOS (soon) / windows / linux client, as well as [Lemmer](https://github.com/uuttff8/Lemmy-iOS), a native iOS client. Much thanks to @krawieck, @shilangyu, and @uuttff8 for making these great clients. If you can, please contribute to their [patreon](https://www.patreon.com/lemmur) to help fund lemmur development.
29
30 ## LemmyNet projects
31
32 ### Lemmy Server
33
34 - [Moved views from SQL to Diesel](https://github.com/LemmyNet/lemmy/issues/1275). This was a spinal replacement for much of lemmy.
35   - Removed all the old fast_tables and triggers, and created new aggregates tables.
36 - Added a `v2` of the API to support the hierarchical objects created from the above changes.
37 - Moved continuous integration to [drone](https://cloud.drone.io/LemmyNet/lemmy/), now includes formatting, clippy, and cargo build checks, unit testing, and federation testing. [Drone also deploys both amd64 and arm64 images to dockerhub.](https://hub.docker.com/r/dessalines/lemmy)
38 - Split out documentation into git submodule.
39 - Shortened slur filter to avoid false positives.
40 - Added query performance testing and comparisons. Added indexes to make sure every query is `< 30 ms`.
41 - Added compilation time testing.
42
43 ### Federation
44
45 This release includes some bug fixes for federation, and some changes to get us closer to compliance with the ActivityPub standard.
46
47 - [Community bans now federating](https://github.com/LemmyNet/lemmy/issues/1287).
48 - [Local posts sometimes got marked as remote](https://github.com/LemmyNet/lemmy/issues/1302).
49 - [Creator of post/comment was not notified about new child comments](https://github.com/LemmyNet/lemmy/issues/1325).
50 - [Community deletion now federated](https://github.com/LemmyNet/lemmy/issues/1256).
51
52 None of these are breaking changes, so federation between 0.9.0 and 0.8.11 will work without problems.
53
54 ### Lemmy javascript / typescript client
55
56 - Updated the [lemmy-js-client](https://github.com/LemmyNet/lemmy-js-client) to use the new `v2` API. Our API docs now reference this project's files, to show what the http / websocket forms and responses should look like.
57 - Drone now handles publishing its [npm packages.](https://www.npmjs.com/package/lemmy-js-client)
58
59 ### Lemmy-UI
60
61 - Updated it to use the `v2` API via `lemmy-js-client`, required changing nearly every component.
62 - Added a live comment count.
63 - Added drone deploying, and builds for ARM.
64 - Fixed community link wrapping.
65 - Various other bug fixes.
66
67
68 ### Lemmy Docs
69
70 - We moved documentation into a separate git repository, and support translation for the docs now!
71 - Moved our code of conduct into the documentation.
72
73 ## Upgrading
74
75 If you'd like to make a DB backup before upgrading, follow [this guide](https://lemmy.ml/docs/en/administration/backup_and_restore.html).
76
77 - [Upgrade with manual Docker installation](https://lemmy.ml/docs/en/administration/install_docker.html#updating)
78 - [Upgrade with Ansible installation](https://lemmy.ml/docs/en/administration/install_ansible.html)
79
80 # Lemmy v0.8.0 Release (2020-10-16)
81
82 ## Changes
83
84 We've been working at warp speed since our `v0.7.0` release in June, adding over [870 commits](https://github.com/LemmyNet/lemmy/compare/v0.7.0...main) since then. :sweat: 
85
86 Here are some of the bigger changes:
87
88 ### LemmyNet projects
89
90 - Created [LemmyNet](https://github.com/LemmyNet), where all lemmy-related projects live.
91 - Split out the frontend into a separete repository, [lemmy-ui](https://github.com/LemmyNet/lemmy-ui)
92 - Created a [lemmy-js-client](https://github.com/LemmyNet/lemmy-js-client), for any js / typescript developers.
93 - Split out i18n [lemmy-translations](https://github.com/LemmyNet/lemmy-translations), that any app or site developers can import and use. Lemmy currently supports [~30 languages!](https://weblate.yerbamate.ml/projects/lemmy/lemmy/)
94
95 ### Lemmy Server
96
97 #### Federation
98
99 - The first **federation public beta release**, woohoo :fireworks: 
100 - All Lemmy functionality now works over ActivityPub (except turning remote users into mods/admins)
101 - Instance allowlist and blocklist
102 - Documentation for [admins](https://lemmy.ml/docs/administration_federation.html) and [devs](https://lemmy.ml/docs/contributing_federation_overview.html) on how federation works
103 - Upgraded to newest versions of @asonix activitypub libraries
104 - Full local federation setup for manual testing
105 - Automated testing for nearly every federation action
106 - Many additional security checks
107 - Lots and lots of refactoring
108 - Asynchronous sending of outgoing activities
109
110 ### User Interface
111
112 - Separated the UI from the server code, in [lemmy-ui](https://github.com/LemmyNet/lemmy-ui).
113 - The UI can now read with javascript disabled! 
114 - It's now a fully isomorphic application using [inferno-isomorphic](https://infernojs.org/docs/guides/isomorphic). This means that page loads are now much faster, as the server does the work.
115 - The UI now also supports open-graph and twitter cards! Linking to lemmy posts (from whatever platform you use) looks pretty now: ![](https://i.imgur.com/6TZ2v7s.png)
116 - Improved the search page ( more features incoming ).
117 - The default view is now `Local`, instead of `All`, since all would show all federated posts.
118 - User settings are now shared across browsers ( a page refresh will pick up changes ).
119 - A much leaner mobile view.
120
121 #### Backend
122
123 - Re-organized the rust codebase into separate workspaces for backend and frontend.
124 - Removed materialized views, making the database **a lot faster**.
125 - New post sorts `Active` (previously called hot), and `Hot`. Active shows posts with recent comments, hot shows highly ranked posts.
126 - New sort for `Local` ( meaning from local communities).
127 - Customizeable site, user, and community icons and banners.
128 - Added user preferred names / display names, bios, and cakedays.
129 - Visual / Audio captchas through the lemmy API.
130 - Lots of API field verifications.
131 - Upgraded to pictrs-v2 ( thanks to @asonix )
132 - Wayyy too many bugfixes to count.
133
134 ## Contributors
135
136 We'd also like to thank both the [NLnet foundation](https://nlnet.nl/) for their support in allowing us to work full-time on Lemmy ( as well as their support for [other important open-source projects](https://nlnet.nl/project/current.html) ), [those who sponsor us](https://lemmy.ml/sponsors), and those who [help translate Lemmy](https://weblate.yerbamate.ml/projects/lemmy/). Every little bit does help. We remain committed to never allowing advertisements, monetizing, or venture-capital in Lemmy; software should be communal, and should benefit humanity, not a small group of company owners. 
137
138 ## Upgrading
139
140 - [with manual Docker installation](https://lemmy.ml/docs/administration_install_docker.html#updating)
141 - [with Ansible installation](https://lemmy.ml/docs/administration_install_ansible.html)
142
143 ## Testing Federation
144
145 Federation is finally ready in Lemmy, pending possible bugs or other issues. So for now we suggest to enable federation only on test servers, or try it on our own test servers ( [enterprise](https://enterprise.lemmy.ml/), [ds9](https://ds9.lemmy.ml/), [voyager](https://voyager.lemmy.ml/) ).
146
147 If everything goes well, after a few weeks we will enable federation on lemmy.ml, at first with a limited number of trusted instances. We will also likely change the domain to https://lemmy.ml . Keep in mind that changing domains after turning on federation will break things.
148
149 To enable on your instance, edit your [lemmy.hjson](https://github.com/LemmyNet/lemmy/blob/main/config/defaults.hjson#L60) federation section to `enabled: true`, and restart.
150
151 ### Connecting to another server
152
153 The server https://ds9.lemmy.ml has open federation, so after either adding it to the `allowed_instances` list in your `config.hjson`, or if you have open federation, you don't need to add it explicitly.
154
155 To federate / connect with a server, type in `!community_name@server.tld`, in your server's search box [like so](https://voyager.lemmy.ml/search/q/!main%40ds9.lemmy.ml/type/All/sort/TopAll/page/1).
156
157 To connect with the `main` community on ds9, the search is `!main@ds9.lemmy.ml`.
158
159 You can then click the community, and you will see a local version of the community, which you can subscribe to. New posts and comments from `!main@ds9.lemmy.ml` will now show up on your front page, or `/c/All`
160
161 # Lemmy v0.7.40 Pre-Release (2020-08-05)
162
163 We've [added a lot](https://github.com/LemmyNet/lemmy/compare/v0.7.40...v0.7.0) in this pre-release:
164
165 - New post sorts `Active` (previously called hot), and `Hot`. Active shows posts with recent comments, hot shows highly ranked posts.
166 - Customizeable site icon and banner, user icon and banner, and community icon and banner.
167 - Added user preferred names / display names, bios, and cakedays.
168 - User settings are now shared across browsers (a page refresh will pick up changes).
169 - Visual / Audio captchas through the lemmy API.
170 - Lots of UI prettiness.
171 - Lots of bug fixes.
172 - Lots of additional translations.
173 - Lots of federation prepping / additions / refactors.
174
175 This release removes the need for you to have a pictrs nginx route (the requests are now routed through lemmy directly). Follow the upgrade instructions below to replace your nginx with the new one.
176
177 ## Upgrading
178
179 **With Ansible:**
180
181 ```
182 # run these commands locally
183 git pull
184 cd ansible
185 ansible-playbook lemmy.yml
186 ```
187
188 **With manual Docker installation:**
189 ```
190 # run these commands on your server
191 cd /lemmy
192 wget https://raw.githubusercontent.com/LemmyNet/lemmy/master/ansible/templates/nginx.conf
193 # Replace the {{ vars }}
194 sudo mv nginx.conf /etc/nginx/sites-enabled/lemmy.conf
195 sudo nginx -s reload
196 wget https://raw.githubusercontent.com/LemmyNet/lemmy/master/docker/prod/docker-compose.yml
197 sudo docker-compose up -d
198 ```
199
200
201 # Lemmy v0.7.0 Release (2020-06-23)
202
203 This release replaces [pictshare](https://github.com/HaschekSolutions/pictshare)
204 with [pict-rs](https://git.asonix.dog/asonix/pict-rs), which improves performance
205 and security.
206
207 Overall, since our last major release in January (v0.6.0), we have closed over
208 [100 issues!](https://github.com/LemmyNet/lemmy/milestone/16?closed=1)
209
210 - Site-wide list of recent comments
211 - Reconnecting websockets
212 - Many more themes, including a default light one.
213 - Expandable embeds for post links (and thumbnails), from
214 [iframely](https://github.com/itteco/iframely)
215 - Better icons
216 - Emoji autocomplete to post and message bodies, and an Emoji Picker
217 - Post body now searchable
218 - Community title and description is now searchable
219 - Simplified cross-posts
220 - Better documentation
221 - LOTS more languages
222 - Lots of bugs squashed
223 - And more ...
224
225 ## Upgrading
226
227 Before starting the upgrade, make sure that you have a working backup of your
228 database and image files. See our
229 [documentation](https://lemmy.ml/docs/administration_backup_and_restore.html)
230 for backup instructions.
231
232 **With Ansible:**
233
234 ```
235 # deploy with ansible from your local lemmy git repo
236 git pull
237 cd ansible
238 ansible-playbook lemmy.yml
239 # connect via ssh to run the migration script
240 ssh your-server
241 cd /lemmy/
242 wget https://raw.githubusercontent.com/LemmyNet/lemmy/master/docker/prod/migrate-pictshare-to-pictrs.bash
243 chmod +x migrate-pictshare-to-pictrs.bash
244 sudo ./migrate-pictshare-to-pictrs.bash
245 ```
246
247 **With manual Docker installation:**
248 ```
249 # run these commands on your server
250 cd /lemmy
251 wget https://raw.githubusercontent.com/LemmyNet/lemmy/master/ansible/templates/nginx.conf
252 # Replace the {{ vars }}
253 sudo mv nginx.conf /etc/nginx/sites-enabled/lemmy.conf
254 sudo nginx -s reload
255 wget https://raw.githubusercontent.com/LemmyNet/lemmy/master/docker/prod/docker-compose.yml
256 wget https://raw.githubusercontent.com/LemmyNet/lemmy/master/docker/prod/migrate-pictshare-to-pictrs.bash
257 chmod +x migrate-pictshare-to-pictrs.bash
258 sudo bash migrate-pictshare-to-pictrs.bash
259 ```
260
261 **Note:** After upgrading, all users need to reload the page, then logout and
262 login again, so that images are loaded correctly.
263
264 # Lemmy v0.6.0 Release (2020-01-16)
265
266 `v0.6.0` is here, and we've closed [41 issues!](https://github.com/LemmyNet/lemmy/milestone/15?closed=1) 
267
268 This is the biggest release by far:
269
270 - Avatars!
271 - Optional Email notifications for username mentions, post and comment replies.
272 - Ability to change your password and email address.
273 - Can set a custom language.
274 - Lemmy-wide settings to disable downvotes, and close registration.
275 - A better documentation system, hosted in lemmy itself.
276 - [Huge DB performance gains](https://github.com/LemmyNet/lemmy/issues/411) (everthing down to < `30ms`) by using materialized views. 
277 - Fixed major issue with similar post URL and title searching.
278 - Upgraded to Actix `2.0`
279 - Faster comment / post voting.
280 - Better small screen support.
281 - Lots of bug fixes, refactoring of back end code.
282
283 Another major announcement is that Lemmy now has another lead developer besides me, [@felix@radical.town](https://radical.town/@felix). Theyve created a better documentation system, implemented RSS feeds, simplified docker and project configs, upgraded actix, working on federation, a whole lot else.
284
285 https://lemmy.ml