====== Yggmail ====== Это [[yggdrasil:email|электронная почта]], но немного не такая, какой вы ее знаете. В мире существует множество всевозможных служб обмена сообщениями, но асинхронная связь по-прежнему востребована и широко распространена. Yggmail разработан в соответствии со стандартами, которые большинству людей хорошо знакомы и понятны. [[Yggdrasil:Yggdrasil]] хорошо подходит для доставки электронной почты и позволяет Yggmail работать даже в закрытых сетях, где Интернет или другие возможности подключения ограничены или просто недоступны. Yggmail гарантирует сквозное шифрование и достаточно хорошо работает в сетях с изменчивой топологией. ===== Введение ===== **Yggmail** - это агент электронной почты, реализованный в одном бинарном файле, который может отправлять и получать сообщения через сеть [[Yggdrasil:Yggdrasil]]. * Yggmail можно запустить где угодно — ваш почтовый ящик сохраняется прямо на вашей машине; * Реализованы протоколы IMAP и SMTP для отправки и получения почты, таким образом, вы можете использовать свои любимые почтовые клиенты; * Для обмена сообщениями Yggmail использует подключения встроенного в него узла Yggdrasil; * Обмен сообщениями между двумя узлами Yggmail всегда защищен сквозным шифрованием; * Узлы Yggdrasil и Yggmail в одной и той же сети могут обнаруживаются автоматически с помощью отправки широковещательных пакетов ([[yggdrasil:mpd|multicast]]), либо вы можете настроить статическое подключение к желаемым узлам Yggdrasil. * Yggmail содержит в себе собственный узел Yggdrasil, но не использует отдельный TUN-адаптер, таким образом, Yggmail можно без проблем запускать на машине, где уже установлен и настроен сам Yggdrasil, а так же на машинах, где Yggdrasil не установлен (Yggmail не использует IP-пакеты, поэтому TUN не нужен; встроенный узел Yggdrasil используется в качестве транспорта, SMTP использует uTP). Адреса электронной почты формируются на основе ваших публичных ключей. Пример: \\ ''%%617b5772c6d10feda41fc6e0e43b976c4cc9383d3729310d3dc9e1332f0d9acd@yggmail%%''. ===== Быстрый старт ===== Используйте последнюю версию [[go:go|Go]] для установки Yggmail: go install github.com/neilalexander/yggmail/cmd/yggmail@latest (подробнее об установке или обновлении Go можно прочесть [[go:go_installation|здесь]]) Yggmail будет установлен в директорию, указанную в переменной окружения GOPATH, для удобства вы можете указать этот путь в переменной PATH: export PATH=$PATH:`go env GOPATH`/bin Создайте свой почтовый ящик и установите пароль. База данных Yggmail будет автоматически создана в вашей рабочей директории, если она еще не существует: yggmail -password Запустите Yggmail, используя созданную в рабочей директории базу данных, указав при запуске либо multicast, либо статический узел Yggdrasil, либо и то и другое: yggmail -multicast yggmail -peer=tls://... yggmail -multicast -peer=tls://... Адрес вашей электронной почты будет выведен в log при запуске Yggmail. Так же, этот адрес необходимо будет использовать в качестве имени пользователя для подключений SMTP/IMAP. Подключитесь к Yggmail с помощью вашего почтового клиента. Примеры параметров подключения: * SMTP прослушивает TCP-порт 1025, имя пользователя - ваш адрес, аутентификация по паролю простым текстом, не использовать SSL/TLS * IMAP прослушивает TCP-порт 1143, имя пользователя - ваш адрес, аутентификация по паролю простым текстом, не использовать SSL/TLS Теперь вы можете попробовать отправить электронное письмо другому пользователю Yggmail! ===== Параметры запуска ===== Поддерживаются следующие параметры командной строки: * ''%%-peer=tls://... or -peer=tcp://...%%'' — подключение к указанному узлу Yggdrasil, подобно тому, как настраивается подключение к [[yggdrasil:public_peer|публичному пиру]]; * ''%%-multicast%%'' - задействовать multicast peer discovery (автоматическое обнаружение) для узлов Yggdrasil в вашей локальной сети; * ''%%-database=/path/to/yggmail.db%%'' — использовать указанный файл базы данных; * ''%%-smtp=listenaddr:port%%'' — ожидать подключения SMTP на указанных адресе/порте; * ''%%-imap=listenaddr:port%%'' — ожидать подключения IMAP на указанных адресе/порте; * ''%%-password%%'' — установить IMAP/SMTP пароль (не имеет значения запущен Yggmail или нет, просто убедитесь, что Yggmail работает с нужной базой данных или что вы находитесь в нужной рабочей директории). ===== Пример ===== При запуске на локальном компьютере без Yggdrasil, достаточно указать один [[https://publicpeers.neilalexander.dev/|пир]] (а в настройках почтового клиента - localhost): yggmail -peer=tls://94.140.114.89:4708 Так можно запустить Yggmail, чтобы он был доступен для подключения по SMTP / IMAP из локальной сети: yggmail -peer=tls://192.168.1.4:22953 -database=/home/user/go/bin/yggmail.db -smtp=192.168.1.4:1025 -imap=192.168.1.4:1143 Здесь: * 192.168.1.4 - адрес в локальной сети устройства, на котором запускается Yggmail (в моём случае, это RaspberryPi); на этом же устройстве запущен пир Yggdrasil, который принимает подключения на порту 22953. * ''%%/home/user/go/bin/yggmail.db%%'' - путь к локальной базе Yggmail (см. выше) Таким образом мы подключаем Yggmail к нашему пиру Yggdrasil и открываем на этом устройстве в локальной сети порты 1025 и 1143. На любом другом устройстве в этой локальной сети настраиваем почтовый клиент (например, Thunderbird (notebook) или Почта (iPhone)) для подключения к получившемуся мини почтовому серверу, указав в настройках адрес 192.168.1.4 и соответствующие порты для SMTP и IMAP протоколов: 1025 и 1143. В дальнейшем работаем, как с любой другой почтой на других серверах. В этом примере ''%%-peer=tls://192.168.1.4:22953%%'' можно заменить на ''%%-multicast%%'', тогда Yggmail будет пытаться сам найти Yggdrasil в локальной сети с помощью отправки широковещательных пакетов. Пример systemd-unit'a для запуска yggmail: [Unit] Description=Yggmail Documentation=https://github.com/neilalexander/yggmail After=network-online.target [Service] Type=simple ExecStart=/home/user/go/bin/yggmail -peer=tcp://192.168.1.4:22953 -database=/home/user/go/bin/yggmail.db -smtp=192.168.1.4:1025 -imap=192.168.1.4:1143 2>&1 Restart=always RestartSec=1 TimeoutStopSec=0 [Install] WantedBy=multi-user.target Unit нужно сохранить в файл ''%%/lib/systemd/system/yggmail.service%%'' и выполнить команду: ''%%sudo systemctl enable --now yggmail%%'' (не забудьте указать корректные пути к yggmail и yggmail.db).\\ Если все сделано правильно ''%%systemctl status yggmail%%'' покажет: "Active (running)". Таким же образом можно установить и запустить Yggmail на [[:VPS]] [cо статическим ("белым") IP-адресом], тогда этот почтовый сервер может стать доступным не только из локальной сети, но и через Интернет, и вы сможете отправлять и получать почту Yggmail со смартфона, находясь, где угодно, имея любое подключение к Интернет. Дополнительно соединения и аутентификацию на SMTP / IMAP можно защитить c помощью VPN. C учетом описанных ниже [[.:yggmail#Замечания|ограничений]] Yggmail [на данный момент] больше подходит для использования с мессенджером [[https://delta.chat/ru/|Delta Chat]], однако другие e-mail клиенты так же можно настроить для работы с ним. ==== Пример настроек Delta Chat ==== Мессенджер доступен для популярных настольных операционных систем, а так же для [[wpru>IOS|iOS]] и [[wpru>Android]]. Ниже пример настроек клиента iOS, с учетом описанного выше. ^ Параметр ^ Значение ^ | Адрес эл. почты | 36ef9bc3a91ffbcc511b33faa3bb72b31c140f18e3ef143559a0128be440de49@yggmail| | Пароль | %%***%% (ваш пароль) | | **Дополнительные параметры** || | Параметры безопасности IMAP | Выкл.| | IMAP логин | 36ef9bc3a91ffbcc511b33faa3bb72b31c140f18e3ef143559a0128be440de49@yggmail | | IMAP сервер | 192.168.1.4 | | IMAP порт | 1143 | | Параметры безопасности SMTP | Выкл. | | SMTP логин | 36ef9bc3a91ffbcc511b33faa3bb72b31c140f18e3ef143559a0128be440de49@yggmail | | SMTP пароль | %%***%% (ваш пароль) | | SMTP сервер | 192.168.1.4| | SMTP порт |1025 | | Проверка сертификатов| Принимать недействительный | {{ yggdrasil:email:deltachat_settings.png?183&direct|Настройки Delta Chat }} ==== Пример настроек аккаунта электронной почты в Mozilla Thunderbird ==== {{yggdrasil:email:yggmail_tb_acc_settings.png?350&direct|Настройки аккаунта Yggmail в Mozilla Thunderbird}} Для настроенного аккаунта можно в его свойствах задать отображаемое имя (Account Name), чтобы выглядело примерно так: {{yggdrasil:email:yggmail_tb_acc_view.png?350&direct|Как выглядит аккаунт в Thunderbird}} ===== Резервные копии ===== Чтобы полностью сохранить копию аккаунта и почтовые сообщения для переноса или восстановления - достаточно скопировать файл, указанный при инициализации сервера: yggmail -database=/path/to/yggmail.db Если данный путь не указан явно, файл можно найти в домашней директории профиля. Приватный ключ (private_key) и хеш пароля (password) расположены в таблице config. Также нужно отдельно сохранить пароль инициализации базы данных (при выполнении команды yggmail -password), поскольку в исходном виде он не сохраняется. ===== Замечания ===== Несколько важных замечаний: * Yggmail должен быть запущен, чтобы была возможность получать входящие сообщения. По этой причине важно запускать Yggmail там, где он будет запущен постоянно, 24/7 [ //возможно, информация [[https://github.com/neilalexander/yggmail/issues/1#issuecomment-1930768430|устарела]]// ]; * Yggmail пытается гарантировать, что отправители - это те, за кого они себя выдают, поэтому заголовок 'From address' в отправляемых сообщениях должен соответствовать вашему Yggmail-адресу; * Вы можете обмениваться сообщениями только с другими пользователями Yggmail, обычные адреса электронной почты в Интернет и других сетях не поддерживаются; * Вы должны настроить свой почтовый клиент так, чтобы он использовал "insecure" (небезопасную) или "plaintext" (простым текстом) аутентификацию для IMAP/SMTP — это потому, что мы не используем SSL/TLS для IMAP/SMTP-протоколов, трафик Yggdrasil зашифрован; * На данный момент Yggmail поддерживает отправку сообщений, объемом не более 1MB. * Попытка отправить тестовое письмо на собственный адрес приведет к ошибке ([[https://github.com/neilalexander/yggmail/issues/33|#33]], [[https://github.com/neilalexander/yggmail/issues/35|#35]]) ===== Известные проблемы ===== Вероятно, Yggmail содержит большее количество багов, ниже упомянуты пара из них: * Поведение IMAP может не вполне соответствовать спецификации в некоторых случаях, таким образом, в различных почтовых клиентах могут наблюдаться различные проблемы; * Поиск в IMAP на данным момент не реализован полностью и вместо этого будет возвращать все известные адреса. Так же, код немного запутан, простите нас за это ;) ([[https://github.com/neilalexander|neilalexander]]) ===== Адреса пользователей ===== Желающие могут оставить здесь свой адрес, чтобы другие пользователи могли его найти и связаться с вами. \\ (если в таблице наберется большое количество контактов, перенесём её на отдельную страницу, а здесь оставим ссылку) ^ Никнейм / Имя ^ Адрес ^ | TomasGl | f6065c4d768d5b40e40c942ca77bd40079ed3cc2df266562b9f4546ebe2c13d6@yggmail | | BiGLapa | b6c2beb9ed1d8847bd5dba85d0623200435625fb2f9e155b8dd703a53b8c734d@yggmail | ====== Ссылки ====== Репозиторий проекта на GitHub: https://github.com/neilalexander/yggmail