> Правда в этом он наломал дров - явно не задав себе простой вопрос: "как другим юзать эту либу?"В документации английским по белому написано - смотрите код Коммуниста. Со временем, если руки дойдут, сделаю нормальный пример.
> Плюсатое апи у либы - ну вы поняли
Какой язык программирования автор знает, на том и написал. Изучить тот же С - дело нехитрое. Другой вопрос - зачем? С учётом того, что я ни разу не программист. Ни по образованию, ни по роду занятий.
> Дока не говорит о структурировании протокола
Сделаю со временем и описание протокола. Хотя ничего особенного там нет. Сообщение шифруется и разбивается на датаграммы. По 512 байт в каждой. Первые 32 байта - ключ отправителя, затем 2 байта - тип сообщения (латинские заглавные буквы), дальше - время создания датаграммы (time_t, переведённый в uint64_t). Дальше могут быть вариации, в зависимости от типа сообщения. В целом размер "шапки" 50 байт. Дальше - содержательная часть (если таковая есть). Каждые пять секунд на каждый контакт уходит техническое сообщение для поддержания соединения (если вы работаете в режиме "интернет" и не прошло установленное время, после которого контакт считается "не в сети" - смотрите, есть в настройках, в их описании и в документации библиотеки). В режиме "локальная" сеть раз в минуту отправляется широковещательный запрос (по протоколам ipv4 и ipv6). Если пришёл отклик, и ключ ответившего есть в списке, то устанавливается соединение. Грубо - как-то так, подробнее будет позже в репозиториях. Если интересует протокол работы STUN или ретранслятора - смотрите код. Весь функционал ретранслятора вынесен в отдельный класс (и серверная, и клиентская части), там не много. STUN - там тоже не сложно, одна функция по большому счёту.