/liquid-migration

Facilitate the VPN migration for Liquid Investigations.

Primary LanguageTypeScriptGNU General Public License v3.0GPL-3.0

liquid-migration

Facilitate the VPN migration for Liquid Investigations.

Installation

To prepare the build environment start as root on a fresh Debian 11 installation:

apt update
apt install libwebkit2gtk-4.0-dev \
    build-essential \
    curl \
    wget \
    libssl-dev \
    libgtk-3-dev \
    libayatana-appindicator3-dev \
    librsvg2-dev \
    git-core
adduser build

Continue as the build user:

# Install Rust
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
source "$HOME/.cargo/env"
rustc --version

# Install node
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
$SHELL   # Open a new shell to load nvm
nvm install 16

# Get the source code, copy the ssh public key to the Github deploy keys
ssh-keygen -o -a 100 -t ed25519 -f ~/.ssh/id_ed25519 -C "build@liquid-migration"

# Build the app
cargo install tauri-cli
git clone git@github.com:critocrito/liquid-migration.git
cd liquid-migration
npm install
cat <<EOF >> resources/app-config.json
> {
  "project": "E",
  "server": {
    "host": "10.0.11.1",
    "network": "10.0.11.0/24",
    "endpoint": "23.23.23.23",
    "public_key": "<pub key>"
  }
}
> EOF
cargo tauri build

The build outputs can be found in src-tauri/target/release:

ls -l src-tauri/target/release/bundle/app-image

Development

To start the app during development run:

cargo tauri dev

There are various scripts that verify code quality:

  • npm run lint : Check the code quality of the Typescript and Rust code.
  • npm run fix : Fix any code quality issues that can be automated.
  • npm run watch : Run various code quality checkers in watch mode.