Skip to content

TokoVoip is a TeamSpeak plugin used along a FiveM script to add a custom proximity chat and radio system to FiveM

License

Notifications You must be signed in to change notification settings

DawsonGodin/TokoVOIP_TS3

 
 

Repository files navigation

Introduction: TokoVOIP

TokoVOIP is a TeamSpeak plugin used along a FiveM script to add a custom proximity chat and radio system to FiveM

It includes radio effects thanks to the integration of the RadioFX plugin

Downloads are available on the releases page

If you like TokoVOIP, give it a star ! It'd be much appreciated <3

We have a Discord server to discuss, or if you need help !
Discord

You can support my work:
Patreon Donate

Table of Contents

Setting up TokoVOIP

You can download the ws-server, fivem-script & ts3-plugin on the release page

(players) Setting up the ts3-plugin

Every player must install Teamspeak 3 and the TokoVOIP plugin

  • Install the plugin downloaded on the release page
  • Connect to the fivem server
  • Connect to the TS3 server
  • Join the right TS3 channel

The TS3 Plugin will connect only if you are already in-game
The TS3 Plugin will try to connect if you join a TS3 channel containing 'tokovoip' in it's name
You can use the buttons in Plugins->TokoVoip to manually connect/disconnect the TS3 Plugin

(servers) Setting up the ws-server and fivem-script

Step 1: Setting up the ws-server

  • Download ws-server from the release page
  • Extract it in your fivem resources folder
  • Open ws_server/config.js
  • Change "TSServer" to your Teamspeak server IPv4
    Note: domain names are currently not supported. Please open an issue if that's something you would like to see available
  • start ws_server in your fivem server console
  • Copy the IP:PORT in the console after Listening on and save it for Step 2: Setting up the fivem-script

Step 2: Setting up the fivem-script

A documentation for the FiveM script is available here

(servers) Setting up ws-server as Standalone

It can be run as a standalone NodeJS application, on the same machine as your fivem server, or on a completely different machine

  • Download Node.js
  • Open config.js
    • Change "TSServer" to your Teamspeak server IPv4
    • Change "FivemServerPort" to your FiveM server port
    • If the ws-server is hosted on a separate machine:
      Change "FivemServerIP" to your FiveM server IPv4
  • Open ws-server folder in cmd / terminal
  • Execute npm i
  • After its done run node index.js
    A module such as pm2 can be used to run the ws-server in the background

(servers) Onesync Infinity

Onesync infinity is supported with TokoVOIP 1.5.0+
By default, Teamspeak servers silence everyone when more than 100 users are in a channel
Make sure your teamspeak server is configured properly:

  • Right click your teamspeak server
  • Press Edit virtual server
  • Press more
  • Open tab Misc
  • Change the value of Min clients in channel before silence

How does it work ?

The system is based on websockets
In-game data is sent through websockets to the TS3 plugin
FiveM blocks websockets running on the local network, we must use a remote ws-server

TS3 has no way to know on which fivem server you are currently on locally, a handshake system is required
A master server is used to register handshakes
That is it's only purpose, everything else is run on your own self-hosted ws-server and fivem-script

  • Phase 1 - Handshake:
    • fivem-script -> ws-server -> register for handshake (master server)
    • ts3-plugin -> look for handshake (master server) -> ws-server

Once the fivem websocket & ts3 websocket successfully handshaked, the master server is not used anymore

  • Phase 2 - Communicate:
    • fivem-script -> ws-server -> ts3-plugin
    • fivem-script <- ws-server <- ts3-plugin

Why do I need a ws-server ?

Read the following:

TROUBLESHOOTING (only 1.5.2)

FiveM websocket keeps saying Not connected:

  • FiveM didn't successfuly connect to the websocket server.
  • Make sure your websocket port is open
  • Make sure firewall isn't blocking your port

Ts3 websocket keeps saying Not connected:

  • Make sure your waiting channel has tokovoip in the name
  • FiveM and Ts3 didn't successfuly handshake
  • Make sure your websocket has proper teamspeak, fivem and ws ip
  • Try manually using the connect button in Plugins -> TokoVoip -> Connect

Could not find dependency yarn for resource ws_server:

Terms and conditions

A 'TokoVOIP' watermark must be visible on screen. You can move it, change it's design however you like.
Just keep one somewhere. Thanks
For the rest, refer to the license

Contributing

I am open to pull requests, feel free to build upon my work and improve it Mind you, this is my only project done in C++ and have only done low level C projects, so I am certain a lot of improvements can be made

Building the TS3 plugin

You will need the following installed:

Clone the repo and don't forget to initialize the submodules:

git submodule update --init --recursive

Then move to the ts3_plugin folder, and generate the Visual Studio solution: (set the correct path to Qt)

mkdir build32
cd build32
cmake -G "Visual Studio 15 2017" -DCMAKE_PREFIX_PATH="<PATH_TO>/Qt/5.12.7/msvc2017" ..
cd ..
mkdir build64
cd build64
cmake -G "Visual Studio 15 2017 Win64"  -DCMAKE_PREFIX_PATH="<PATH_TO>/Qt/5.12.7/msvc2017_64" ..

The visual studio solutions are available in their platform specific folders. You're ready to go !

Packaging the TS3 plugin

Making a TS3 plugin package is very easy, you can use the template in ts3_package if you want. You will need:

  • package.ini file which gives some info about the plugin
  • .dll files in a plugin folder

The .dll should have a suffix _win32 or _win64 matching their target platforms.

Then, archive the whole thing as a .zip file, and rename it to .ts3_plugin.

It's that simple.

Archive tree example:

.
+-- package.ini
+-- plugins
|   +-- tokovoip
|       +-- walkie_talkie16.png
|       +-- mic_click_off.wav
|       +-- mic_click_on.wav
|   +-- plugin_win32.dll
|   +-- plugin_win64.dll

Dependencies and sources

About

TokoVoip is a TeamSpeak plugin used along a FiveM script to add a custom proximity chat and radio system to FiveM

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 84.0%
  • C++ 11.6%
  • Lua 2.5%
  • JavaScript 1.5%
  • HTML 0.2%
  • CMake 0.1%
  • Other 0.1%