Skip to main content

Simplified number generation library for the Diffie-Hellman protocol.

Project description

Diffie - Hellman Python/C++ Library

Описание

Эта библиотека реализует криптографический протокол Diffie-Hellman для безопасного обмена ключами через незащищённый канал. Она использует C++ для высокой скорости генерации больших простых чисел и Python-обёртку (wrapper) для упрощённой интеграции.

Основные возможности

  • Генерация параметров: простое число ( p ), основание ( g ), приватные ключи ( a, b ), публичные ключи ( A, B ).
  • Обмен ключами: функции для организации серверной и клиентской части через сокеты.
  • Поддержка хэширования: автоматическое хэширование общего ключа для безопасности.
  • Кроссплатформенность: поддержка Windows, Linux, и архитектур x86, x64, ARMv7, ARM64.

Установка

Для установки библиотеки используйте:

pip install diffiehellmanlib

Использование

Импорт библиотеки

from diffiehellmanlib import wrapper

Пример 1: Генерация параметров

Генерация ( p ) и ( g ):

p, g = wrapper.generate_p_g(2048)
print(f"Generated p: {p}, g: {g}")

Пример 2: Генерация публичного и приватного ключей

a = wrapper.generate_a_or_b(p, g)
A = wrapper.generate_A_or_B(p, g, a)
print(f"Private key (a): {a}, Public key (A): {A}")

Пример 3: Генерация общего ключа

После обмена ( A ) и ( B ):

shared_key = wrapper.generate_shared_key(B, p, g, a)
print(f"Shared key: {shared_key}")

Обмен ключами через сокеты

Функциональность доступна с версии 2.0

Библиотека предоставляет функции exchange_server и exchange_client для безопасного обмена ключами через сеть. В версии 3.0 проврка не хешей цифр, а подпись полностью сообщения через cryptography. Должно усилить безопасность.

Пример использования

Сервер

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_server("0.0.0.0", 5000, "127.0.0.1")
print(f"Shared key: {shared_key}")
  • IP: "0.0.0.0" позволяет принимать соединения на всех интерфейсах.
  • Порт: 5000 — порт для ожидания соединений.
  • Таргет IP: "127.0.0.1" — IP-адрес клиента, с которым разрешено соединение.

Клиент

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_client("127.0.0.1", 5000)
print(f"Shared key: {shared_key}")
  • Таргет IP сервера: "127.0.0.1".
  • Порт сервера: 5000.

Алгоритм работы

  1. Сервер
    • Генерирует ( p, g ), приватный ключ ( a ), и публичный ключ ( A ).
    • Отправляет их клиенту в формате JSON вместе с хэшами.
  2. Клиент
    • Проверяет корректность данных и генерирует ( b ), ( B ).
    • Отправляет публичный ключ ( B ) серверу.
  3. Общий ключ
    • Сервер и клиент рассчитывают общий ключ ( K ) с использованием своих приватных и чужих публичных ключей.

Формат сообщений

Сообщения передаются в формате JSON:

  • От сервера:
    {
        "error": false,
        "numbers": {"p": p, "g": g, "A": A},
        "hash": {"p": "hash_p", "g": "hash_g", "A": "hash_A"},
        "timeset": timeset
    }
    
  • От клиента:
    {
        "error": false,
        "numbers": {"B": B},
        "hashes": {"B": "hash_b"},
        "timeset": timeset
    }
    

Примеры полного использования (Ручной режим)

Alice (Серверная часть)

from diffiehellmanlib import wrapper

p, g = wrapper.generate_p_g(2048)
a = wrapper.generate_a_or_b(p, g)
A = wrapper.generate_A_or_B(p, g, a)

# Отправляем p, g, A Bob-у и получаем B
shared_key = wrapper.generate_shared_key(B, p, g, a)
print(f"Shared key: {shared_key}")

Bob (Клиентская часть)

from diffiehellmanlib import wrapper

# Получаем p, g, A от Alice
b = wrapper.generate_a_or_b(p, g)
B = wrapper.generate_A_or_B(p, g, b)

# Отправляем B Alice и рассчитываем общий ключ
shared_key = wrapper.generate_shared_key(A, p, g, b)
print(f"Shared key: {shared_key}")

Пример полного использования (Автоматический режим)

Alice (Серверная часть)

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_server(IP_alice, port, IP_bob)

print(f"Shared key: {shared_key}")

Bob (Клиентская часть)

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_client(IP_alice, port)

print(f"Shared key: {shared_key}")

Лицензия

MIT License


Авторы

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

diffiehellmanlib-3.0.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

diffiehellmanlib-3.0-py3-none-any.whl (4.9 MB view details)

Uploaded Python 3

File details

Details for the file diffiehellmanlib-3.0.tar.gz.

File metadata

  • Download URL: diffiehellmanlib-3.0.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for diffiehellmanlib-3.0.tar.gz
Algorithm Hash digest
SHA256 763d5e0fef797b3a4cb7d6927cdd2e72d08191ef168e59819a65018d05e7a562
MD5 bf2da72fb80d7f95217ff9e95f5511f8
BLAKE2b-256 797c2d4e9144dd80f3ed400aa486667220251c44c2a403d3d1dc34d6e325ce14

See more details on using hashes here.

File details

Details for the file diffiehellmanlib-3.0-py3-none-any.whl.

File metadata

  • Download URL: diffiehellmanlib-3.0-py3-none-any.whl
  • Upload date:
  • Size: 4.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for diffiehellmanlib-3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 82b1bcbde3d84605b8780339b5dfa5c3670973dffe2be22870e467de0539067c
MD5 2e1703eb09be01fece6c7637ad1d7d78
BLAKE2b-256 23d6c4be857647ac7d606276a1ad507480c709b296c3caaba6ee0bac361a378f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page