前回までには、NFTトークンの扱いについて説明しました。
今回はFireflyのイベント管理機能について紹介します。
イベント駆動型プログラミングモデル
Fireflyは、非常に優れたプログラムの一つです。その中でも、最も重要な概念は「イベント駆動型プログラミングモデル」です。簡単に説明すると、Fireflyでは参加者がメッセージやトランザクション(データのやり取りのようなもの)を相互に送り合います。これらのメッセージやトランザクションは、ブロックチェーン内外で送受信できます。そして、これらのイベントが集約され、確認されると、他の参加者に何らかの処理をトリガーします。この仕組みにより、多数の参加者が関与する複雑なシステムやビジネスプロセスを調整することが可能になります。Fireflyは各参加者に、彼ら自身のプライベートヒストリーを提供します。このヒストリーには、ブロックチェーンをバックエンドとするトランザクションだけでなく、完全にオフチェーンのメッセージのやり取りも含まれています。
今回の説明では、WebSockクライアントを使用します。
※ 「https://hyperledger.github.io/firefly/tutorials/events.html Listen for events」より引用
前提
- swagger UIの利用
- スマートコントラクトEVMイベントの基礎知識
- chrome拡張機能にBrowser WebSocket Clientがインストール済(Browser WebSocket Client)
EVMのイベントについて、どのような挙動になるか実際に動作するシンプルなアプリをこちらで紹介しています。
参考までに参照ください。
Qiita記事:ブロックチェーン・ブリッジを実装してみる
edevスタックの準備
ここでは、前回構築したBinance testnet bscスタックはとは別に、Fireflyの標準的な環境を使用します。
以下の手順によりスタックを構築します。
以下のコマンドにより、edevスタックの作成と起動を行います。
$ sudo service docker start
$ ff init
initializing new FireFly stack...
stack name: edev
You selected edev
number of members: 3
Stack 'edev' created!
To start your new stack run:
$ ff start edev
Your docker compose file for this stack can be found at: /home/ubuntu/.firefly/stacks/edev/docker-compose.yml
$ff start edev
done
Web UI for member '0': http://127.0.0.1:5000/ui
Sandbox UI for member '0': http://127.0.0.1:5109
Web UI for member '1': http://127.0.0.1:5001/ui
Sandbox UI for member '1': http://127.0.0.1:5209
Web UI for member '2': http://127.0.0.1:5002/ui
Sandbox UI for member '2': http://127.0.0.1:5309
To see logs for your stack run:
ff logs edev
イベント受信の動作確認
イベント受信の動作確認は以下の手順で行います。
- Browser WebSocket Clientを使用しFireFly WebSocketへ接続します。
- Sandbox UIを使用してメッセージを送信します。
- Browser WebSocket Clientでイベントの受信状態を確認します。
イベント監視対象を指定
ChromeブラウザからBrowser WebSocket Clientを起動します。
ここではイベント監視対象として、Defaultネームスペースで発生する事象を監視します。
以下の文字列を入力して、WebSockへ接続します。
ws://localhost:5000/ws?namespace=default&ephemeral&autoack&filter.events=message_confirmed
接続状態
ServerURLに上記wsアドレスを入力します。
Connectボタンをクリックすると、接続が行われセッションが開始されます。
Sandbox UIからメッセージを送信
BandBoxhttp http://127.0.0.1:5109をブラウザから開きます。
Messageエリアが表示されますので、送信するメッセージを入力します。
画面中央のjsonの内容に入力した文字列がセットされていることを確認し、Runボタンをクリックします。
ここで入力した文字列とともにイベントが発生します。イベントの状態は画面右側で確認することができます。
イベント受信状態を確認
ChromeブラウザのBrowser WebSocket Client画面に戻ります。
画面を下にスクロールすると、メッセージが1件表示されていることが確認できます。
イベントを受信する条件の指定
上記はメッセージ処理された際のエベントを全て受信していました。
ここでは、メッセージに含まれる特定の情報に合致した場合のみイベントを受信するようにします。
ここでのシナリオとして、メッセージを送信する際にTAG項目に「RELAY」と指定されているメッセージのみハンドリングするようにします。
サブスクリプションのセットアップ
特定の条件を受け取るためのサブスクリプションを登録します。
swaggerUIを開きます。
画面から/namespaces/{ns}/subscriptionsを探します。
以下のテキストを登録します。
"name"に"relay"を指定します。ここで入力した文字列をBrowser WebSocket Clientで監視する際のパラメータに指定します。
"tag"に"RELAY"を指定します。ここで入力した文字列がメッセージ受信時のフィルタとして処理されます。
{
"transport": "websockets",
"name": "relay",
"filter": {
"blockchainevent": {
"listener": ".*",
"name": ".*"
},
"events": ".*",
"message": {
"author": ".*",
"group": ".*",
"tag": "RELAY",
"topics": ".*"
},
"transaction": {
"type": ".*"
}
},
"options": {
"firstEvent": "newest",
"readAhead": 50
}
}
イベント監視対象を指定
ChromeブラウザからBrowser WebSocket Clientを起動します。
以下のnameにrelay文字列を入力して、WebSockへ接続します。
ws://localhost:5000/ws?namespace=default&autoack&name=relay
接続状態
ServerURLに上記wsアドレスを入力します。
Connectボタンをクリックすると、接続が行われセッションが開始されます。
Sandbox UIからメッセージを送信
BandBoxhttp http://127.0.0.1:5109をブラウザから開きます。
Messageエリアが表示されますので、送信するメッセージを入力します。
ここで、TAGエリアに「RELAY」を入力します。
入力後、画面中央の「Run」ボタンをクリックしメッセージを送信します。
イベント受信状態を確認
ChromeブラウザのBrowser WebSocket Client画面に戻ります。
画面を下にスクロールすると、メッセージが1件表示されていることが確認できます。
なお、TAGにRELAY以外の文字列(NONEなど)を入力して送信するとイベントが表示されないことが確認できます。
イベントの動作確認は以上です。
次回は
今回は、イベントの扱いについて紹介しました。
イベントをハンドリングする方法やサブスクリプションのフィルタの定義など、用意されているパラメータを確認すると、さらに多くの条件を指定することが可能のようです。今回の動作確認はここまでにしたいと思います。
次回は、カスタムスマートコントラクトの登録と利用について紹介する予定です。