From 60773d7a4056a6f9882883b9bdadcde2b44f7917 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Brauer?= Date: Mon, 6 Jan 2025 01:27:08 +0100 Subject: [PATCH] chore: configure and build Dev Container for flutter development (#1144) --- .devcontainer/Dockerfile | 56 +++++++++++++++++++++++++++++++++ .devcontainer/devcontainer.json | 31 ++++++++++++++++++ README.md | 43 +++++++++++++++++++++++++ 3 files changed, 130 insertions(+) create mode 100644 .devcontainer/Dockerfile create mode 100644 .devcontainer/devcontainer.json diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile new file mode 100644 index 000000000..fab122960 --- /dev/null +++ b/.devcontainer/Dockerfile @@ -0,0 +1,56 @@ +ARG BASE_TAG=bookworm +FROM mcr.microsoft.com/vscode/devcontainers/base:dev-${BASE_TAG} + +# Install prerequisites for Flutter and Android development +RUN apt-get update -qq \ + && apt-get -yqq upgrade \ + && apt-get install -yqq \ + clang \ + cmake \ + lib32z1 \ + libbz2-1.0:amd64 \ + libc6:amd64 \ + libglu1-mesa \ + libgtk-3-dev \ + libstdc++6:amd64 \ + ninja-build \ + openjdk-17-jdk-headless \ + pkg-config \ + usbutils + +# Install latest stable Flutter SDK +ARG FLUTTER_CHANNEL=stable + +ENV PATH="$PATH:/opt/flutter/bin" +RUN export FLUTTER_RELEASES_URL=https://storage.googleapis.com/flutter_infra_release/releases \ + && curl -sS "${FLUTTER_RELEASES_URL}/releases_linux.json" \ + | jq -r ". as \$r | \$r.releases[] | select(.hash == \$r.current_release.stable) | (\"${FLUTTER_RELEASES_URL}/\" + .archive)" \ + | xargs -I {} curl -sS {} \ + | tar -xJC /opt + + +USER vscode + +# Install Android SDK +ARG ANDROID_CMDLINE_TOOLS_VERSION=12266719 +ARG ANDROID_PLATFORM_VERSION=35 +ARG ANDROID_BUILD_TOOLS_VERSION=35.0.0 + +ENV PATH="$PATH:/home/vscode/Android/Sdk/cmdline-tools/latest/bin:/home/vscode/Android/Sdk/platform-tools" +RUN curl -sS "https://dl.google.com/android/repository/commandlinetools-linux-${ANDROID_CMDLINE_TOOLS_VERSION}_latest.zip" \ + -o /tmp/cmdline-tools.zip \ + && mkdir -p ~/Android/Sdk/cmdline-tools \ + && unzip -q /tmp/cmdline-tools.zip -d ~/Android/Sdk/cmdline-tools \ + && mv ~/Android/Sdk/cmdline-tools/cmdline-tools ~/Android/Sdk/cmdline-tools/latest \ + && rm /tmp/cmdline-tools.zip + +# Install required Android SDK components +RUN yes | sdkmanager --licenses \ + && sdkmanager \ + "platforms;android-${ANDROID_PLATFORM_VERSION}" \ + "build-tools;${ANDROID_BUILD_TOOLS_VERSION}" \ + "platform-tools" + +RUN echo 'alias ll="ls -alF"' >> ~/.bashrc \ + && flutter config --no-analytics \ + && flutter precache diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json new file mode 100644 index 000000000..a0dce9481 --- /dev/null +++ b/.devcontainer/devcontainer.json @@ -0,0 +1,31 @@ +{ + "build": { + "dockerfile": "Dockerfile" + }, + "runArgs": [ + "--add-host", + "host.docker.internal:host-gateway", + "--device-cgroup-rule", + "c 189:* rmw" + ], + "mounts": [ + { + "source": "/dev/bus/usb", + "target": "/dev/bus/usb", + "type": "bind" + } + ], + "postAttachCommand": [ + "bash", + "-c", + "sudo chmod 0666 /dev/bus/usb/*/* && flutter pub get" + ], + "customizations": { + "vscode": { + "extensions": [ + "Dart-Code.dart-code", + "Dart-Code.flutter" + ] + } + } +} diff --git a/README.md b/README.md index 591c2ddc0..489c9b59f 100644 --- a/README.md +++ b/README.md @@ -72,6 +72,49 @@ Please read FOSSASIA's [Best Practices](https://blog.fossasia.org/open-source-de * Before you join development, please set up the project on your local machine, run it and go through the application completely. Press on any button you can find and see where it leads to. Explore. * If you would like to work on an issue, drop in a comment at the issue. If it is already assigned to someone, but there is no sign of any work being done, please free to drop in a comment and start working on it. +## Dev Container usage + +Opening this repository in VSCode, GitHub Codespaces or another supported editor/IDE will allow the repository to be opened in a [Dev Container](https://containers.dev/). + +The Dev Container contains all necessary dependencies and tools required to build, run and debug flutter applications. + +### How to connect via `adb` + +:warning: In case `adb` is already installed and running on the host it may need to be stopped before continuing. + +This Dev Container allows several different methods of connecting to a device via `adb`: + +#### Entirely from inside the container (USB pass-through) + +:information_source: **Windows** and **MacOS** need a working **USB/IP** setup. Read more in the official [Docker Desktop documentation](https://docs.docker.com/desktop/features/usbip/) and in this [blog post](https://blog.golioth.io/usb-docker-windows-macos/). + +The Dev Container bind-mounts `/dev/bus/usb/` and sets the correct access controls for a seamless integration. \ +Enable [USB debugging](https://developer.android.com/tools/adb#Enabling) on your phone and try to find it via: + +```bash +adb devices +``` +If it shows up, everything is ready and you can run `flutter run` to push a development version of the app onto your device. + +#### Using the host's `adb` server + +If `adb` is already installed on the host, the tools in the Dev Container can be configured to use the host's `adb` server: + +1. Ensure the `adb` server is listening on **all interfaces** + 1. If that is not the case, kill and restart it: `adb kill-server && adb -a server` (the `-a` instructs it to listen on all interfaces). +1. Set or export the following environment variable before executing `adb` or `flutter run`: `ADB_SERVER_SOCKET=tcp:host.docker.internal:5037` +1. You should now be able to list the devices connected via USB to the host + +#### Wireless connection + +Android 11 and higher support wireless debugging. Check out the [documentation](https://developer.android.com/tools/adb#wireless-android11-command-line) for more information. \ +For this mode it is required that both the workstation and the device are on the **same network**. + +:information_source: This also works when developing inside **GitHub Codespaces**. In that case you can bring your device and the Codespace onto the same network by installing WireGuard, Tailscale or another overlay/mesh network on both the Codespace and your device. + +Enable Wireless debugging as per the [documentation](https://developer.android.com/tools/adb#wireless-android11-command-line), then **pair** `adb pair :` and **connect** `adb connect :` and you should be able to find your device via `adb devices`. + + ## LICENSE The application is licensed under the [Apache License 2.0](/LICENSE). Copyright is owned by FOSSASIA and its contributors.