diff --git a/docs/89-NEWS.md b/docs/89-NEWS.md
index 736c2fd1..90a0355c 100644
--- a/docs/89-NEWS.md
+++ b/docs/89-NEWS.md
@@ -1,10 +1,189 @@
# NEWS
+
+# Awesome window manager framework version 4.3 changes
+
+
+
+Awesome v4.3 is the third release of the 4.x API. It comes after one and a half
+years of little fixes and improvements. Awesome v4.2 was very stable thanks to
+everybody's effort to unit test everything. Given no major bug warranted a new
+release, this one adds a few large features while preserving full compatibility
+with existing user configurations.
+
+## New features
+
+ * `gears.string` now has a `endswith` and `startswith` functions
+ * `luarocks` modules are now automatically available in Awesome
+ * A generic way to create or use widgets has been added
+ (`wibox.widget.base.make_widget_from_value`)
+ * It is now possible to connect to signals from all instances of a widget at once
+ * The calendar widget now supports margins
+ * The documentation has a new theme
+ * Wiboxes now have `to_widget()` and `save_to_svg()` methods.
+ * The client objects now have a `immobilized_horizontal` and
+ `immobilized_vertical` property to know if they can currently be moved or
+ resized (for example, it is set to false when maximized)
+ * `gears.timer` objects now have a `call_now` method.
+ * The hotkey popup now supports `termite` keybindings
+ * The menubar loads faster
+ * Wiboxes have an `input_passthrough` property to send mouse clicks
+ to the object below.
+ * The `taglist` and `tasklist` now support the declarative constructor syntax
+ * There is now an `awesome.pixbuf_to_surface` to convert a `GdkPixbuf` to
+ a cairo surface.
+ * The notifications icon can now be resized and limited with
+ `notification\_icon_\size`
+ * A `gears.sort` module has been added with graph resolution
+ * `awesome-client` now runs code in a protected context
+ * The widget documentation has
+ been extended to be more friendly to new users.
+ * There is a new `beautiful.maximized_hide_border` theme option to hide the
+ border for maximized clients.
+ * The `client` `startup_id` field is now writable. This is useful when the
+ client native implementation is not present or too buggy to be used.
+ * The `awful.widget.prompt` now has a `with_shell` option to allow Bash/ZSH
+ aliases, function and environment variables to be used in commands.
+ * The `awful.titlebar`s now have a `fallback_name` when a client has no `name`
+ property.
+ * Clients now have a `motif_wm_hints` property to reflect some hints using the
+ Motif X11 property extension. This is used by some modern toolkits including
+ GTK.
+ * Clients now have a `requests_no_titlebar` property to expose when a client
+ has client side titlebars (also known as decorations and CSD)
+ * The hotkey popup now has a `show_awesome_keys` option.
+ * The `awful.widget.prompt` now has more of the `awful.prompt` constructor
+ arguments.
+ * It is now possible to set a list of layouts per tag instead of a single
+ global one.
+ * There is now a `awful.layout.get_tag_layout_index()` function to get the
+ index of the current layout in the global layout list
+ (`awful.layout..layouts`)
+ * The `wibox.layout.manual` layout now has an `:insert()` method.
+
+### Better DPI handling
+
+The screen now has a read/write `dpi` property and `awful.screen.set_auto_dpi_enabled(true)`
+can be used to automatically set the DPI for many Awesome elements. Please
+note that it is not backward compatible and breaks many widget. As AwesomeWM
+always used pixels as the de-facto metric for sizes, enabling `auto_dpi` will
+break most existing configs. However, for people who use such setup, it might be
+worth speding some time to fix their config.
+
+### Extendable `awful.rules` providers and better `awful.spawn` functions
+
+There is two new functions called `awful.rules.add_rule_source` and
+`awful.rules.remove_rule_source`. They allow to create a dependency graph
+for where a rule comes from and which provider has the priority when setting it.
+
+Previously, there were the normal properties,
+`awful.rules.high_priority_properties` and `awful.rules.delayed_properties`.
+This didn't scale and could not represent all corner cases. Those table still
+exist and are still honored, but there is now a system that can handle the full
+complexity of the property priority graph.
+
+This is used by default in `awful.spawn`. The reliability of attaching
+properties to `spawn` calls has been improved. On top of this, three new
+functions were added
+
+ * `awful.spawn.once`
+ * `awful.spawn.single_instance`
+ * `awful.spawn.raise_or_spawn`
+
+They allow to specify that a command should only have one running instance.
+This works across restart too, so all hacks to handle restarting Awesome are
+no longer required.
+
+Note that the `client.startup_id` isn't supported by all applications and a
+Linux-specific workaround is recommended to improve the reliability of the
+`awful.spawn` functions.
+
+### A brand new keygrabber API
+
+The `keygrabber` module API was rebuilt from scratch to make it more usable.
+The previous API was very low level, very close to how it actually work, but
+was disconnected from how keygrabbers are used in a window manager. Getting
+anything done with the previous API required a lot of boilerplate code and had
+many corner cases to handle. The new API has built-in support for the most
+common use cases and is fully declarative.
+
+### A new GTK color palette based theme
+
+A new theme has been added. It reads the GTK theme colors and use them in the
+`wibar`, `menu` and `titlebar`. It helps create an uniform look and feel
+between the window manager and client applications with minimal efforts.
+
+### Widgets improvements
+
+The following widgets have been added:
+
+
+
+It is now possible to set `spacing` widgets for all layouts:
+
+[![The separator widget](../images/AUTOGEN_wibox_layout_flex_spacing_widget.svg)](../classes/wibox.layout.flex.html#wibox.layout.flex.spacing_widget)
+
+The `awful.widget.taglist` and `awful.widget.tasklist` now support creating
+custom widgets for each elements:
+
+[![The separator widget](../images/AUTOGEN_wibox_awidget_taglist_indexed.svg)](../classes/wibox.layout.flex.html#wibox.layout.flex.spacing_widget)
+
+[![The separator widget](../images/AUTOGEN_wibox_awidget_tasklist_rounded.svg)](../classes/wibox.layout.flex.html#wibox.layout.flex.spacing_widget)
+
+[![The separator widget](../images/AUTOGEN_wibox_awidget_tasklist_windows10.svg)](../classes/wibox.layout.flex.html#wibox.layout.flex.spacing_widget)
+
+A new `popup` widget allows to bypass most of the boilerplate code and easily
+display widgets on the screen:
+
+[![The ratio strategies](../images/AUTOGEN_awful_popup_wiboxtypes.svg)](../classes/awful.popup.html)
+
+
+The `awful.widget.layoutlist` allows to easily display and select the client
+layout from a widget:
+
+[![The layoutbox](../images/AUTOGEN_awful_widget_layoutlist_bar.svg)](../classes/awful.widget.layoutlist.html)
+
+
+## Noteworthy fixes
+
+ * There is no longer an error when a tag defined by name in `awful.rules` is
+ not found.
+ * The menubar is now generally more robust thanks to a variety of improvements
+ * Many dead links in the documentation have been fixed
+ * The `textclock` is now generally more robust with formatting issues,
+ timezones and declarative constructors.
+ * The last screen is never removed. Previously, some laptops removed all screens
+ during suspend, causing all clients to go to the first tag or getting lost
+ completely.
+ * The new default `rc.lua` uses `request::activate` to set the focus. This
+ fixes many corner case such as unfocusable clients getting the focus.
+ * Calling `awful.spawn` with a set of properties is now more reliable.
+ * `awful.key.execute` is now much more reliable.
+
+## Behavior changes
+
+* Previously, when accessing a screen by RandR output name caused a Lua error
+ when no output with the given name exists. This was changed to now return
+ `nil` instead. This could break code that uses `pcall` to check if a screen
+ exists. This code now needs to be changed to check for a `nil` return instead.
+ In practice it is unlikely anyone will notice the difference.
+* In the previous release, unfocusable clients might also not be raised.
+ It was decided that this is a bug and the default behavior was changed.
+
# Awesome window manager framework version 4.2 changes
-
-
Awesome v4.2 is the second release of the 4.x API. It mostly fixes the bugs
reported over the last 3 months and adds a couple widgets. Almost 150 issues
have been resolved or decided to be obsolete.