mirror of
https://github.com/rustdesk/doc.rustdesk.com.git
synced 2025-01-22 14:08:36 +01:00
177 lines
4.5 KiB
Markdown
177 lines
4.5 KiB
Markdown
---
|
|
title: Web
|
|
weight: 23
|
|
---
|
|
|
|
## How to build on Linux
|
|
|
|
Run below on Linux or Mac (works on Windows too, however you may need to slightly modify some commands, e.g. change `wget` to `curl.exe -O`):
|
|
|
|
```sh
|
|
git clone https://github.com/JelleBuning/rustdesk.git
|
|
cd rustdesk
|
|
git switch fix_build
|
|
cd flutter/web/js
|
|
|
|
# Install protoc first, see: https://google.github.io/proto-lens/installing-protoc.html
|
|
npm install ts-proto
|
|
# Only works with vite <= 2.8, see: https://github.com/vitejs/vite/blob/main/docs/guide/build.md#chunking-strategy
|
|
npm install vite@2.8
|
|
|
|
# Required for yarn build
|
|
npm install yarn -g
|
|
npm install typescript -g
|
|
npm install protoc -g
|
|
|
|
yarn build
|
|
|
|
cd ..
|
|
|
|
# About details of YUV converter, check this https://github.com/rustdesk/rustdesk/issues/364#issuecomment-1023562050
|
|
wget https://github.com/rustdesk/doc.rustdesk.com/releases/download/console/web_deps.tar.gz
|
|
# Decompress to the current directory
|
|
tar xzf web_deps.tar.gz
|
|
|
|
cd ..
|
|
|
|
# Good Luck!
|
|
flutter run -d chrome
|
|
```
|
|
|
|
## How to build release on Linux
|
|
|
|
If you want to host the web client you should build a release before running it on a web server.
|
|
To do so follow the steps shown above except the `flutter run -d chrome` command. Continue with the following commands:
|
|
|
|
```sh
|
|
flutter build web --release
|
|
cd build/web
|
|
# You could use any server, just an example
|
|
python -m http.server 8000
|
|
```
|
|
|
|
To configure the build on HTTPS we would recommend following the instructions from the following [source](https://medium.com/flutter-community/how-to-host-flutter-using-nginx-a71bcb11d96).
|
|
|
|
> Currently, YUV converter and VP9 are the bottleneck.
|
|
|
|
## How to build with Docker
|
|
|
|
Run below on Linux or Mac:
|
|
- Begin by installing flutter for [Linux](https://docs.flutter.dev/get-started/install/linux#install-flutter-manually) or [macOS](https://docs.flutter.dev/get-started/install/macos)
|
|
- Setup the flutter app locally:
|
|
|
|
```sh
|
|
git clone https://github.com/JelleBuning/rustdesk.git
|
|
cd rustdesk
|
|
git switch fix_build
|
|
cd flutter/web/js
|
|
|
|
# Install protoc first, see: https://google.github.io/proto-lens/installing-protoc.html
|
|
npm install ts-proto
|
|
# Only works with vite <= 2.8, see: https://github.com/vitejs/vite/blob/main/docs/guide/build.md#chunking-strategy
|
|
npm install vite@2.8
|
|
|
|
# Required for yarn build
|
|
npm install yarn -g
|
|
npm install typescript -g
|
|
npm install protoc -g
|
|
|
|
yarn build
|
|
```
|
|
|
|
- Create a `Dockerfile` with the following content under `flutter` directory:
|
|
|
|
```Dockerfile
|
|
# Install operating system and dependencies
|
|
FROM ubuntu:20.04
|
|
|
|
ENV DEBIAN_FRONTEND=noninteractive
|
|
|
|
RUN apt-get update
|
|
RUN apt-get install -y curl git wget unzip libgconf-2-4 gdb libstdc++6 libglu1-mesa fonts-droid-fallback lib32stdc++6 python3 clang cmake ninja-build pkg-config libgtk-3-dev
|
|
RUN apt-get clean
|
|
|
|
# Download Flutter SDK from Flutter GitHub repo
|
|
RUN git clone https://github.com/flutter/flutter.git /usr/local/flutter
|
|
|
|
# Set flutter environment path
|
|
ENV PATH="/usr/local/flutter/bin:/usr/local/flutter/bin/cache/dart-sdk/bin:${PATH}"
|
|
|
|
# Run flutter doctor
|
|
RUN flutter doctor
|
|
|
|
# Enable flutter web
|
|
RUN flutter channel master
|
|
RUN flutter upgrade
|
|
RUN flutter config --enable-web
|
|
|
|
# Copy files to container and build
|
|
RUN mkdir /app/
|
|
# I was unable to build web app from dockerfile
|
|
# So instead I built it locally and commented the "flutter build web" in this file
|
|
COPY . /app/
|
|
WORKDIR /app/
|
|
# RUN flutter build web
|
|
|
|
# Record the exposed port
|
|
EXPOSE 5000
|
|
|
|
# Make server startup script executable and start the web server
|
|
RUN ["chmod", "+x", "/app/server/server.sh"]
|
|
|
|
ENTRYPOINT [ "/app/server/server.sh"]
|
|
```
|
|
|
|
- Create `server` directory under `flutter`
|
|
- Create a `server.sh` file with the following content under `flutter/server` directory:
|
|
|
|
```sh
|
|
#!/bin/bash
|
|
|
|
# Set the port
|
|
PORT=5000
|
|
|
|
# Stop any program currently running on the set port
|
|
echo 'preparing port' $PORT '...'
|
|
fuser -k 5000/tcp
|
|
|
|
# Switch directory
|
|
cd build/web/
|
|
|
|
# Start the server
|
|
echo 'Server starting on port' $PORT '...'
|
|
python3 -m http.server $PORT
|
|
```
|
|
|
|
- Build the Docker image:
|
|
|
|
```sh
|
|
docker build -t rustdesk-web-client .
|
|
```
|
|
|
|
- Run the Docker image:
|
|
|
|
```sh
|
|
docker run -p 5000:5000 rustdesk-web-client
|
|
```
|
|
|
|
- Open your browser and go to `localhost:5000` to see the web app
|
|
|
|
### RustDesk Web Client using existing Docker image
|
|
|
|
If you do not want to build the Docker image yourself, you can use the image I built and uploaded to [Docker Hub](https://hub.docker.com/r/keyurbhole/flutter_web_desk).
|
|
|
|
- Pull the image:
|
|
|
|
```sh
|
|
docker pull keyurbhole/flutter_web_desk
|
|
```
|
|
|
|
- Run the image:
|
|
|
|
```sh
|
|
docker run -p 5000:5000 keyurbhole/flutter_web_desk
|
|
```
|
|
|
|
- Open your browser and go to `localhost:5000` to see the web app
|