Tox

Tox是一种点对点(无服务器)即时通讯工具,旨在使普通用户轻松获得安全性和隐私。(Tox is a peer to peer (serverless) instant messenger aimed at making security and privacy easy to obtain for regular users. )

Github星跟蹤圖

Tox是一种点对点(无服务器)即时通讯工具,旨在使普通用户轻松获得安全性和隐私。 它使用NaCl进行加密和身份验证。

重要!

危险:实验

这是一个实验性加密网络库。 它尚未经过专门从事加密或密码分析的独立第三方的正式审核。 使用此库需要您自担风险。

底层加密库NaCl提供可靠的加密,但安全模型尚未完全指定。 有关开发威胁模型的讨论,请参见问题210。 有关已知缺陷的其他问题(例如,问题426描述了如果您的密钥被盗则会发生什么)。

主要指標

概覽
名稱與所有者TokTok/c-toxcore
主編程語言C
編程語言Makefile (語言數: 13)
平台Linux, Unix-like, Windows
許可證GNU General Public License v3.0
所有者活动
創建於2016-07-06 08:15:22
推送於2025-06-08 06:30:38
最后一次提交2025-03-07 15:01:40
發布數42
最新版本名稱nightly (發布於 )
第一版名稱v0.0.0 (發布於 )
用户参与
星數2.4k
關注者數107
派生數295
提交數5.6k
已啟用問題?
問題數610
打開的問題數180
拉請求數1669
打開的拉請求數37
關閉的拉請求數589
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?

Project Tox

Current build status: Build Status
Current Coverage: Coverage Status

Website **, ** Wiki **, ** Blog **, ** FAQ **, ** Binaries/Downloads **, ** Clients **, ** Compiling **, ** Toxcore's Projects

IRC Channels: Users: #tox@freenode, Developers: #toktok@freenode

What is Tox

Tox is a peer to peer (serverless) instant messenger aimed at making security
and privacy easy to obtain for regular users. It uses
NaCl for its encryption and authentication.

IMPORTANT!

Danger: Experimental

This is an experimental cryptographic network library. It has not been
formally audited by an independent third party that specializes in
cryptography or cryptanalysis. Use this library at your own risk.

The underlying crypto library NaCl
provides reliable encryption, but the security model has not yet been fully
specified. See issue 210 for
a discussion on developing a threat model. See other issues for known
weaknesses (e.g. issue 426
describes what can happen if your secret key is stolen).

Toxcore Development Roadmap

The roadmap and changelog are generated from GitHub issues. You may view them
on the website, where they are updated at least once every 24 hours:

Installing toxcore

Detailed installation instructions can be found in INSTALL.md.

In a nutshell, if you have libsodium
installed, run:

mkdir _build && cd _build
cmake ..
make
sudo make install

If you have libvpx and
opus installed, the above will also build the
A/V library for multimedia chats.

Using toxcore

The simplest "hello world" example could be an echo bot. Here we will walk
through the implementation of a simple bot.

Creating the tox instance

All toxcore API functions work with error parameters. They are enums with one
OK value and several error codes that describe the different situations in
which the function might fail.

TOX_ERR_NEW err_new;
Tox *tox = tox_new(NULL, &err_new);
if (err_new != TOX_ERR_NEW_OK) {
  fprintf(stderr, "tox_new failed with error code %d\n", err_new);
  exit(1);
}

Here, we simply exit the program, but in a real client you will probably want
to do some error handling and proper error reporting to the user. The NULL
argument given to the first parameter of tox_new is the Tox_Options. It
contains various write-once network settings and allows you to load a
previously serialised instance. See toxcore/tox.h for details.

Setting up callbacks

Toxcore works with callbacks that you can register to listen for certain
events. Examples of such events are "friend request received" or "friend sent
a message". Search the API for tox_callback_* to find all of them.

Here, we will set up callbacks for receiving friend requests and receiving
messages. We will always accept any friend request (because we're a bot), and
when we receive a message, we send it back to the sender.

tox_callback_friend_request(tox, handle_friend_request);
tox_callback_friend_message(tox, handle_friend_message);

These two function calls set up the callbacks. Now we also need to implement
these "handle" functions.

Handle friend requests

static void handle_friend_request(
  Tox *tox, const uint8_t *public_key, const uint8_t *message, size_t length,
  void *user_data) {
  // Accept the friend request:
  TOX_ERR_FRIEND_ADD err_friend_add;
  tox_friend_add_norequest(tox, public_key, &err_friend_add);
  if (err_friend_add != TOX_ERR_FRIEND_ADD_OK) {
    fprintf(stderr, "unable to add friend: %d\n", err_friend_add);
  }
}

The tox_friend_add_norequest function adds the friend without sending them a
friend request. Since we already got a friend request, this is the right thing
to do. If you wanted to send a friend request yourself, you would use
tox_friend_add, which has an extra parameter for the message.

Handle messages

Now, when the friend sends us a message, we want to respond to them by sending
them the same message back. This will be our "echo".

static void handle_friend_message(
  Tox *tox, uint32_t friend_number, TOX_MESSAGE_TYPE type,
  const uint8_t *message, size_t length,
  void *user_data) {
  TOX_ERR_FRIEND_SEND_MESSAGE err_send;
  tox_friend_send_message(tox, friend_number, type, message, length,
    &err_send);
  if (err_send != TOX_ERR_FRIEND_SEND_MESSAGE_OK) {
    fprintf(stderr, "unable to send message back to friend %d: %d\n",
      friend_number, err_send);
  }
}

That's it for the setup. Now we want to actually run the bot.

Main event loop

Toxcore works with a main event loop function tox_iterate that you need to
call at a certain frequency dictated by tox_iteration_interval. This is a
polling function that receives new network messages and processes them.

while (true) {
  usleep(1000 * tox_iteration_interval(tox));
  tox_iterate(tox, NULL);
}

That's it! Now you have a working echo bot. The only problem is that since Tox
works with public keys, and you can't really guess your bot's public key, you
can't add it as a friend in your client. For this, we need to call another API
function: tox_self_get_address(tox, address). This will fill the 38 byte
friend address into the address buffer. You can then display that binary
string as hex and input it into your client. Writing a bin2hex function is
left as exercise for the reader.

We glossed over a lot of details, such as the user data which we passed to
tox_iterate (passing NULL), bootstrapping into an actual network (this bot
will work in the LAN, but not on an internet server) and the fact that we now
have no clean way of stopping the bot (while (true)). If you want to write a
real bot, you will probably want to read up on all the API functions. Consult
the API documentation in toxcore/tox.h for more information.

Other resources