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 для безопасного обмена ключами через сеть.

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

Сервер

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-2.0.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

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

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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for diffiehellmanlib-2.0.tar.gz
Algorithm Hash digest
SHA256 4c350d8761ce4751dc8850ffd3cef4262141f0821f49f0bc675c6ec89e002687
MD5 f5360bd7b18262524ed13a74fa34c98a
BLAKE2b-256 72067452b9fe2ad35ff9b58a119716c48f39357b91c93d14ccbb391259e9051f

See more details on using hashes here.

File details

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

File metadata

  • Download URL: diffiehellmanlib-2.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-2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5c731ae781a18316107d8d19e88821db250993f6a47075a447896be86dd949c7
MD5 8077d3d9d32f96e72cb70cd98b8b64f3
BLAKE2b-256 5808835d7df4a1098b0fcb0be8eaaaa0210d23eb2b2d88e6542e332b974c9f47

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