3.5 KiB
Attention this guid is currently outdated!
Anyway most of this stuff is still relevant for the web client, just the last few steps may differ
Build TeaWeb
General start
Before you start, please ensure that you've successfully set up your environment.
If you don't want to install all this, you could also use the official web build docker.
1. Clone and initialize project
git clone https://github.com/TeaSpeak/TeaWeb
git submodule update --init --recursive --remote --checkout
(2.) Build native libraries
As already mentioned, if you're just want to develop or style the web client this isnt required!
If you want to speak or use TeamSpeak 3 Identities you have to complete this!
Opus
Native loader
cd asm
./make_opus.sh
Javascript loader
npm run build-worker
Tommath
cd libraries/tommath
mkdir build; cd build
emcmake cmake ..
emmake make -j 4
Tomcrypt
ATTENTION: Do not use the create_build.sh
script!
cd libraries/tomcrypt
emmake make -f makefile CFLAGS="-DUSE_LTM -DLTM_DESC -I../tommath/" EXTRALIBS="$(pwd)/../tommath/build/libtommathStatic.a" test
Make js files
cd asm
mkdir build; cd build
emcmake cmake ..
emmake make -j 4
3. Compiling the typescript and as well the style sheets
npm install --only=dev # Install the dependencies
./scripts/web_build.sh dev # Use "rel" insteadof "dev" to create a release build
You should now find an ready to use environment within web/environment/development
.
Please notice that all files are just relative links to the files.
4. Create a final package
./scripts/web_package.sh dev # Use "rel" insteadof "dev" to create a release package
Environment setup
Basic system requirements
You need a linux based (ubuntu or debian is recommanded) system.
As well you need the following packaged installed:
apt-get install git wget gcc make python2.7 xz-utils php5 autoconf libtool zip
ATTENTION: Its important to have python2.7 as default python
command.
Install emscripten
emscripten
is required for compiling c++ into webassably or even javascript.
This currently affects the TeamSpeak 3 Identity part and the codec part.
Just for developing or styling the web client, this isn't required.
So if you want to save some time you could scrip this.
Install java (Required for emscripten)
apt-get install software-properties-common
add-apt-repository ppa:webupd8team/java
apt-get update
apt-get install oracle-java8-installer
Install cmake (For webassembly and emscripten)
wget https://cmake.org/files/v3.12/cmake-3.12.3.tar.gz
tar xvf cmake-*.tar.gz
cd cmake-*
./configure
make -j 4
make install
Install nodjs (Later for emscripten too)
wget https://nodejs.org/dist/v8.12.0/node-v8.12.0-linux-x64.tar.xz
tar xvf node-*.tar.xz
cd node-*
cp -R * /usr/local/
Install emscripten with fastcomp and llvm + clang
Fastcomp and CLang compiler
git clone https://github.com/kripken/emscripten-fastcomp
cd emscripten-fastcomp
git clone https://github.com/kripken/emscripten-fastcomp-clang tools/clang
mkdir build; cd build
cmake .. -DCMAKE_BUILD_TYPE=Release -DLLVM_TARGETS_TO_BUILD="host;JSBackend" -DLLVM_INCLUDE_EXAMPLES=OFF -DLLVM_INCLUDE_TESTS=OFF -DCLANG_INCLUDE_TESTS=OFF
make -j 4
make install
Emscripten
git clone https://github.com/kripken/emscripten.git
cd emscripten
python emscripten.py
python emscripten.py #Execute it twice to detekt error
echo "PATH=\"$PATH:`pwd`\"" >> ~/.bashrc