devzone.org.ua/post/reyestratsiia-domenu-v-merezi-i2p.md
2025-11-01 14:28:20 +02:00

9.5 KiB
Raw Blame History

Реєстрація домену в мережі I2P

Останнім часом, захопився дослідженням мережі I2P, зокрема:

На цьому, думав завершити свій експеримент з налаштуванням інфраструктури, але довгий час залишалось питання стосовно доменів: усі відомі мені ресурси мали короткі адреси, які я знайшов у списку notbob.i2p, але цей сайт не відображає перманентні B32. Від того, про мої сервіси ніхто окрім мене не знає, від того крутити їх онлайн - сенсу мало. Трохи полиставши документацію, віднайшов деяку інформацію і організував перший домен для одного зі своїх проєктів у списку, що виявилось тривіально просто. Нижче опишу свій скромний досвід, можливо, він стане в нагоді початківцям.

Набір утиліт i2pd-tools

Для адміністрування доменів I2P, нам знадобиться утиліта i2pd-tools. В її репозиторії є детальна інструкція. Збірка з початкового коду, на момент написання матеріалу, виглядає наступним чином:

git clone https://github.com/PurpleI2P/i2pd-tools.git && cd i2pd-tools
git submodule init && git submodule update
git submodule update --init
git pull --recurse-submodules
make

Розглянемо декілька варіантів реєстрації доменів та відповідні утиліти з набору i2pd-tools.

Майнинг семантичного префіксу для домена B32

Однією з опцій створення домену - може бути майнинг семантичного префіксу для хешу B32 (актуально для EDDSA-SHA512-ED25519). Цей спосіб вартий уваги до розгляду наступних опцій реєстрації, адже згенерувавши візуально зрозумілий префікс, такий сервіс буде простіше знайти в історії браузеру. До того ж це буде канонічний, перманентний ідентифікатор I2P, що згідно оригінальної парадигми, належатиме тільки вам.

Для цієї мети, в i2pd-tools, використовується утиліта vain:

./vain domain -o mydomain.dat
  • domain - бажаний префікс для адреси типу domain1ad...2u7adq.b32.i2p: чим більша його довжина - тим складнішою буде процедура видобутку!
  • mydomain.dat - шлях до файлу, куди буде записано знайдений ключ (тунелю)
  • додатково можна вказати:
    • -t (--threads) - кількість паралельних потоків для майнингу
    • -r (--reg) - якщо потрібно генерувати по регулярному виразу замість статичного рядка

Централізовані короткі домени

В цілому, класична технологія DNS в мережі I2P відсутня в принципі. Можливо є засоби інтеграції, але вони так чи інакше пов'язані з централізацією. Короткі домени в I2P - є також частково централізованими, але таких "центрів" як мінімум два: stats.i2p (від команди Java роутера) і reg.i2p (від команди роутера C++). Працюють вони за іншим принципом, аніж класичні DNS, але при тому так само виконують свою функцію надання семантичних адрес безкоштовно, хоч і з певними умовами стосовно цензури і терміну дії (умов пролонгації).

Умови реєстраторів переписувати не буду, актуальну версію можна почитати на їх сайтах. Якщо коротко, то для реєстрації такого формату, адреса повинна бути не зайнята а ваш сервіс - доступним онлайн. В іншому випадку адресу буде звільнено для інших користувачів.

Працює така реєстрація за принципом автоматизованого створення реєстрів hosts.txt що по суті являють собою індекс псевдонімів для хешу вашого тунелю (домену B32). Коли додається новий домен, він підписується приватним ключем власника тунелю, перевіряється системою реєстратора і за виконання умов - поширюється між іншими роутерами I2P, що підтримують цього реєстратора.

Короткий домен другого рівня (2LD) з i2pd-tools/regaddr

Передбачається, що у вас є умовний сайт з ключем тунелю domain.dat, щоб згенерувати для нього підписаний запит на реєстрацію, виконуємо regaddr:

./regaddr domain.dat domain.i2p > domain.txt
  • domain.i2p - бажана адреса для domain.dat

Короткий домен третього рівня (3LD) з i2pd-tools/regaddr_3ld

Тут майже те само що й для 2LD, але нам потрібно підписати піддомен третього рівня ключем власника домену другого рівня. Виконується така операція вже в три кроки, утилітою regaddr_3ld:

./regaddr_3ld step1 sub_domain.dat sub.domain.i2p > step1.txt
./regaddr_3ld step2 step1.txt domain.dat domain.i2p > step2.txt
./regaddr_3ld step3 step2.txt sub_domain.dat > step3.txt
  • sub.domain.i2p - бажана адреса для sub_domain.dat

Реєстрація

Згенерувавши підписи, переходимо на сайти обраних реєстраторів:

  • reg.i2p
  • stats.i2p
    • якщо ви користуєтесь роутером i2pd і бачите помилку "403 Denied - Inproxy access denied. You must run I2P to access this site." - переключіть ваш роутер в режим проксі HTTP замість SOCKS (джерело)

Заповнюємо форму, вказавши наш вміст файлів domain.txt і step3.txt відповідно до типу домену і слідуємо інструкціям. Звичайно, потрібно почекати декілька днів, поки заявку буде оброблено, а інші роутери мережі оновлять локальні реєстри. Щоб не чекати самому, можна скористатись посиланнями API, що надаються при реєстрації, для миттєвого оновлення вашого локального реєстру.

На прикладі реєстратора stats.i2p, статус домену можна перевірити на сторінці нових хостів.