diff --git a/documentation/asciidoc/accessories/ai-camera/details.adoc b/documentation/asciidoc/accessories/ai-camera/details.adoc index f7331d4d0..e640f289c 100644 --- a/documentation/asciidoc/accessories/ai-camera/details.adoc +++ b/documentation/asciidoc/accessories/ai-camera/details.adoc @@ -9,7 +9,7 @@ image::images/imx500-comparison.svg[Traditional versus IMX500 AI camera systems] The left side demonstrates the architecture of a traditional AI camera system. In such a system, the camera delivers images to the Raspberry Pi. The Raspberry Pi processes the images and then performs AI inference. Traditional systems may use external AI accelerators (as shown) or rely exclusively on the CPU. -The right side demonstrates the architecture of a system that uses IMX500. The camera module contains a small Image Signal Processor (ISP) which turns the raw camera image data into an **input tensor**. The camera module sends this tensor directly into the AI accelerator within the camera, which produces an **output tensor** that contains the inferencing results. The AI accelerator sends this tensor to the Raspberry Pi. There is no need for an external accelerator, nor for the Raspberry Pi to run neural network software on the CPU. +The right side demonstrates the architecture of a system that uses IMX500. The camera module contains a small Image Signal Processor (ISP) which turns the raw camera image data into an **input tensor**. The camera module sends this tensor directly into the AI accelerator within the camera, which produces **output tensors** that contain the inferencing results. The AI accelerator sends these tensors to the Raspberry Pi. There is no need for an external accelerator, nor for the Raspberry Pi to run neural network software on the CPU. To fully understand this system, familiarise yourself with the following concepts: @@ -17,7 +17,7 @@ Input Tensor:: The part of the sensor image passed to the AI engine for inferenc Region of Interest (ROI):: Specifies exactly which part of the sensor image is cropped out before being rescaled to the size demanded by the neural network. Can be queried and set by an application. The units used are always pixels in the full resolution sensor output. The default ROI setting uses the full image received from the sensor, cropping no data. -Output Tensor:: The results of inferencing performed by the neural network. The precise number and shape of the outputs depend on the neural network. Application code must understand how to handle the tensor. +Output Tensors:: The results of inferencing performed by the neural network. The precise number and shape of the outputs depend on the neural network. Application code must understand how to handle the tensors. === System architecture @@ -43,13 +43,13 @@ Once `libcamera` dequeues the image and inference data buffers from the kernel, | Description | `CnnOutputTensor` -| Floating point array storing the output tensor. +| Floating point array storing the output tensors. | `CnnInputTensor` | Floating point array storing the input tensor. | `CnnOutputTensorInfo` -| Network specific parameters describing the output tensors structure: +| Network specific parameters describing the output tensors' structure: [source,c] ---- @@ -67,7 +67,7 @@ struct CnnOutputTensorInfo { ---- | `CnnInputTensorInfo` -| Network specific parameters describing the input tensors structure: +| Network specific parameters describing the input tensor's structure: [source,c] ---- @@ -204,7 +204,7 @@ def draw_detections(request, detections, stream="main"): cv2.rectangle(m.array, (b.x, b.y), (b.x + b.width, b.y + b.height), (255, 0, 0, 0)) def parse_detections(request, stream='main'): - """Parse the output tensor into a number of detected objects, scaled to the ISP out.""" + """Parse the output tensor into a number of detected objects, scaled to the ISP output.""" outputs = imx500.get_outputs(request.get_metadata()) boxes, scores, classes = outputs[0][0], outputs[1][0], outputs[2][0] detections = [ Detection(box, category, score, metadata) @@ -245,7 +245,7 @@ There are a number of scaling/cropping/translation operations occurring from the | Returns the input tensor size based on the neural network model used. | `IMX500.get_outputs(metadata)` -| Returns the output tensors from the Picamera2 image metadata metadata. +| Returns the output tensors from the Picamera2 image metadata. | `IMX500.get_output_shapes(metadata)` | Returns the shape of the output tensors from the Picamera2 image metadata for the neural network model used. diff --git a/documentation/asciidoc/accessories/display/display_intro.adoc b/documentation/asciidoc/accessories/display/display_intro.adoc index 5f9e0dded..4e08b1858 100644 --- a/documentation/asciidoc/accessories/display/display_intro.adoc +++ b/documentation/asciidoc/accessories/display/display_intro.adoc @@ -75,22 +75,17 @@ WARNING: When using a micro USB cable to power the display, mount it inside a ch === Use an on-screen keyboard -In Raspberry Pi OS Bookworm and later, you can use the https://github.com/jjsullivan5196/wvkbd[`wvkbd`] on-screen keyboard as an input device. To install `wvkbd`, run the following command: +Raspberry Pi OS _Bookworm_ and later include the Squeekboard on-screen keyboard by default. When a touch display is attached, the on-screen keyboard should automatically show when it is possible to enter text and automatically hide when it is not possible to enter text. -[source,console] ----- -$ sudo apt install wvkbd ----- +For applications which do not support text entry detection, use the keyboard icon at the right end of the taskbar to manually show and hide the keyboard. -TIP: In Raspberry Pi OS releases prior to Bookworm, you can use `matchbox-keyboard` instead. - -=== Change screen orientation +You can also permanently show or hide the on-screen keyboard in the Display tab of Raspberry Pi Configuration or the `Display` section of `raspi-config`. -If you want to physically rotate the display, or mount it in a specific position, you can use software to adjust the orientation of the screen to better match your setup. +TIP: In Raspberry Pi OS releases prior to _Bookworm_, use `matchbox-keyboard` instead. If you use the wayfire desktop compositor, use `wvkbd` instead. -==== Rotate screen from the desktop +=== Change screen orientation -To set the screen orientation from the desktop environment, select **Screen Configuration** from the **Preferences** menu. Right-click on the DSI-1 display rectangle in the layout editor, select **Orientation**, then pick the best option to fit your needs. You can also ensure that the touch overlay is assigned to the correct display with the **Touchscreen** option. +If you want to physically rotate the display, or mount it in a specific position, select **Screen Configuration** from the **Preferences** menu. Right-click on the DSI-1 display rectangle in the layout editor, select **Orientation**, then pick the best option to fit your needs. You can also ensure that the touch overlay is assigned to the correct display with the **Touchscreen** option. image::images/display-rotation.png[Screenshot of orientation options in screen configuration, width="80%"] @@ -132,27 +127,6 @@ Then, disable automatic display detection by removing the following line from `c display_auto_detect=1 ---- -[NOTE] -==== -In Raspberry Pi OS _Bookworm_, a bug in https://github.com/WayfireWM/wayfire[Wayfire] currently prevents cursor movement rotation when using WayVNC. There is no workaround for this bug in Wayfire. Instead, you can use https://github.com/labwc/labwc[`labwc`] (currently in beta). - -First install `labwc`: - -[source,console] ----- -$ sudo apt install labwc ----- - -Then, use the Raspberry Pi Configuration CLI to switch to the `labwc` window compositor. Run the following command to open `raspi-config`: - -[source,console] ----- -$ sudo raspi-config ----- - -Go to **Advanced Options**. Select **Wayland**, then select **labwc**. Exit `raspi-config` and reboot with `sudo reboot`. Switching to `labwc` may reset some configuration, including keyboard layout and rotation settings. -==== - ==== Touch Display device tree option reference The `vc4-kms-dsi-7inch` overlay supports the following options: diff --git a/documentation/asciidoc/computers/configuration/display-resolution.adoc b/documentation/asciidoc/computers/configuration/display-resolution.adoc index 564df32cb..294f7ad44 100644 --- a/documentation/asciidoc/computers/configuration/display-resolution.adoc +++ b/documentation/asciidoc/computers/configuration/display-resolution.adoc @@ -44,20 +44,12 @@ $ kmsprint | grep Connector ==== Set a custom resolution -If you run the Wayland desktop compositor, you can set a custom display resolution by editing the `.config/wayfire.ini` file in your home directory. Edit the existing `[output:]` section, or add a new `[output:]` section for your xref:configuration.adoc#determine-display-device-name[display device] if one doesn't exist. To change your display resolution, add a `mode` line. For example, the following example shows a configuration for the device named `HDMI-A-1` with a resolution of 1080p at 60Hz: - -[source,ini] ----- -[output:HDMI-A-1] -mode = 1920x1080@60 ----- - -For information about supported modes and the `mode` syntax, see the https://github.com/WayfireWM/wayfire-wiki/blob/master/Configuration.md#output-configuration[Wayfire documentation]. - -Add the same configuration block to `/usr/share/greeter.ini` to configure the login screen resolution. +To set a custom resolution, use our Screen Configuration tool, `raindrop`. If your Raspberry Pi OS installation doesn't already include `raindrop` (for instance, if you're still using the previous Screen Configuration tool, `arandr`), you can download `raindrop` from `apt` or the Recommended Software GUI. ==== Set a custom rotation +To set a custom resolution, use our Screen Configuration tool, `raindrop`. If your Raspberry Pi OS installation doesn't already include `raindrop` (for instance, if you're still using the previous Screen Configuration tool, `arandr`), you can download `raindrop` from `apt` or the Recommended Software GUI. + If you run the Wayland desktop compositor, you can set a custom display rotation with `wlr-randr`. The following commands rotate the display by 0°, 90°, 180°, and 270°: [source,console] @@ -72,25 +64,7 @@ The `--output` option specifies the device to be rotated. NOTE: To run this command over SSH, add the following prefix: `WAYLAND_DISPLAY=wayland-1`, e.g. `WAYLAND_DISPLAY=wayland-1 wlr-randr --output HDMI-A-1 --transform 90`. -You can also use one of the following `--transform` options to mirror the display at the same time as rotating it: `flipped`, `flipped-90`, `flipped-180`, `flipped-270` - -Alternatively, you can rotate the display using by editing the `.config/wayfire.ini` file in your home directory. Edit the existing `[output:]` section, or add a new `[output:]` section for your xref:configuration.adoc#determine-display-device-name[display device] if one doesn't exist. To rotate your display, add a `transform` line. For example, the following example shows a configuration for the device named `HDMI-A-1` with a resolution of 1080p at 60Hz and a 270° transform: - -[source,ini] ----- -[output:HDMI-A-1] -mode = 1920x1080@60 -transform = 270 ----- - -Wayland supports the following `transform` options: - -* `normal` -* `90` -* `180` -* `270` - -Add the same configuration block to `/usr/share/greeter.ini` to configure the login screen rotation. +You can also use one of the following `--transform` options to mirror the display at the same time as rotating it: `flipped`, `flipped-90`, `flipped-180`, `flipped-270`. === Console resolution and rotation diff --git a/documentation/asciidoc/computers/configuration/raspi-config.adoc b/documentation/asciidoc/computers/configuration/raspi-config.adoc index 2fd95ad36..6933760b1 100644 --- a/documentation/asciidoc/computers/configuration/raspi-config.adoc +++ b/documentation/asciidoc/computers/configuration/raspi-config.adoc @@ -225,9 +225,9 @@ On the Raspberry Pi 4 and later, switch to the latest boot ROM software. Alterna ==== Wayland -Switch between the X11 and Wayland backends. Raspberry Pi 4 and later use Wayland by default; other models of Raspberry Pi use X11 by default. +Switch between the X11 and Wayland backends, and choose a window manager. Since Raspberry Pi OS _Bookworm_, all Raspberry Pi models run Wayland using labwc by default. -NOTE: To use Wayland on Raspberry Pi models prior to Raspberry Pi 4, you must also add `wayland=on` to `/boot/firmware/cmdline.txt`. +NOTE: To use Wayland on Raspberry Pi models prior to Raspberry Pi 4 running a version of Raspberry Pi OS earlier than _Bookworm_, add `wayland=on` to `/boot/firmware/cmdline.txt`. ==== Audio config @@ -770,17 +770,18 @@ $ sudo raspi-config nonint do_boot_rom ==== Wayland -Switch between the X11 and Wayland backends. Raspberry Pi 4 and later use Wayland by default; other models of Raspberry Pi use X11 by default. +Switch between the X11 and Wayland backends, and choose a window manager. Since Raspberry Pi OS _Bookworm_, all Raspberry Pi models run Wayland using the labwc window manager by default. + +NOTE: To use Wayland on Raspberry Pi models prior to Raspberry Pi 4 running a version of Raspberry Pi OS earlier than _Bookworm_, add `wayland=on` to `/boot/firmware/cmdline.txt`. [source,console] ---- $ sudo raspi-config nonint do_wayland ---- -* `W1`: use the X11 backend -* `W2`: use the Wayland backend - -NOTE: To use Wayland on Raspberry Pi models prior to Raspberry Pi 4, you must also add `wayland=on` to `/boot/firmware/cmdline.txt`. +* `W1`: use the Openbox window manager with X11 backend +* `W2`: use the wayfire window manager with Wayland backend +* `W3`: use the labwc window manager with Wayland backend ==== Audio config diff --git a/documentation/asciidoc/computers/configuration/screensaver.adoc b/documentation/asciidoc/computers/configuration/screensaver.adoc index 09db477cc..f12900f3f 100644 --- a/documentation/asciidoc/computers/configuration/screensaver.adoc +++ b/documentation/asciidoc/computers/configuration/screensaver.adoc @@ -27,16 +27,6 @@ $ sudo raspi-config Use the arrow keys to navigate and the *Enter* key to select. Select `Display Options` > `Screen Blanking`. Choose `yes` with the arrow keys to enable screen blanking, or `no` to disable screen blanking. -Alternatively, you can add or edit the following lines to `~/.config/wayfire.ini`: - -[source,ini] ----- -[idle] -dpms_timeout=600 ----- - -The `dpms_timeout` variable controls the number of seconds of inactivity required before Raspberry Pi OS blanks your screen. For example, a value of `600` blanks the screen after 600 seconds, or ten minutes. Set the value to `0` to never blank the screen. - === Console The `dpms_timeout` screen blanking configuration used by Raspberry Pi Configuration only affects desktop sessions. In *console mode*, when your Raspberry Pi is connected to a monitor and keyboard with only a terminal for input, use the `consoleblank` setting in the kernel command line. diff --git a/documentation/asciidoc/computers/raspberry-pi/revision-codes.adoc b/documentation/asciidoc/computers/raspberry-pi/revision-codes.adoc index b0b44b80e..fcea56251 100644 --- a/documentation/asciidoc/computers/raspberry-pi/revision-codes.adoc +++ b/documentation/asciidoc/computers/raspberry-pi/revision-codes.adoc @@ -738,7 +738,6 @@ Raspberry Pi models have the following device tree values: | Raspberry Pi 5 | `raspberrypi` | `5-model-b` | `brcm` | `bcm2712` | Raspberry Pi 400 | `raspberrypi` | `400` | `brcm` | `bcm2711` | Raspberry Pi Compute Module 4 | `raspberrypi` | `4-compute-module` | `brcm` | `bcm2711` -| Raspberry Pi 4 Model A | `raspberrypi` | `4-model-a` | `brcm` | `bcm2711` | Raspberry Pi 4 Model B | `raspberrypi` | `4-model-b` | `brcm` | `bcm2711` | Raspberry Pi Compute Module 3 | `raspberrypi` | `3-compute-module` | `brcm` | `bcm2837` | Raspberry Pi 3 Model A+ | `raspberrypi` | `3-model-a-plus` | `brcm` | `bcm2837` diff --git a/documentation/asciidoc/services/connect/images/browser-sign-in.png b/documentation/asciidoc/services/connect/images/browser-sign-in.png new file mode 100644 index 000000000..87c50da7e Binary files /dev/null and b/documentation/asciidoc/services/connect/images/browser-sign-in.png differ diff --git a/documentation/asciidoc/services/connect/images/create-device.png b/documentation/asciidoc/services/connect/images/create-device.png deleted file mode 100755 index f6d9a2a71..000000000 Binary files a/documentation/asciidoc/services/connect/images/create-device.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/device-details.png b/documentation/asciidoc/services/connect/images/device-details.png deleted file mode 100644 index 809a3539f..000000000 Binary files a/documentation/asciidoc/services/connect/images/device-details.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/device.png b/documentation/asciidoc/services/connect/images/device.png new file mode 100644 index 000000000..0e4e6bbd2 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/device.png differ diff --git a/documentation/asciidoc/services/connect/images/devices.png b/documentation/asciidoc/services/connect/images/devices.png new file mode 100644 index 000000000..73b5859ac Binary files /dev/null and b/documentation/asciidoc/services/connect/images/devices.png differ diff --git a/documentation/asciidoc/services/connect/images/disallow-remote-shell.png b/documentation/asciidoc/services/connect/images/disallow-remote-shell.png new file mode 100644 index 000000000..348d0ac0f Binary files /dev/null and b/documentation/asciidoc/services/connect/images/disallow-remote-shell.png differ diff --git a/documentation/asciidoc/services/connect/images/disallow-screen-sharing.png b/documentation/asciidoc/services/connect/images/disallow-screen-sharing.png new file mode 100644 index 000000000..52d4d17aa Binary files /dev/null and b/documentation/asciidoc/services/connect/images/disallow-screen-sharing.png differ diff --git a/documentation/asciidoc/services/connect/images/hero.png b/documentation/asciidoc/services/connect/images/hero.png index f26372ed5..5f13e18a2 100644 Binary files a/documentation/asciidoc/services/connect/images/hero.png and b/documentation/asciidoc/services/connect/images/hero.png differ diff --git a/documentation/asciidoc/services/connect/images/just_installed.png b/documentation/asciidoc/services/connect/images/just_installed.png deleted file mode 100644 index b45d997b3..000000000 Binary files a/documentation/asciidoc/services/connect/images/just_installed.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/list-of-devices.png b/documentation/asciidoc/services/connect/images/list-of-devices.png deleted file mode 100644 index 17663d240..000000000 Binary files a/documentation/asciidoc/services/connect/images/list-of-devices.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/login-with-id-2.png b/documentation/asciidoc/services/connect/images/login-with-id-2.png deleted file mode 100755 index dd0a6deca..000000000 Binary files a/documentation/asciidoc/services/connect/images/login-with-id-2.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/login-with-id.png b/documentation/asciidoc/services/connect/images/login-with-id.png deleted file mode 100755 index 0ed21408c..000000000 Binary files a/documentation/asciidoc/services/connect/images/login-with-id.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/new-device.png b/documentation/asciidoc/services/connect/images/new-device.png new file mode 100644 index 000000000..8753ada4f Binary files /dev/null and b/documentation/asciidoc/services/connect/images/new-device.png differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-active.png b/documentation/asciidoc/services/connect/images/remote-shell-active.png deleted file mode 100644 index d51fb7510..000000000 Binary files a/documentation/asciidoc/services/connect/images/remote-shell-active.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-connected.png b/documentation/asciidoc/services/connect/images/remote-shell-connected.png deleted file mode 100755 index 4bc7c01d4..000000000 Binary files a/documentation/asciidoc/services/connect/images/remote-shell-connected.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-connecting.png b/documentation/asciidoc/services/connect/images/remote-shell-connecting.png deleted file mode 100644 index b23ceb611..000000000 Binary files a/documentation/asciidoc/services/connect/images/remote-shell-connecting.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-disabled-desktop.png b/documentation/asciidoc/services/connect/images/remote-shell-disabled-desktop.png deleted file mode 100644 index 90055b800..000000000 Binary files a/documentation/asciidoc/services/connect/images/remote-shell-disabled-desktop.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-disabled.png b/documentation/asciidoc/services/connect/images/remote-shell-disabled.png index d68049c9c..991c1e295 100644 Binary files a/documentation/asciidoc/services/connect/images/remote-shell-disabled.png and b/documentation/asciidoc/services/connect/images/remote-shell-disabled.png differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-end.png b/documentation/asciidoc/services/connect/images/remote-shell-end.png deleted file mode 100644 index 834f0b828..000000000 Binary files a/documentation/asciidoc/services/connect/images/remote-shell-end.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-ended.png b/documentation/asciidoc/services/connect/images/remote-shell-ended.png new file mode 100644 index 000000000..0f4ce1f43 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/remote-shell-ended.png differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-in-progress.png b/documentation/asciidoc/services/connect/images/remote-shell-in-progress.png new file mode 100644 index 000000000..b6eaaeceb Binary files /dev/null and b/documentation/asciidoc/services/connect/images/remote-shell-in-progress.png differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-notification.png b/documentation/asciidoc/services/connect/images/remote-shell-notification.png new file mode 100644 index 000000000..2bb47d88f Binary files /dev/null and b/documentation/asciidoc/services/connect/images/remote-shell-notification.png differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell-start.png b/documentation/asciidoc/services/connect/images/remote-shell-start.png deleted file mode 100644 index 56212bc7a..000000000 Binary files a/documentation/asciidoc/services/connect/images/remote-shell-start.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/remote-shell.png b/documentation/asciidoc/services/connect/images/remote-shell.png new file mode 100644 index 000000000..398165e17 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/remote-shell.png differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-active.png b/documentation/asciidoc/services/connect/images/screen-sharing-active.png deleted file mode 100644 index 4b26a5626..000000000 Binary files a/documentation/asciidoc/services/connect/images/screen-sharing-active.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-connected.png b/documentation/asciidoc/services/connect/images/screen-sharing-connected.png deleted file mode 100755 index 124f81ded..000000000 Binary files a/documentation/asciidoc/services/connect/images/screen-sharing-connected.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-connecting.png b/documentation/asciidoc/services/connect/images/screen-sharing-connecting.png deleted file mode 100644 index 0462b3b10..000000000 Binary files a/documentation/asciidoc/services/connect/images/screen-sharing-connecting.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-disabled-desktop.png b/documentation/asciidoc/services/connect/images/screen-sharing-disabled-desktop.png deleted file mode 100644 index 7403cf928..000000000 Binary files a/documentation/asciidoc/services/connect/images/screen-sharing-disabled-desktop.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-disabled.png b/documentation/asciidoc/services/connect/images/screen-sharing-disabled.png index b52d7fd5b..f5a3d7d03 100644 Binary files a/documentation/asciidoc/services/connect/images/screen-sharing-disabled.png and b/documentation/asciidoc/services/connect/images/screen-sharing-disabled.png differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-end.png b/documentation/asciidoc/services/connect/images/screen-sharing-end.png deleted file mode 100644 index d39e994a0..000000000 Binary files a/documentation/asciidoc/services/connect/images/screen-sharing-end.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-ended.png b/documentation/asciidoc/services/connect/images/screen-sharing-ended.png new file mode 100644 index 000000000..58c4190a5 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/screen-sharing-ended.png differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-in-progress.png b/documentation/asciidoc/services/connect/images/screen-sharing-in-progress.png new file mode 100644 index 000000000..2c3398f9a Binary files /dev/null and b/documentation/asciidoc/services/connect/images/screen-sharing-in-progress.png differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-notification.png b/documentation/asciidoc/services/connect/images/screen-sharing-notification.png new file mode 100644 index 000000000..439d43748 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/screen-sharing-notification.png differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing-start.png b/documentation/asciidoc/services/connect/images/screen-sharing-start.png deleted file mode 100644 index febe603eb..000000000 Binary files a/documentation/asciidoc/services/connect/images/screen-sharing-start.png and /dev/null differ diff --git a/documentation/asciidoc/services/connect/images/screen-sharing.png b/documentation/asciidoc/services/connect/images/screen-sharing.png new file mode 100644 index 000000000..94fc1e871 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/screen-sharing.png differ diff --git a/documentation/asciidoc/services/connect/images/sign-in-email.png b/documentation/asciidoc/services/connect/images/sign-in-email.png index f04a55d00..0ed30d7fc 100644 Binary files a/documentation/asciidoc/services/connect/images/sign-in-email.png and b/documentation/asciidoc/services/connect/images/sign-in-email.png differ diff --git a/documentation/asciidoc/services/connect/images/sign-in.png b/documentation/asciidoc/services/connect/images/sign-in.png index 897a08b27..7b66320e9 100644 Binary files a/documentation/asciidoc/services/connect/images/sign-in.png and b/documentation/asciidoc/services/connect/images/sign-in.png differ diff --git a/documentation/asciidoc/services/connect/images/turn-on-connect.png b/documentation/asciidoc/services/connect/images/turn-on-connect.png new file mode 100644 index 000000000..96c749c79 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/turn-on-connect.png differ diff --git a/documentation/asciidoc/services/connect/images/waiting-for-remote-shell.png b/documentation/asciidoc/services/connect/images/waiting-for-remote-shell.png new file mode 100644 index 000000000..0197088f1 Binary files /dev/null and b/documentation/asciidoc/services/connect/images/waiting-for-remote-shell.png differ diff --git a/documentation/asciidoc/services/connect/images/waiting-for-screen-sharing.png b/documentation/asciidoc/services/connect/images/waiting-for-screen-sharing.png new file mode 100644 index 000000000..87ba5fcec Binary files /dev/null and b/documentation/asciidoc/services/connect/images/waiting-for-screen-sharing.png differ diff --git a/documentation/asciidoc/services/connect/install.adoc b/documentation/asciidoc/services/connect/install.adoc index d09045297..7c8224c22 100644 --- a/documentation/asciidoc/services/connect/install.adoc +++ b/documentation/asciidoc/services/connect/install.adoc @@ -1,7 +1,7 @@ [[install-connect]] == Install -To begin installation, open a Terminal window. Run the following command to update your system and packages: +If Connect isn't already installed in your version of Raspberry Pi OS, open a Terminal window. Run the following command to update your system and packages: [source,console] ---- @@ -16,14 +16,18 @@ Run the following command on your Raspberry Pi to install Connect: $ sudo apt install rpi-connect ---- -After installation, reboot your Raspberry Pi or xref:connect.adoc#manually-start-connect[manually start the Connect service] to use Connect: +You can also install Connect from the Recommended Software application. + +After installation, use the `rpi-connect` command line interface to start Connect for your current user: [source,console] ---- -$ sudo reboot +$ rpi-connect on ---- -Connect will automatically start the next time you log in to your Raspberry Pi. +Alternatively, click the Connect icon in the menu bar to open a dropdown menu and select *Turn On Raspberry Pi Connect*: + +image::images/turn-on-connect.png[width="80%"] === Connect Lite @@ -36,19 +40,29 @@ Run the following command on your Raspberry Pi to install Connect Lite: $ sudo apt install rpi-connect-lite ---- -Reboot your Raspberry Pi or xref:connect.adoc#manually-start-connect[manually start the Connect service] to use Connect. +After installation, use the `rpi-connect` command line interface to start Connect for your current user: + +[source,console] +---- +$ rpi-connect on +---- -Consider xref:connect.adoc#enable-remote-shell-at-all-times[enabling user lingering] to make your device accessible even when your user account isn't logged in. +xref:connect.adoc#enable-remote-shell-at-all-times[Enable user-lingering] to make your device accessible even when your user account isn't logged in. TIP: Lite commands use the same `rpi-connect` name as the full version of Connect. `rpi-connect-lite` is just a package name. -=== Manually start Connect +=== Manually start and stop Connect + +To start Connect from the command line, run the following command: -NOTE: By default, Connect automatically starts at login. You don't need to manually start Connect after it starts for the first time unless you remove it from your login items. +[source,console] +---- +$ rpi-connect on +---- -To start the service manually from the command line, run the following command: +To stop Connect, run the following command: [source,console] ---- -$ systemctl --user start rpi-connect +$ rpi-connect off ---- diff --git a/documentation/asciidoc/services/connect/introduction.adoc b/documentation/asciidoc/services/connect/introduction.adoc index 0c75e4e12..56db23adc 100644 --- a/documentation/asciidoc/services/connect/introduction.adoc +++ b/documentation/asciidoc/services/connect/introduction.adoc @@ -4,7 +4,7 @@ Raspberry Pi Connect provides secure access to your Raspberry Pi from anywhere i image::images/hero.png[width="100%"] -To use Connect, xref:connect.adoc#install-connect[install the Connect software] on your Raspberry Pi. Then visit https://connect.raspberrypi.com[connect.raspberrypi.com] to access the desktop or a shell running on your Raspberry Pi in a browser window. +To use Connect, xref:connect.adoc#install-connect[install the Connect software] and xref:connect.adoc#link-connect[link your device with an account] on your Raspberry Pi. Then visit https://connect.raspberrypi.com[connect.raspberrypi.com] to access the desktop or a shell running on your Raspberry Pi in a browser window. Connect uses a secure, encrypted connection. By default, Connect communicates directly between your Raspberry Pi and your browser. However, when Connect can't establish a direct connection between your Raspberry Pi and your browser, we use a relay server. In such cases, Raspberry Pi only retains the metadata required to operate Connect. diff --git a/documentation/asciidoc/services/connect/troubleshooting.adoc b/documentation/asciidoc/services/connect/troubleshooting.adoc index 2a3398bef..78334e9e4 100644 --- a/documentation/asciidoc/services/connect/troubleshooting.adoc +++ b/documentation/asciidoc/services/connect/troubleshooting.adoc @@ -10,6 +10,63 @@ * Browsers intercept certain keys and key combinations. As a result, you can't type these keys into your Connect window. Screen sharing includes a toolbar to simulate some of the most popular intercepted keys. +* To upgrade from version 1 to version 2, you must first upgrade the package you currently have installed before switching between `rpi-connect` and `rpi-connect-lite`. This ensures that Connect's services properly migrate to the version 2 format. If you currently have `rpi-connect` installed, run the following command: ++ +[source,console] +---- +$ sudo apt install --only-upgrade rpi-connect +---- ++ +Alternatively, if you currently have `rpi-connect-lite` installed, run the following command: ++ +[source,console] +---- +$ sudo apt install --only-upgrade rpi-connect-lite +---- ++ +You should see output similar to the following during the upgrade, indicating that Connect's services have migrated to the version 2 format: ++ +[source,console] +---- +Replacing globally-enabled rpi-connect services with user-enabled ones... +---- + +=== Common issues + +==== Screen sharing not available + +If Connect states that screen sharing is unavailable, it cannot connect to the dedicated Connect WayVNC service. + +To find out more about the cause of the issue, run the following commands to check the status of the Connect WayVNC service: + +[source,console] +---- +$ systemctl --user status rpi-connect-wayvnc.service +$ journalctl --user --follow --unit rpi-connect-wayvnc.service +---- + +If the service fails to start or doesn't exist, ensure that your environment meets the following criteria: + +. You use `rpi-connect` version 1.1.0 or later. +. You do not use `rpi-connect-lite`, which lacks screen sharing support. +. You use a Wayland compositor such as wayfire or labwc, not X. You can control this setting via ``raspi-config``'s Advanced Options. +. You use a desktop environment supported by WayVNC, e.g. Raspberry Pi Desktop. For instance, using KDE switches your Wayland compositor to kwin, which is unsupported. +. You have an active graphical desktop session running as the same user as the one you signed into. For most, this means enabling "Desktop Autologin" via ``raspi-config``'s System Options. + +==== Can't connect after restarting or ending SSH session + +Connect runs as a user-level service and is therefore only available if there is an active session for the user signed into the service. If you want remote shell access without also running another login session, xref:connect.adoc#enable-remote-shell-at-all-times[enable user-lingering] for your user, which will keep Connect running at all times. + +For screen sharing, Connect can only share an existing graphical desktop session: it does not create entirely new sessions. There must already be a desktop session in progress. To start such a session automatically on boot, enable Desktop Autologin via ``raspi-config``'s System Options. + +==== Networking and firewall issues + +Connect avoids changing your network or firewall in order to establish a connection. However, if you have a restrictive network and experience trouble connecting, check the following: + +. Can you access the Connect API, which Connect uses for authentication and connection negotiation between your Raspberry Pi and your browser? To check, load https://api.connect.raspberrypi.com/up?[https://api.connect.raspberrypi.com/up?] on your Raspberry Pi. +. Can you access the Connect STUN server, which Connect uses to obtain a peer-to-peer connection through local or public networks? To check, ping `stun.raspberrypi.com` on UDP port 3478. +. Can you access our TURN servers, which Connect uses to relay sessions when a peer-to-peer connection fails? To check, ping `turn1.raspberrypi.com`, `turn2.raspberrypi.com` and `turn3.raspberrypi.com` on TCP ports 3478 or 443, or UDP ports 3478, 443 and 49152 -> 65535. + === View Connect status To view the current status of the Connect service, run the following command: @@ -19,19 +76,29 @@ To view the current status of the Connect service, run the following command: $ rpi-connect status ---- +You should see output similar to the following: + +---- +Signed in: yes +Screen sharing: allowed (0 sessions active) +Remote shell: allowed (0 sessions active) +---- + The output of this command indicates whether or not you are currently signed in to Connect, as well as the remote services enabled on your Raspberry Pi. +If you see output including "Raspberry Pi Connect is not running, run rpi-connect on", run `rpi-connect on` to start Connect. + === Enable enhanced logging You can enable debug logging for both `rpi-connect` and its dedicated WayVNC server for a detailed account of local operations on your Raspberry Pi. ==== Enable enhanced logging in `rpi-connect` -Open the `rpi-connect` configuration file for editing with the following command: +Override the `rpi-connect` service definition with the following command: [source,console] ---- -$ systemctl --user edit rpi-connect +$ systemctl --user edit rpi-connect.service ---- Enter the following lines of configuration between the comments: @@ -45,23 +112,23 @@ ExecStart=/usr/bin/rpi-connectd -socket %t/rpi-connect-wayvnc.sock -v NOTE: You need **both** lines that begin with `ExecStart=`. -Finally, restart the service with the following command: +Finally, restart Connect with the following command: [source,console] ---- -$ systemctl --user restart rpi-connect +$ rpi-connect restart ---- ==== Enable enhanced logging in the dedicated `wayvnc` server -Open the configuration file for the dedicated WayVNC server associated with Connect: +Override the `rpi-connect-wayvnc` service definition with the following command: [source,console] ---- $ systemctl --user edit rpi-connect-wayvnc ---- -Enter the following lines of configuration between the comments: +Enter the following lines of configuration between the comments (including the `-Ldebug` flag): [source,bash] ---- @@ -72,11 +139,11 @@ ExecStart=/usr/bin/rpi-connect-env /usr/bin/wayvnc --config /etc/rpi-connect/way NOTE: You need **both** lines that begin with `ExecStart=`. -Finally, restart the service with the following command: +Finally, restart Connect with the following command: [source,console] ---- -$ systemctl --user restart rpi-connect-wayvnc +$ rpi-connect restart ---- === View Connect logs @@ -85,5 +152,5 @@ To view logs for the Connect service and its dedicated WayVNC server, run the fo [source,console] ---- -$ journalctl --user --follow --unit rpi-connect --unit rpi-connect-wayvnc +$ journalctl --user --follow --unit rpi-connect.service --unit rpi-connect-wayvnc.service ---- diff --git a/documentation/asciidoc/services/connect/use.adoc b/documentation/asciidoc/services/connect/use.adoc index 207afe6f3..7b80d406a 100644 --- a/documentation/asciidoc/services/connect/use.adoc +++ b/documentation/asciidoc/services/connect/use.adoc @@ -1,27 +1,19 @@ +[[link-connect]] == Link a Raspberry Pi device with a Connect account -Now that you've installed Connect on your Raspberry Pi device, you must associate your device with your Connect account before you can use Connect. - -If you do not have a Connect account: - -. xref:id.adoc#create-a-raspberry-pi-id[Create a Raspberry Pi ID]. -. Visit https://connect.raspberrypi.com[connect.raspberrypi.com] and create a Connect account using your Raspberry Pi ID. - -To link your device with your Connect account, use the Connect client software to generate a verification URL. Visit the URL and sign into your Connect account with your Raspberry Pi ID to add your device to your account. - -To generate the verification URL, use the Connect icon on the Raspberry Pi Desktop or the `rpi-connect` CLI. Follow the instructions below: +Now that you've installed and started Connect on your Raspberry Pi device, you must associate your device with your Connect account. === via the Raspberry Pi Desktop -Once the `rpi-connect` service starts running, the Connect icon appears in the system tray. +If you're using the Connect plugin for the menu bar, clicking "Turn On Raspberry Pi Connect" for the first time will open your browser, prompting you to sign in with your Raspberry Pi ID: -image::images/just_installed.png[width="80%"] +image::images/browser-sign-in.png[width="80%"] -Click on the Connect icon and choose "Sign in" from the drop-down menu. +Alternatively, you can choose "Sign In..." from the dropdown menu: image::images/sign-in.png[width="80%"] -This opens a verification URL you can use to link your device to your Connect account. +If you don't already have a Raspberry Pi ID, click *create one for free* to xref:id.adoc#create-a-raspberry-pi-id[create one]. === via the command line @@ -42,23 +34,17 @@ Visit the verification URL on any device and sign in with your Raspberry Pi ID t === Finish linking your Raspberry Pi -Visit the verification URL generated in the previous step. - -Sign in to Connect using your xref:id.adoc[Raspberry Pi ID]. - -image::images/login-with-id.png[width="80%"] - After authenticating, assign a name to your device. Choose a name that uniquely identifies the device. Click the **Create device and sign in** button to continue. -image::images/create-device.png[width="80%"] +image::images/new-device.png[width="80%"] -You can now remotely connect to your device. The Connect system tray icon will turn blue to indicate that your device is now signed in to the Connect service. You should receive an email notification indicating that a new device is linked to your Connect account. +You can now remotely connect to your device. The Connect icon in your menu bar will turn blue to indicate that your device is now signed in to the Connect service. You should receive an email notification indicating that a new device is linked to your Connect account. image::images/sign-in-email.png[width="70%"] WARNING: If you receive an email that says a device that you do not recognise has signed into Connect, change your Raspberry Pi ID password immediately. xref:connect.adoc#manage-devices[Remove the device from Connect] to permanently disassociate it from your account. Consider xref:id.adoc#enable-two-factor-authentication[enabling two-factor authentication] to keep your account secure. -Click the Connect system tray icon to open the Connect menu. This menu shows your current sign in status, an option to sign out, and options to enable or disable remote access methods. +Click the Connect icon in your menu bar to open the Connect menu. This menu allows you to turn Connect on and off, sign in and out, and allow or disallow remote access methods. TIP: Connect signs communication with your device serial number. Moving your SD card between devices will sign you out of Connect. @@ -70,45 +56,45 @@ Now that your device appears on your Connect dashboard, you can access your devi Connect includes the ability to share your device's screen in a browser. Use the following instructions to share your device's screen. -NOTE: Screen sharing requires the **Wayland** window server. By default, Raspberry Pi OS only uses Wayland for **64-bit** distributions of Raspberry Pi OS **Bookworm** on Raspberry Pi 5, 4, or 400. Screen sharing is **not** compatible with Raspberry Pi OS Lite or systems that use the X window server. +NOTE: Screen sharing requires the **Wayland** window server. Raspberry Pi OS _Bookworm_ and later use Wayland by default. Screen sharing is **not** compatible with Raspberry Pi OS Lite or systems that use the X window server. Visit https://connect.raspberrypi.com[connect.raspberrypi.com] on any computer. Connect redirects you to the Raspberry Pi ID service to sign in. After signing in, Connect displays a list of linked devices. Devices available for screen sharing show a grey **Screen sharing** badge below the name of the device. -image::images/list-of-devices.png[width="80%"] +image::images/devices.png[width="80%"] Click the **Connect via** button to the right of the device you would like to access. Select the **Screen sharing** option from the menu. This opens a browser window that displays your device's desktop. -image::images/screen-sharing-connecting.png[width="80%"] +image::images/waiting-for-screen-sharing.png[width="80%"] You can now use your device as you would locally. For more information about the connection, hover your mouse over the padlock icon immediately to the right of the **Disconnect** button. -image::images/screen-sharing-start.png[width="80%"] +image::images/screen-sharing.png[width="80%"] TIP: Use the **Copy from remote** and **Paste to remote** buttons above your desktop to transfer text between your local and remote clipboards. Once connected, a green dot appears next to the **Screen sharing** badge in the Connect dashboard. This indicates an active screen sharing session. Hover to see the current number of screen sharing sessions. -image::images/screen-sharing-active.png[width="80%"] +image::images/screen-sharing-in-progress.png[width="80%"] -The Connect icon in the system tray turns purple and displays a closed circle when a screen sharing session is in progress. +The Connect icon in the system tray turns purple and displays a closed circle when a screen sharing session is in progress. A desktop notification will appear whenever a screen sharing session starts. -image::images/screen-sharing-connected.png[width="80%"] +image::images/screen-sharing-notification.png[width="80%"] ==== Stop screen sharing To close a screen sharing session, click the **Disconnect** button above your desktop. -image::images/screen-sharing-end.png[width="80%"] +image::images/screen-sharing-ended.png[width="80%"] -==== Disable screen sharing +==== Disallow screen sharing -To turn off screen sharing, click the Connect system tray icon and unselect **Allow screen sharing**. Your device remains signed into Connect, but you won't be able to create a screen sharing session from the Connect dashboard. +To turn off screen sharing, click the Connect icon in the menu bar and unselect **Allow Screen Sharing**. Your device remains signed into Connect, but you won't be able to create a screen sharing session from the Connect dashboard. -image::images/screen-sharing-disabled-desktop.png[width="80%"] +image::images/disallow-screen-sharing.png[width="80%"] -Alternatively, you can disable screen sharing with the following command: +Alternatively, you can disallow screen sharing with the following command: [source,console] ---- @@ -121,7 +107,7 @@ image::images/screen-sharing-disabled.png[width="80%"] To re-enable screen sharing, do one of the following: -* click the Connect system tray icon and select **Allow screen sharing** +* click the Connect icon in the menu bar and select **Allow Screen Sharing** * run the following command: + [source,console] @@ -131,33 +117,33 @@ $ rpi-connect vnc on === Remote shell -Connect includes the ability to access a shell running on your device from a browser. Use the following instructions to access the remote shell. +Connect includes the ability to start a shell running on your device from a browser. Use the following instructions to access the remote shell. Visit https://connect.raspberrypi.com[connect.raspberrypi.com] on any computer. Connect redirects you to the Raspberry Pi ID service to sign in. After signing in, Connect displays a list of linked devices. Devices available for remote shell access show a grey **Remote shell** badge below the name of the device. -image::images/list-of-devices.png[width="80%"] +image::images/devices.png[width="80%"] Click the **Connect via** button to the right of the device you would like to access. Select the **Remote shell** option from the menu. This opens a shell session on your device. -image::images/remote-shell-connecting.png[width="80%"] +image::images/waiting-for-remote-shell.png[width="80%"] You can now use your device as you would locally. -image::images/remote-shell-start.png[width="80%"] +image::images/remote-shell.png[width="80%"] TIP: On some operating systems, the browser intercepts key combinations like **Ctrl+Shift+C** and **Ctrl+C**. Instead, you can use the right click menu or **Ctrl+Insert** to copy and **Shift+Insert** to paste. Once connected, a green dot appears next to the **Remote shell** badge in the Connect dashboard. This indicates an active remote shell session. Hover to see the current number of remote shell sessions. -image::images/remote-shell-active.png[width="80%"] +image::images/remote-shell-in-progress.png[width="80%"] TIP: Every remote shell connection creates a brand new connection, just like SSH. To persist background commands and configuration across multiple sessions, use `screen` or `tmux`. -The Connect icon in the system tray turns purple and displays a closed circle when a remote shell session is in progress. +The Connect icon in the menu bar turns purple and displays a closed circle when a remote shell session is in progress. A desktop notification will appear whenever a remote shell session starts. -image::images/remote-shell-connected.png[width="80%"] +image::images/remote-shell-notification.png[width="80%"] TIP: The `CONNECT_TTY` environment variable indicates that a session uses a remote shell provided by Connect. @@ -165,15 +151,15 @@ TIP: The `CONNECT_TTY` environment variable indicates that a session uses a remo To close a remote shell session, run the `exit` command or close the window. -image::images/remote-shell-end.png[width="80%"] +image::images/remote-shell-ended.png[width="80%"] -==== Disable remote shell access +==== Disallow remote shell access -To turn off remote shell access, click the Connect system tray icon and unselect **Allow remote shell**. Your device remains signed into Connect, but you won't be able to create a remote shell session from the Connect dashboard. +To turn off remote shell access, click the Connect icon in the menu bar and unselect **Allow Remote Shell Access**. Your device remains signed into Connect, but you won't be able to create a remote shell session from the Connect dashboard. -image::images/remote-shell-disabled-desktop.png[width="80%"] +image::images/disallow-remote-shell.png[width="80%"] -Alternatively, you can disable remote shell access with the following command: +Alternatively, you can disallow remote shell access with the following command: [source,console] ---- @@ -186,7 +172,7 @@ image::images/remote-shell-disabled.png[width="80%"] To re-enable remote shell access, do one of the following: -* click the Connect system tray icon and select **Allow remote shell** +* click the Connect system tray icon and select **Allow Remote Shell Access** * run the following command: + [source,console] @@ -209,13 +195,13 @@ TIP: We recommend enabling user-lingering on all headless Raspberry Pi OS Lite s The Connect dashboard lists all of the devices linked with your Connect account and shows you the various ways you can access them. -image::images/list-of-devices.png[width="80%"] +image::images/devices.png[width="80%"] Click on a device name to open the device details page. This screen provides low-level information about your device. You can also edit the device name or remove the device from Connect. -image::images/device-details.png[width="80%"] +image::images/device.png[width="80%"] -Deleting a device from Connect automatically signs you out of Connect on the device. The Connect system tray icon turns grey and the menu only provides a **Sign in** option. +Deleting a device from Connect automatically signs you out of Connect on the device. The Connect icon in the menu bar turns grey and the menu only provides a **Sign In...** option. == Update @@ -227,12 +213,7 @@ $ sudo apt update $ sudo apt install --only-upgrade rpi-connect ---- -Reboot your device to put your update into effect: - -[source, console] ----- -$ sudo reboot ----- +TIP: If you installed Connect Lite, replace `rpi-connect` with `rpi-connect-lite` in the above command. == Disconnect a device from Connect @@ -243,11 +224,13 @@ Run the following command on your device to sign out of your Raspberry Pi ID, wh $ rpi-connect signout ---- +Alternatively, click the Connect icon in the menu bar and click "Sign Out". + TIP: To fully remove a device from your Connect account, xref:connect.adoc#manage-devices[remove it from the Connect dashboard]. == Uninstall -Run the following command to remove Connect software from a device: +Run the following command to stop and remove Connect from a device: [source,console] ---- diff --git a/documentation/images/Connect-SMALL.png b/documentation/images/Connect-SMALL.png deleted file mode 100644 index e22abf2af..000000000 Binary files a/documentation/images/Connect-SMALL.png and /dev/null differ diff --git a/documentation/images/full-sized/Connect.png b/documentation/images/full-sized/Connect.png deleted file mode 100755 index 98fc955d5..000000000 Binary files a/documentation/images/full-sized/Connect.png and /dev/null differ