2022-08-22 15:35:37 -04:00
|
|
|
# Veilid
|
|
|
|
|
|
|
|
## Introduction
|
|
|
|
|
|
|
|
## Obtaining the source code
|
|
|
|
|
|
|
|
```shell
|
|
|
|
git clone --recurse-submodules git@gitlab.hackers.town:veilid/veilid.git
|
|
|
|
```
|
|
|
|
|
|
|
|
## Dependencies
|
|
|
|
|
|
|
|
### GNU/Linux
|
|
|
|
|
|
|
|
Development of Veilid on GNU/Linux requires a Debian variant such as Debian
|
|
|
|
itself, Ubuntu or Mint. Pull requests to support other distributions would be
|
|
|
|
welcome!
|
|
|
|
|
2022-08-23 10:37:41 -04:00
|
|
|
Running the setup script requires:
|
|
|
|
* Android SDK and NDK
|
|
|
|
* Rust
|
2022-08-22 15:35:37 -04:00
|
|
|
|
2022-08-23 10:37:41 -04:00
|
|
|
You may decide to use Android Studio [here](https://developer.android.com/studio)
|
|
|
|
to maintain your Android dependencies. If so, use the dependency manager
|
2022-08-23 11:48:22 -04:00
|
|
|
within your IDE. If you plan on using Flutter for Veilid development, the Android Studio
|
|
|
|
method is highly recommended as you may run into path problems with the 'flutter'
|
|
|
|
command line without it. If you do so, you may skip to
|
2022-08-22 15:35:37 -04:00
|
|
|
[Run Veilid setup script](#Run Veilid setup script).
|
|
|
|
|
|
|
|
* build-tools;30.0.3
|
|
|
|
* ndk;22.0.7026061
|
|
|
|
* cmake;3.22.1
|
|
|
|
|
|
|
|
#### Setup Dependencies using the CLI
|
|
|
|
|
|
|
|
Otherwise, you may choose to use Android `sdkmanager`. Follow the installation
|
|
|
|
instructions for `sdkmanager`
|
|
|
|
[here](https://developer.android.com/studio/command-line/sdkmanager), then use
|
|
|
|
the command line to install the requisite package versions:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
sdkmanager --install "build-tools;30.0.3"
|
|
|
|
sdkmanager --install "ndk;22.0.7026061"
|
|
|
|
sdkmanager --install "cmake;3.22.1"
|
|
|
|
```
|
|
|
|
|
|
|
|
Export environment variables and add the Android SDK platform-tools directory to
|
|
|
|
your path.
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cat << EOF >> ~/.profile
|
|
|
|
export ANDROID_SDK_ROOT=<path to sdk>
|
2022-08-23 10:37:41 -04:00
|
|
|
export ANDROID_NDK_HOME=$ANDROID_SDK_ROOT/ndk/22.0.7026061
|
|
|
|
export PATH=\$PATH:$ANDROID_SDK_ROOT/platform-tools
|
|
|
|
EOF
|
2022-08-22 15:35:37 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
#### Run Veilid setup script
|
|
|
|
|
|
|
|
Now you may run the Linux setup script to check your development environment and
|
|
|
|
pull the remaining Rust dependencies:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
./setup_linux.sh
|
|
|
|
```
|
|
|
|
|
2022-08-23 11:48:22 -04:00
|
|
|
#### Run the veilid-flutter setup script (optional)
|
|
|
|
|
|
|
|
If you are developing Flutter applications or the flutter-veilid portion, you should
|
|
|
|
install Android Studio, and run the flutter setup script:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cd veilid-flutter
|
|
|
|
./setup_flutter.sh
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2022-08-22 15:35:37 -04:00
|
|
|
### macOS
|
|
|
|
|
2022-08-23 10:37:41 -04:00
|
|
|
Development of Veilid on MacOS is possible on both Intel and ARM hardware.
|
|
|
|
|
|
|
|
Development requires:
|
|
|
|
* Xcode, preferably latest version
|
|
|
|
* Homebrew [here](https://brew.sh)
|
|
|
|
* Android SDK and NDK
|
|
|
|
* Java 8
|
|
|
|
* Rust
|
|
|
|
|
|
|
|
You may decide to use Android Studio [here](https://developer.android.com/studio)
|
|
|
|
to maintain your Android dependencies. If so, use the dependency manager
|
2022-08-23 11:48:22 -04:00
|
|
|
within your IDE. If you plan on using Flutter for Veilid development, the Android Studio
|
|
|
|
method is highly recommended as you may run into path problems with the 'flutter'
|
|
|
|
command line without it. If you do so, you may skip to
|
2022-08-23 10:37:41 -04:00
|
|
|
[Run Veilid setup script](#Run Veilid setup script).
|
|
|
|
|
|
|
|
* build-tools;30.0.3
|
|
|
|
* ndk;22.0.7026061
|
|
|
|
* cmake;3.22.1
|
|
|
|
|
|
|
|
#### Setup Java
|
|
|
|
|
|
|
|
```shell
|
|
|
|
brew install openjdk@8
|
|
|
|
```
|
|
|
|
and then symlink it as appropriate for your system:
|
|
|
|
|
|
|
|
Intel:
|
|
|
|
```shell
|
|
|
|
sudo ln -sfn /usr/local/opt/openjdk@8/libexec/openjdk.jdk /Library/Java/JavaVirtualMachines/openjdk-8.jdk
|
|
|
|
```
|
|
|
|
|
|
|
|
ARM:
|
|
|
|
```shell
|
|
|
|
sudo ln -sfn /opt/homebrew/openjdk@8/libexec/openjdk.jdk /Library/Java/JavaVirtualMachines/openjdk-8.jdk
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
#### Setup Dependencies using the CLI
|
|
|
|
|
|
|
|
Otherwise, you may choose to use Android `sdkmanager`. Use
|
|
|
|
the command line to install the requisite package versions: `brew install android-commandlinetools`
|
|
|
|
|
|
|
|
```shell
|
|
|
|
sdkmanager --install "build-tools;30.0.3"
|
|
|
|
sdkmanager --install "ndk;22.0.7026061"
|
|
|
|
sdkmanager --install "cmake;3.22.1"
|
|
|
|
```
|
|
|
|
|
|
|
|
Export environment variables and add the Android SDK platform-tools directory to
|
|
|
|
your path.
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cat << EOF >> ~/.zshenv
|
|
|
|
export ANDROID_SDK_ROOT=$HOME/Library/Android/sdk
|
|
|
|
export ANDROID_NDK_HOME=$HOME/Library/Android/sdk/ndk/22.0.7026061
|
|
|
|
export PATH=\$PATH:$HOME/Library/Android/sdk/platform-tools
|
|
|
|
EOF
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Run Veilid setup script
|
|
|
|
|
|
|
|
Now you may run the MacOS setup script to check your development environment and
|
|
|
|
pull the remaining Rust dependencies:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
./setup_macos.sh
|
|
|
|
```
|
2022-08-22 15:35:37 -04:00
|
|
|
|
2022-08-23 11:48:22 -04:00
|
|
|
#### Run the veilid-flutter setup script (optional)
|
|
|
|
|
|
|
|
If you are developing Flutter applications or the flutter-veilid portion, you should
|
|
|
|
install Android Studio, and run the flutter setup script:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cd veilid-flutter
|
|
|
|
./setup_flutter.sh
|
|
|
|
```
|
|
|
|
|
2022-08-22 15:35:37 -04:00
|
|
|
### Windows
|
|
|
|
|
|
|
|
**TODO**
|
|
|
|
|
|
|
|
## Veilid Server
|
|
|
|
|
|
|
|
In order to run the `veilid-server` locally:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cd ./veilid-server
|
|
|
|
cargo run
|
|
|
|
```
|
|
|
|
|
|
|
|
In order to see what options are available:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cargo run -- --help
|
|
|
|
```
|
|
|
|
|
|
|
|
## Veilid CLI
|
|
|
|
|
|
|
|
In order to connect to your local `veilid-server`:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cd ./veilid-cli
|
|
|
|
cargo run
|
|
|
|
```
|
|
|
|
|
|
|
|
Similar to `veilid-server`, you may see CLI options by typing:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cargo run -- --help
|
|
|
|
```
|