nl::Weave::WeaveMessageLayer

#include <src/lib/core/WeaveMessageLayer.h>

他の Weave ノードとの通信を管理する WeaveMessageLayer クラスの定義。

概要

複数の InetLayer エンドポイントの 1 つを使用して、他の Weave ノードとの通信チャネルを確立します。

コンストラクタとデストラクタ

WeaveMessageLayer(void)
Weave Message レイヤのコンストラクタ。

公開タイプ

AcceptErrorFunct)(WeaveMessageLayer *msgLayer, WEAVE_ERROR err) typedef
void(*
この関数は受信 TCP 接続の処理中にエラーを報告するための上位層のコールバックです。
CallbackRemovedFunct)(void *listenerState) typedef
void(*
この関数は、コールバックを削除するために呼び出されます。
ConnectionReceiveFunct)(WeaveMessageLayer *msgLayer, WeaveConnection *con) typedef
void(*
この関数は受信 TCP 接続を処理するための上位層のコールバックです。
MessageLayerActivityChangeHandlerFunct)(bool messageLayerIsActive) typedef
void(*
この関数は、メッセージ レイヤのアクティビティの変更を報告するためのアプリ コールバックです。
MessageReceiveFunct)(WeaveMessageLayer *msgLayer, WeaveMessageInfo *msgInfo, PacketBuffer *payload) typedef
void(*
この関数は、UDP で Weave メッセージを受信すると呼び出される上位層のコールバックです。
ReceiveErrorFunct)(WeaveMessageLayer *msgLayer, WEAVE_ERROR err, const IPPacketInfo *pktInfo) typedef
void(*
この関数は、エラーが発生したときに呼び出される上位レイヤのコールバックです。
State{
  kState_NotInitialized = 0,
  kState_Initializing = 1,
  kState_Initialized = 2
}
enum
WeaveMessageLayer の状態。
TunneledMsgReceiveFunct)(WeaveMessageLayer *msgLayer, PacketBuffer *payload) typedef
void(*
この関数は上位層のコールバックで、ローカル UDP トンネルでトンネリング パケットを受信したときに呼び出されます。

パブリック属性

AppState
void *
アプリケーション固有の状態オブジェクトへのポインタ。
ExchangeMgr
[読み取り専用] 関連付けられている WeaveExchangeManager オブジェクト。
FabricState
[読み取り専用] 関連付けられている WeaveFabricState オブジェクトです。
IncomingConIdleTimeout
uint32_t
受信接続のデフォルトのアイドル タイムアウト(ミリ秒単位)。
Inet
InetLayer *
[読み取り専用] 関連付けられている InetLayer オブジェクト。
IsListening
bool
[読み取り専用] 受信接続やメッセージをリッスンする場合は true、それ以外の場合は false。
OnAcceptError
OnConnectionReceived
OnMessageReceived
OnReceiveError
OnUDPTunneledMessageReceived
SecurityMgr
[読み取り専用] 関連付けられている WeaveSecurityManager オブジェクト。
State
uint8_t
[読み取り専用] WeaveMessageLayer オブジェクトの状態。
SystemLayer
mDropMessage
bool
内部およびデバッグ専用設定すると、WeaveMessageLayer でメッセージが破棄されて返されます。

パブリック関数

ClearUnsecuredConnectionListener(ConnectionReceiveFunct oldOnUnsecuredConnectionReceived, CallbackRemovedFunct newOnUnsecuredConnectionCallbacksRemoved)
CloseEndpoints(void)
開いている TCP エンドポイントと UDP エンドポイントをすべて閉じます。
CreateTunnel(WeaveConnectionTunnel **tunPtr, WeaveConnection & conOne, WeaveConnection & conTwo, uint32_t inactivityTimeoutMS)
指定された 2 つの WeaveConnections を結合して、WeaveConnectionTunnel を作成します。
DecodeHeader(PacketBuffer *msgBuf, WeaveMessageInfo *msgInfo, uint8_t **payloadStart)
受信した Weave メッセージから Weave Message レイヤのヘッダーをデコードします。
EncodeMessage(WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf, WeaveConnection *con, uint16_t maxLen, uint16_t reserve)
WeaveMessageLayer ヘッダーを PacketBuffer にエンコードします。
EncodeMessage(const IPAddress & destAddr, uint16_t destPort, InterfaceId sendIntId, WeaveMessageInfo *msgInfo, PacketBuffer *payload)
Weave Message レイヤのヘッダーを PacketBuffer にエンコードします。
EphemeralUDPPortEnabled(void) const
bool
ローカルで開始された Weave UDP 交換を、エフェメラル UDP 送信元ポートから送信する必要があるかどうかを確認します。
GetConnectionPoolStats(nl::Weave::System::Stats::count_t & aOutInUse) const
void
使用中の WeaveConnections の数とプールのサイズを取得します。
IPv4ListenEnabled(void) const
bool
WeaveMessageLayer が IPv4 経由の受信通信をリッスンするように構成されているかどうかを確認します。
IPv6ListenEnabled(void) const
bool
WeaveMessageLayer が IPv4 経由の受信通信をリッスンするように構成されているかどうかを確認します。
Init(InitContext *context)
Weave Message レイヤ オブジェクトを初期化します。
IsBoundToLocalIPv4Address(void) const
bool
WeaveMessageLayer がローカル IPv4 アドレスにバインドされているかどうかを確認します。
IsBoundToLocalIPv6Address(void) const
bool
WeaveMessageLayer がローカル IPv6 アドレスにバインドされているかどうかを確認します。
IsMessageLayerActive(void)
bool
NewConnection(void)
プールから新しい WeaveConnection オブジェクトを作成します。
NewConnectionTunnel(void)
プールから新しい WeaveConnectionTunnel オブジェクトを作成します。
ReEncodeMessage(PacketBuffer *buf)
RefreshEndpoints(void)
システムのネットワーク インターフェースの現在の状態に基づいて、InetLayer エンドポイントを更新します。
ResendMessage(WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。
ResendMessage(const IPAddress & destAddr, WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。
ResendMessage(const IPAddress & destAddr, uint16_t destPort, WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。
ResendMessage(const IPAddress & destAddr, uint16_t destPort, InterfaceId interfaceId, WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。
SendMessage(WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
エンコード後、基盤となる Inetlayer UDP エンドポイントを使用して Weave メッセージを送信します。
SendMessage(const IPAddress & destAddr, WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
エンコード後、基盤となる Inetlayer UDP エンドポイントを使用して Weave メッセージを送信します。
SendMessage(const IPAddress & destAddr, uint16_t destPort, InterfaceId sendIntfId, WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
エンコード後、基盤となる Inetlayer UDP エンドポイントを使用して Weave メッセージを送信します。
SendUDPTunneledMessage(const IPAddress & destAddr, WeaveMessageInfo *msgInfo, PacketBuffer *msgBuf)
ローカル UDP トンネルを介してトンネリング パケットを送信する関数。
SetSignalMessageLayerActivityChanged(MessageLayerActivityChangeHandlerFunct messageLayerActivityChangeHandler)
void
メッセージ レイヤのアクティビティが変更されるたびに呼び出されるアプリケーション ハンドラを設定します。
SetTCPListenEnabled(bool val)
void
WeaveMessageLayer で受信 TCP 接続のリッスンを有効または無効にします。
SetUDPListenEnabled(bool val)
void
WeaveMessageLayer で、受信 UDP メッセージのリッスンを有効または無効にします。
SetUnsecuredConnectionListener(ConnectionReceiveFunct newOnUnsecuredConnectionReceived, CallbackRemovedFunct newOnUnsecuredConnectionCallbacksRemoved, bool force, void *listenerState)
Shutdown(void)
WeaveMessageLayer をシャットダウンします。
TCPListenEnabled(void) const
bool
WeaveMessageLayer が受信 TCP 接続をリッスンするように構成されているかどうかを確認します。
UDPListenEnabled(void) const
bool
WeaveMessageLayer がインバウンド UDP メッセージをリッスンするように構成されているかどうかを確認します。
UnsecuredListenEnabled(void) const
bool
エフェメラル UDP 送信元ポートからの Weave UDP 交換の開始を有効または無効にします。

静的パブリック関数

GetMaxWeavePayloadSize(const PacketBuffer *msgBuf, bool isUDP, uint32_t udpMTU)
uint32_t
メッセージ構成と指定された PacketBuffer の Weave ペイロードの最大サイズを取得します。
GetPeerDescription(char *buf, size_t bufSize, uint64_t nodeId, const IPAddress *addr, uint16_t port, InterfaceId interfaceId, const WeaveConnection *con)
void
ピアノードとそれに関連するアドレス / 接続情報を記述する文字列を作成します。
GetPeerDescription(char *buf, size_t bufSize, const WeaveMessageInfo *msgInfo)
void
ピアから受信したメッセージに関連付けられた情報に基づいて、ピアノードを記述する文字列を作成します。

クラス

nl::Weave::WeaveMessageLayer::InitContext

InitContext クラスの定義。

公開タイプ

AcceptErrorFunct

void(* AcceptErrorFunct)(WeaveMessageLayer *msgLayer, WEAVE_ERROR err)

この関数は受信 TCP 接続の処理中にエラーを報告するための上位層のコールバックです。

詳細
パラメータ
[in] msgLayer
WeaveMessageLayer オブジェクトへのポインタ。
[in] err
受信 TCP 接続の処理中に発生した WEAVE_ERROR。

CallbackRemovedFunct

void(* CallbackRemovedFunct)(void *listenerState)

この関数は、コールバックを削除するために呼び出されます。

詳細
パラメータ
[in] listenerState
アプリ状態オブジェクトへのポインタ。

ConnectionReceiveFunct

void(* ConnectionReceiveFunct)(WeaveMessageLayer *msgLayer, WeaveConnection *con)

この関数は受信 TCP 接続を処理するための上位層のコールバックです。

詳細
パラメータ
[in] msgLayer
WeaveMessageLayer オブジェクトへのポインタ。
[in] con
WeaveConnection オブジェクトへのポインタ。

MessageLayerActivityChangeHandlerFunct

void(* MessageLayerActivityChangeHandlerFunct)(bool messageLayerIsActive)

この関数は、メッセージ レイヤのアクティビティの変更を報告するためのアプリ コールバックです。

オープン エクスチェンジまたは保留中のメッセージ カウンタ同期リクエストが 1 つ以上ある場合、メッセージ レイヤはアクティブとみなされます。

詳細
パラメータ
[in] messageLayerIsActive
メッセージ レイヤが有効かどうかを示すブール値。

MessageReceiveFunct

void(* MessageReceiveFunct)(WeaveMessageLayer *msgLayer, WeaveMessageInfo *msgInfo, PacketBuffer *payload)

この関数は UDP で Weave メッセージを受信すると呼び出される上位層のコールバックです。

詳細
パラメータ
[in] msgLayer
WeaveMessageLayer オブジェクトへのポインタ。
[in] msgInfo
WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
受信したトンネリング パケットを含む PacketBuffer メッセージへのポインタ。

ReceiveErrorFunct

void(* ReceiveErrorFunct)(WeaveMessageLayer *msgLayer, WEAVE_ERROR err, const IPPacketInfo *pktInfo)

この関数は、エラーが発生したときに呼び出される上位レイヤのコールバックです。

詳細
パラメータ
[in] msgLayer
WeaveMessageLayer オブジェクトへのポインタ。
[in] err
データの受信時に WEAVE_ERROR が発生しました。
[in] pktInfo
IPPacketInfo オブジェクトへの読み取り専用ポインタ。

 State

WeaveMessageLayer の状態。

プロパティ
kState_Initialized

WeaveMessageLayer が初期化されたときの状態。

kState_Initializing

WeaveMessageLayer が初期化処理中の状態。

kState_NotInitialized

WeaveMessageLayer が初期化されていないときの状態。

TunneledMsgReceiveFunct

void(* TunneledMsgReceiveFunct)(WeaveMessageLayer *msgLayer, PacketBuffer *payload)

この関数は上位層のコールバックで、ローカル UDP トンネルでトンネリング パケットを受信したときに呼び出されます。

詳細
パラメータ
[in] msgLayer
WeaveMessageLayer オブジェクトへのポインタ。
[in] payload
受信したトンネリング パケットを含む PacketBuffer メッセージへのポインタ。

パブリック属性

AppState

void * AppState

アプリケーション固有の状態オブジェクトへのポインタ。

ExchangeMgr

WeaveExchangeManager * ExchangeMgr

[読み取り専用] 関連付けられている WeaveExchangeManager オブジェクト。

FabricState

WeaveFabricState * FabricState

[読み取り専用] 関連付けられている WeaveFabricState オブジェクトです。

IncomingConIdleTimeout

uint32_t IncomingConIdleTimeout

受信接続のデフォルトのアイドル タイムアウト(ミリ秒単位)。

Inet

InetLayer * Inet

[読み取り専用] 関連付けられている InetLayer オブジェクト。

IsListening

bool IsListening

[読み取り専用] 受信接続やメッセージをリッスンする場合は true、それ以外の場合は false。

OnAcceptError

AcceptErrorFunct OnAcceptError

OnConnectionReceived

ConnectionReceiveFunct OnConnectionReceived

OnMessageReceived

MessageReceiveFunct OnMessageReceived

OnReceiveError

ReceiveErrorFunct OnReceiveError

OnUDPTunneledMessageReceived

TunneledMsgReceiveFunct OnUDPTunneledMessageReceived

SecurityMgr

WeaveSecurityManager * SecurityMgr

[読み取り専用] 関連付けられている WeaveSecurityManager オブジェクト。

uint8_t State

[読み取り専用] WeaveMessageLayer オブジェクトの状態。

SystemLayer

System::Layer * SystemLayer

mDropMessage

bool mDropMessage

内部およびデバッグ専用設定すると、WeaveMessageLayer でメッセージが破棄されて返されます。

パブリック関数

ClearUnsecuredConnectionListener

WEAVE_ERROR ClearUnsecuredConnectionListener(
  ConnectionReceiveFunct oldOnUnsecuredConnectionReceived,
  CallbackRemovedFunct newOnUnsecuredConnectionCallbacksRemoved
)

CloseEndpoints

WEAVE_ERROR CloseEndpoints(
  void
)

開いている TCP エンドポイントと UDP エンドポイントをすべて閉じます。

その後、開いている WeaveConnections を中止し、開いている WeaveConnectionTunnel オブジェクトをすべてシャットダウンします。

関連情報:
Shutdown()

CreateTunnel

WEAVE_ERROR CreateTunnel(
  WeaveConnectionTunnel **tunPtr,
  WeaveConnection & conOne,
  WeaveConnection & conTwo,
  uint32_t inactivityTimeoutMS
)

指定された 2 つの WeaveConnections を結合して、WeaveConnectionTunnel を作成します。

作成が成功すると、コンポーネント WeaveConnection オブジェクトに対応する TCPEndPoint が WeaveConnectionTunnel に渡されます。それ以外の場合は、WeaveConnections が終了します。

詳細
パラメータ
[out] tunPtr
WeaveConnectionTunnel オブジェクトのポインタへのポインタ。
[in] conOne
1 つ目の WeaveConnection オブジェクトへの参照。
[in] conTwo
2 番目の WeaveConnection オブジェクトへの参照。
[in] inactivityTimeoutMS
Weave 接続トンネルがアイドル状態である最長時間(ミリ秒)。
戻り値
WEAVE_NO_ERROR
WeaveConnectionTunnel が正常に作成されたときに通知を受け取ります。
WEAVE_ERROR_INCORRECT_STATE
WeaveConnectionTunnel のコンポーネントの WeaveConnection オブジェクトが正しい状態でない場合。
WEAVE_ERROR_NO_MEMORY
新しい WeaveConnectionTunnel オブジェクトを作成できない場合。

DecodeHeader

WEAVE_ERROR DecodeHeader(
  PacketBuffer *msgBuf,
  WeaveMessageInfo *msgInfo,
  uint8_t **payloadStart
)

受信した Weave メッセージから Weave Message レイヤのヘッダーをデコードします。

詳細
パラメータ
[in] msgBuf
Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
[in] msgInfo
メッセージに関する情報を受け取る WeaveMessageInfo オブジェクトへのポインタ。
[out] payloadStart
デコード完了後のメッセージ バッファ内の位置を指すポインタ。
戻り値
WEAVE_NO_ERROR
メッセージ ヘッダーのデコードが成功した場合。
WEAVE_ERROR_INVALID_MESSAGE_LENGTH
渡されたメッセージ バッファの長さが無効な場合。
WEAVE_ERROR_UNSUPPORTED_MESSAGE_VERSION
Weave メッセージ ヘッダー形式のバージョンがサポートされていない場合。

EncodeMessage

WEAVE_ERROR EncodeMessage(
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf,
  WeaveConnection *con,
  uint16_t maxLen,
  uint16_t reserve
)

WeaveMessageLayer ヘッダーを PacketBuffer にエンコードします。

詳細
パラメータ
[in] msgInfo
エンコードするメッセージに関する情報を含む WeaveMessageInfo オブジェクトへのポインタ。
[in] msgBuf
Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
[in] con
WeaveConnection オブジェクトへのポインタ。
[in] maxLen
エンコードされた Weave メッセージの最大長。
[in] reserve
Weave メッセージ ヘッダーを保持するペイロードの前に予約されたスペース。
戻り値
WEAVE_NO_ERROR
メッセージが正常にエンコーディングされたかどうかがわかります。
WEAVE_ERROR_UNSUPPORTED_MESSAGE_VERSION
Weave Message ヘッダー形式のバージョンがサポートされていない場合。
WEAVE_ERROR_INVALID_MESSAGE_LENGTH
(メッセージ バッファ内のペイロード長がゼロの場合)。
WEAVE_ERROR_UNSUPPORTED_ENCRYPTION_TYPE
メッセージ ヘッダーの暗号化タイプがサポートされていない場合。
WEAVE_ERROR_MESSAGE_TOO_LONG
エンコードされたメッセージが要求された最大長よりも長くなる場合に、
WEAVE_ERROR_BUFFER_TOO_SMALL
メッセージ ペイロードの前後に十分なスペースがない場合。
other
ファブリック状態オブジェクトによって生成されたエラーは、

EncodeMessage

WEAVE_ERROR EncodeMessage(
  const IPAddress & destAddr,
  uint16_t destPort,
  InterfaceId sendIntId,
  WeaveMessageInfo *msgInfo,
  PacketBuffer *payload
)

Weave Message レイヤのヘッダーを PacketBuffer にエンコードします。

詳細
パラメータ
[in] destAddr
宛先 IP アドレス。
[in] destPort
宛先ポート。
[in] sendIntId
Weave メッセージを送信するインターフェース。
[in] msgInfo
WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
Weave メッセージのエンコーディングが成功するかどうかの基準です。
WEAVE_ERROR_UNSUPPORTED_MESSAGE_VERSION
Weave Message バージョンがサポートされていない場合。
WEAVE_ERROR_INVALID_MESSAGE_LENGTH
(メッセージ バッファ内のペイロード長がゼロの場合)。
WEAVE_ERROR_UNSUPPORTED_ENCRYPTION_TYPE
暗号化タイプがサポートされていない場合
WEAVE_ERROR_MESSAGE_TOO_LONG
エンコードされたメッセージが要求された最大長よりも長くなる場合に、
WEAVE_ERROR_BUFFER_TOO_SMALL
メッセージ ペイロードの前後に十分なスペースがない場合。
other
セッション状態の取得時にファブリック状態オブジェクトによって生成されたエラー。

EphemeralUDPPortEnabled

bool EphemeralUDPPortEnabled(
  void
) const 

ローカルで開始された Weave UDP 交換を、エフェメラル UDP 送信元ポートから送信する必要があるかどうかを確認します。

GetConnectionPoolStats

void GetConnectionPoolStats(
  nl::Weave::System::Stats::count_t & aOutInUse
) const 

使用中の WeaveConnections の数とプールのサイズを取得します。

詳細
パラメータ
[out] aOutInUse
使用中の接続数を格納する size_t の参照。

IPv4ListenEnabled

bool IPv4ListenEnabled(
  void
) const 

WeaveMessageLayer が IPv4 経由の受信通信をリッスンするように構成されているかどうかを確認します。

IPv6ListenEnabled

bool IPv6ListenEnabled(
  void
) const 

WeaveMessageLayer が IPv4 経由の受信通信をリッスンするように構成されているかどうかを確認します。

init

WEAVE_ERROR Init(
  InitContext *context
)

Weave Message レイヤ オブジェクトを初期化します。

詳細
パラメータ
[in] context
InitContext オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
発生します。
WEAVE_ERROR_INVALID_ARGUMENT
渡された InitContext オブジェクトが NULL の場合。
WEAVE_ERROR_INCORRECT_STATE
WeaveMessageLayer オブジェクトの状態が正しくない場合にスローされます。
other
エンドポイントの作成時に下位 Inet レイヤから生成されたエラー。

IsBoundToLocalIPv4Address

bool IsBoundToLocalIPv4Address(
  void
) const 

WeaveMessageLayer がローカル IPv4 アドレスにバインドされているかどうかを確認します。

IsBoundToLocalIPv6Address

bool IsBoundToLocalIPv6Address(
  void
) const 

WeaveMessageLayer がローカル IPv6 アドレスにバインドされているかどうかを確認します。

IsMessageLayerActive

bool IsMessageLayerActive(
  void
)

NewConnection

WeaveConnection * NewConnection(
  void
)

プールから新しい WeaveConnection オブジェクトを作成します。

詳細
戻り値
成功した場合は新しく作成された WeaveConnection オブジェクトへのポインタ。それ以外の場合は NULL。

NewConnectionTunnel

WeaveConnectionTunnel * NewConnectionTunnel(
  void
)

プールから新しい WeaveConnectionTunnel オブジェクトを作成します。

詳細
戻り値
成功した場合は新しく作成された WeaveConnectionTunnel オブジェクトへのポインタ。それ以外の場合は NULL。

ReEncodeMessage

WEAVE_ERROR ReEncodeMessage(
  PacketBuffer *buf
)

RefreshEndpoints

WEAVE_ERROR RefreshEndpoints(
  void
)

システムのネットワーク インターフェースの現在の状態に基づいて、InetLayer エンドポイントを更新します。

詳細
戻り値
WEAVE_NO_ERROR
エンドポイントが正常に更新された場合に 通知を受け取ることができます
InetLayer
TCP/UDP エンドポイントの作成呼び出しに基づくエラー。

ResendMessage

WEAVE_ERROR ResendMessage(
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。

詳細
パラメータ
[in] msgInfo
WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
エンコードされた Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
errors
レイヤの UDP エンドポイントから生成されます。

ResendMessage

WEAVE_ERROR ResendMessage(
  const IPAddress & destAddr,
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。

詳細
パラメータ
[in] destAddr
宛先 IP アドレス。
[in] msgInfo
WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
エンコードされた Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
errors
レイヤの UDP エンドポイントから生成されます。

ResendMessage

WEAVE_ERROR ResendMessage(
  const IPAddress & destAddr,
  uint16_t destPort,
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。

詳細
パラメータ
[in] destAddr
宛先 IP アドレス。
[in] destPort
宛先ポート。
[in] msgInfo
WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
エンコードされた Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
errors
レイヤの UDP エンドポイントから生成されます。

ResendMessage

WEAVE_ERROR ResendMessage(
  const IPAddress & destAddr,
  uint16_t destPort,
  InterfaceId interfaceId,
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

基盤となる Inetlayer UDP エンドポイントを使用して、エンコードされた Weave メッセージを再送信します。

注: 宛先アドレスが指定されていない場合は、メッセージ ヘッダーのノード ID から宛先アドレスを特定しようとします。実行できない場合は失敗します。 -宛先アドレスがローカル・ファブリックのファブリック・アドレスであり、呼び出し元が宛先ノード ID を指定しなかった場合は、宛先アドレスからそれを抽出します。

詳細
パラメータ
[in] aDestAddr
宛先 IP アドレス。
[in] destPort
宛先ポート。
[in] interfaceId
Weave メッセージを送信するインターフェース。
[in] msgInfo
WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
エンコードされた Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
errors
レイヤの UDP エンドポイントから生成されます。

SendMessage

WEAVE_ERROR SendMessage(
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

エンコード後、基盤となる Inetlayer UDP エンドポイントを使用して Weave メッセージを送信します。

詳細
パラメータ
[in] msgInfo
送信するメッセージに関する情報を含む WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
エンコードされた Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
errors
レイヤの UDP エンドポイントから生成されます。

SendMessage

WEAVE_ERROR SendMessage(
  const IPAddress & destAddr,
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

エンコード後、基盤となる Inetlayer UDP エンドポイントを使用して Weave メッセージを送信します。

注: 使用される宛先ポートは WEAVE_PORT です。 -宛先アドレスが指定されていない場合は、メッセージ・ヘッダー内のノード識別子から宛先アドレスの特定を試みる。実行できない場合は失敗します。

-宛先アドレスがローカル・ファブリックのファブリック・アドレスであり、呼び出し元が宛先ノード ID を指定しなかった場合は、宛先アドレスからそれを抽出します。

詳細
パラメータ
[in] destAddr
宛先 IP アドレス。
[in] msgInfo
送信するメッセージに関する情報を含む WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
エンコードされた Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
errors
レイヤの UDP エンドポイントから生成されます。

SendMessage

WEAVE_ERROR SendMessage(
  const IPAddress & destAddr,
  uint16_t destPort,
  InterfaceId sendIntfId,
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

エンコード後、基盤となる Inetlayer UDP エンドポイントを使用して Weave メッセージを送信します。

注: 宛先アドレスが指定されていない場合は、メッセージ ヘッダーのノード ID から宛先アドレスを特定しようとします。実行できない場合は失敗します。 -宛先アドレスがローカル・ファブリックのファブリック・アドレスであり、呼び出し元が宛先ノード ID を指定しなかった場合は、宛先アドレスからそれを抽出します。

詳細
パラメータ
[in] aDestAddr
宛先 IP アドレス。
[in] destPort
宛先ポート。
[in] sendIntfId
Weave メッセージを送信するインターフェース。
[in] msgInfo
送信するメッセージに関する情報を含む WeaveMessageInfo オブジェクトへのポインタ。
[in] payload
エンコードされた Weave メッセージを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
WEAVE_ERROR_INVALID_ADDRESS
destAddr が指定されていないか、宛先ノード ID から特定できない場合。
errors
レイヤの UDP エンドポイントから生成されます。

SendUDPTunneledMessage

WEAVE_ERROR SendUDPTunneledMessage(
  const IPAddress & destAddr,
  WeaveMessageInfo *msgInfo,
  PacketBuffer *msgBuf
)

ローカル UDP トンネルを介してトンネリング パケットを送信する関数。

トンネリングされた IPv6 データ メッセージを UDP で送信します。

詳細
パラメータ
[in] msgInfo
WeaveMessageInfo オブジェクトへのポインタ。
[in] destAddr
UDP トンネルの宛先の IPAddress。
[in] msgBuf
送信するパケットを保持する PacketBuffer オブジェクトへのポインタ。
戻り値
WEAVE_NO_ERROR
メッセージをネットワーク層に正常に送信するうえで重要です。
WEAVE_ERROR_INVALID_ADDRESS
destAddr が指定されていないか、宛先ノード ID から特定できない場合。
errors
レイヤの UDP エンドポイントから生成されます。

SetSignalMessageLayerActivityChanged

void SetSignalMessageLayerActivityChanged(
  MessageLayerActivityChangeHandlerFunct messageLayerActivityChangeHandler
)

メッセージ レイヤのアクティビティが変更されるたびに呼び出されるアプリケーション ハンドラを設定します。

具体的には、次のたびにアプリケーションに通知されます。

  • オープンエクスチェンジの数の変化です
  • 保留中のメッセージ カウンタ同期リクエストの数が 0 から少なくとも 1 に変わり、さらに 0 に戻ります。ハンドラは、進行中の Weave 会話や保留中の応答があるかどうかを示す一般的なシグナルとして機能します。ハンドラは、WeaveMessageLayer が初期化された後に設定する必要があります。WeaveMessageLayer をシャットダウンすると、現在のハンドラがクリアされます。

詳細
パラメータ
[in] messageLayerActivityChangeHandler
メッセージ レイヤのアクティビティが変更されるたびに呼び出される関数へのポインタ。
戻り値
None.

SetTCPListenEnabled

void SetTCPListenEnabled(
  bool val
)

WeaveMessageLayer で受信 TCP 接続のリッスンを有効または無効にします。

注: RefreshEndpoints() は、TCP リスニング状態が変更された後に呼び出す必要があります。

SetUDPListenEnabled

void SetUDPListenEnabled(
  bool val
)

WeaveMessageLayer で、受信 UDP メッセージのリッスンを有効または無効にします。

注: RefreshEndpoints() は、UDP リスニング状態が変更された後に呼び出す必要があります。

SetUnsecuredConnectionListener

WEAVE_ERROR SetUnsecuredConnectionListener(
  ConnectionReceiveFunct newOnUnsecuredConnectionReceived,
  CallbackRemovedFunct newOnUnsecuredConnectionCallbacksRemoved,
  bool force,
  void *listenerState
)

シャットダウン

WEAVE_ERROR Shutdown(
  void
)

WeaveMessageLayer をシャットダウンします。

開いている Inet レイヤのエンドポイントをすべて閉じ、すべての上位レイヤのコールバック、メンバー変数、オブジェクトをリセットします。Shutdown() を呼び出すと、WeaveMessageLayer オブジェクトは終了します。

TCPListenEnabled

bool TCPListenEnabled(
  void
) const 

WeaveMessageLayer が受信 TCP 接続をリッスンするように構成されているかどうかを確認します。

UDPListenEnabled

bool UDPListenEnabled(
  void
) const 

WeaveMessageLayer がインバウンド UDP メッセージをリッスンするように構成されているかどうかを確認します。

UnsecuredListenEnabled

bool UnsecuredListenEnabled(
  void
) const 

エフェメラル UDP 送信元ポートからの Weave UDP 交換の開始を有効または無効にします。

注: RefreshEndpoints() は、エフェメラル ポートの状態が変更された後に呼び出す必要があります。保護されていないリスニングが有効になっているかどうかを確認します。

WeaveMessageLayer

 WeaveMessageLayer(
  void
)

Weave Message レイヤのコンストラクタ。

静的パブリック関数

GetMaxWeavePayloadSize

uint32_t GetMaxWeavePayloadSize(
  const PacketBuffer *msgBuf,
  bool isUDP,
  uint32_t udpMTU
)

メッセージ構成と指定された PacketBuffer の Weave ペイロードの最大サイズを取得します。

返される最大ペイロード サイズは、指定された PacketBuffer 内のペイロードで利用可能な領域を超えることはありません。

メッセージが UDP の場合、返される最大ペイロード サイズは、指定した UDP MTU をオーバーフローしない Weave メッセージになりません。

最後に、返された最大ペイロード サイズでは、Weave メッセージの最大サイズをオーバーフローする Weave メッセージになることはありません。

詳細
パラメータ
[in] msgBuf
メッセージ ペイロードの書き込み先となる PacketBuffer へのポインタ。
[in] isUDP
メッセージが UDP メッセージの場合は true。
[in] udpMTU
UDP MTU のサイズ。isUDP が false の場合は無視されます。
戻り値
Weave ペイロードサイズの上限を指定します

GetPeerDescription

void GetPeerDescription(
  char *buf,
  size_t bufSize,
  uint64_t nodeId,
  const IPAddress *addr,
  uint16_t port,
  InterfaceId interfaceId,
  const WeaveConnection *con
)

ピアノードとそれに関連するアドレス / 接続情報を記述する文字列を作成します。

生成される文字列の形式は次のとおりです。

 ([]:%, con )

詳細
パラメータ
[in] buf
文字列を書き込むバッファへのポインタ。指定したバッファは、少なくとも kWeavePeerDescription_MaxLength 以上のサイズにしてください。指定されたバッファが小さいと、文字列は適合するように切り捨てられます。いずれの場合も、出力には NUL 終端文字が含まれます。
[in] bufSize
buf が指すバッファのサイズ。
[in] nodeId
出力されるノード ID。
[in] addr
出力される IP アドレスへのポインタ。IP アドレスを表示しない場合は NULL を返します。
[in] port
出力する IP ポート番号。addr が NULL の場合、ポート番号は出力されません。
[in] interfaceId
印刷するインターフェースを識別する InterfaceId。出力文字列には、基盤となるネットワーク スタックで認識されているインターフェースの名前が含まれます。インターフェース ID が INET_NULL_INTERFACEID の場合、または addr が NULL の場合、インターフェース名は出力されません。
[in] con
ロギング ID を出力する WeaveConnection オブジェクトへのポインタ。出力しない場合は NULL を返します。

GetPeerDescription

void GetPeerDescription(
  char *buf,
  size_t bufSize,
  const WeaveMessageInfo *msgInfo
)

ピアから受信したメッセージに関連付けられた情報に基づいて、ピアノードを記述する文字列を作成します。

詳細
パラメータ
[in] buf
文字列を書き込むバッファへのポインタ。指定したバッファは、少なくとも kWeavePeerDescription_MaxLength 以上のサイズにしてください。指定されたバッファが小さいと、文字列は適合するように切り捨てられます。いずれの場合も、出力には NUL 終端文字が含まれます。
[in] bufSize
buf が指すバッファのサイズ。
[in] msgInfo
メッセージに関する情報を含む WeaveMessageInfo 構造体へのポインタ。