したがって、C ++でのI2Pの実装は常に緊急の課題でした。 多くの試みの中で、「Purple I2P」(Purple I2P)は現在最も成功しており、実用に適しています。 名前は、I2Pアイコン上のシャツの色によって決まり、公式のI2Pと区別します。色は赤で、このI2Pの実装を使用するアプリケーションのファミリを示します。 i2pdは汎用I2Pルーターです。
以前に、このようなシステムを構築するために必要なコンポーネントを検討しました。 つまり、I2Pネットワークで動作するには、次の機能を実装するルーターが必要です。
- 他のノードへの直接接続を担当するトランスポート。 通常はインターネット経由ですが、Thorなどの他のネットワーク経由でも可能です
- データのトンネリングと送信
- 最新の他のノードのリストを検索して維持する
- 他の参加者の通過トラフィックの転送
個人データを交換する必要がある場合は、ルーター上で、 ここで説明する追加のプロトコルが必要な操作用のアドレスを配置する必要があります。 ただし、クライアントと対話するには、1回のデータ転送では十分ではありません。ローカルアドレスを管理し、リモートアドレスにアクセスできる必要があります。 公式のI2Pでは、これは個別の外部アプリケーションのセットとして実装されますが、i2pdではこれらのサービスが組み込まれています。 現在実装されています:
- HTTPプロキシ
- I2Pトンネル。ローカルマシンのTCPポートへのアドレスのマッピングです。
- SAMはコマンドラインインターフェイスです。 もっと詳しく考えてみましょう。
SAMプロトコル
SAM (Simple Anonymous Messaging)は長い間、C ++アプリケーションからのI2Pとの完全な相互作用に適した唯一のプロトコルでした。 より正確には、実際には同じ概念を実装するBOBがありますが、SAMほど一般的ではありません。
公式のI2Pが推奨するI2CPプロトコルは、低レベルのプロトコルであり、Javaで記述された外部ストリーム実装も使用するため、これらの目的にはほとんど使用されません。 現時点ではC ++バージョンはありません。 将来的に、i2pdからのストリームの実装を、I2CPを介して動作する別個のライブラリーの形式で配置することが計画されています。
SAMには、すぐに使用できるC ++ライブラリi2psamがあります。これは、暗号通貨がトラフィックを隠すために積極的に使用します。
欠陥と批判にもかかわらず、SAMは紫色のI2Pで最も重要なプロトコルです。SAMとi2pdを使用する既存のC ++アプリケーションのバンドルにより、追加の変更なしにJavaの使用をすぐに停止できるためです。
最も人気のあるもの:
- I2pメッセンジャー
- iMule
- ビットコイン-I2P
一般に、プロトコルは、コマンドモードまたはデータ転送モードで動作するソケットを表すクライアントの観点から、その名前を完全に正当化します。 クライアントがソケットを削除すると、対応するI2Pコンストラクトが削除されます。 作業は、クライアントが指定したキーを使用してローカルアドレスを作成するか、ランダムに生成されたキーを使用して一時アドレスを作成することから始まります。 次に、このアドレスを使用して、リモートアドレスとの接続を確立するか、リモートアドレスからの次の着信接続を待つことができます。 その後、ソケットはデータ転送モードになります。
このようなインターフェイスは、外部ルーターを使用せずにAPIとして実装し、アプリケーションから直接使用でき、エンドユーザーにI2P設定の詳細を強制することなく、既成のソリューションとして配布できます。
実装予定
- Javaアプリケーションがi2pdを介して動作できるようにするI2CP
- より高速で信頼性の高いトンネルを構築するためのノードプロファイラー
- 更新可能なアドレス帳
- データグラム
- フラッドフィルモード
リリース0.1.0
実際、この記事の主なアイデアは、上記の機能を含むi2pdの最初の安定リリースがリリースされたことです。
Ubuntuのバイナリ:
launchpad.net/~i2p.packages/+archive/ubuntu/i2p
Debian用
deb.i2p2.no
他のすべてのプラットフォームの場合は、 こちらからソースからコンパイルします 。
Crypto ++およびboostライブラリが必要です。