# Rippling XRP Ledgerでは、「Rippling」とは同一通貨の[トラストライン](/ja/docs/concepts/tokens/fungible-tokens)を有する複数の接続当事者間での非可分なネット決済のプロセスを指しています。Ripplingはトークンの基幹的なプロセスです。Ripplingを利用すれば、同一イシュアーを信頼するユーザは、そのイシュアーを受動的な仲介機関として発行済み残高を相互に送金できるようになります。Ripplingは、受動的かつ双方向の[通貨取引オーダー](/ja/docs/concepts/tokens/decentralized-exchange/offers)のようなもので、制限がなく、通貨コードが同一でイシュアーが異なる2つの通貨間の為替レートは1:1です。 Ripplingは、支払[パス](/ja/docs/concepts/tokens/fungible-tokens/paths)でのみ発生します。[XRP間の直接決済](/ja/docs/concepts/payment-types/direct-xrp-payments)にはRipplingは使用されません。 発行アカウント以外のアカウントでは、Ripplingが望ましくない場合があります。Ripplingを使えば、他のユーザが同一通貨のイシュアー間で債権債務を移動できるようになるためです。このため、アカウントの[DefaultRippleフラグ](#defaultripple%E3%83%95%E3%83%A9%E3%82%B0)を有効にして、アカウントがデフォルトでRipplingを有効にしない限り、デフォルトでは[NoRippleフラグ](#noripple%E3%83%95%E3%83%A9%E3%82%B0)により着信トラストラインでのRipplingが無効になっています。 別のアドレスへのトラストラインを作成する場合、そのトラストラインのあなたの側でRipplingをブロックするには、tfSetNoRippleフラグを明示的に有効にする必要があります。 ## Ripplingの例 「Rippling」は、支払いを行うために複数のトラストラインが調整されたときに発生します。たとえば、AliceがCharlieにお金を借りており、さらにAliceはBobからもお金を借りている場合、XRP Ledgerではトラストラインは次のようになります: [](/assets/noripple-01.04726bfaef98a92eae3f05f6cc8fef4858906b3a0ae7bb0eee298b3f5f96a719.ac57e6ef.svg) BobがCharlieに$3を支払いたい場合、BobはAliceに対して「Alice、君に貸しているお金の中から$3をCharlieに支払ってくれ。」と言えます。AliceはBobに借りているお金の一部をCharlieに送金します。最終的にはトラストラインは次のようになります。 [](/assets/noripple-02.1953e85ff4f44374629f95216bb4ba493dac30a2d2a555aa4db9c4f9cf11bba2.ac57e6ef.svg) 2つのアドレスが、アドレス間のトラストライン上の残高を調整することで相互に支払うこのプロセスを「Rippling」と呼びます。これはXRP Ledgerの有用で重要な機能です。Ripplingは、同一の[通貨コード](/ja/docs/references/protocol/data-types/currency-formats#%E9%80%9A%E8%B2%A8%E3%82%B3%E3%83%BC%E3%83%89)を使用するトラストラインによってアドレスがリンクされている場合に起こります。イシュアーが同一でなくてもかまいません。実際、大規模なチェーンでは常にイシュアーが変更されます。 ## NoRippleフラグ 発行アカウント以外のアカウント、特に手数料やポリシーが異なる複数のイシュアーの残高を保有している流動性プロバイダーは、一般的に残高がRipplingされることを望みません。 「NoRipple」フラグは、トラストライン上の設定です。2つのトラストラインの両方で、同じアドレスによってNoRippleが有効に設定されている場合、第三者からの支払を、これらのトラストラインでこのアドレスを通じて「Rippling」することはできません。これにより、同一通貨の複数イシュアー間で流動性プロバイダーの残高が予期せず移動されるのを防ぎます。 アカウントは1つのトラストラインでNoRippleを無効にできます。これにより、そのトラストラインを含む任意のペアを通じてのRipplingが可能になります。アカウントにてデフォルトでRipplingを有効にするには、[DefaultRippleフラグ](#defaultripple%E3%83%95%E3%83%A9%E3%82%B0)を有効にします。 たとえば、Emilyが2つの異なる金融機関から発行されたお金を保有しているとします。 [](/assets/noripple-03.892fdd92148fd9e48c8e4e9ecc0a2a73ee532817dd1594c9b7d06134350e2bee.ac57e6ef.svg) CharlieはDanielに支払うため、Emilyのアドレスを通じてRipplingします。たとえば、CharlieがDanielに$10を支払うとします: [](/assets/noripple-04.6b63e6600d346d94da22c572a8fb6bc548bc1bad8bece52ea94a77aaa31ead45.ac57e6ef.svg) この場合、CharlieやDanielと面識のないEmilyは驚く可能性があります。さらに、金融機関Aが金融機関Bよりも高い出金手数料をEmilyに請求した場合、Emilyがコストを負担することになる可能性があります。NoRippleフラグはこの状況を回避するためのフラグです。Emilyが両方のトラストラインでNoRippleフラグを設定していれば、この2つのトラストラインを使用しているEmilyのアドレスを通じて、支払がRipplingされることはありません。 例: [](/assets/noripple-05.889dcc3a78371a4929814b7ee8850a1dea01f825503f6251d7f23a4a01c1120c.ac57e6ef.svg) このように、CharlieがEmilyのアドレスを通じてRipplingし、Danielに支払うという上記のシナリオは、不可能になります。 ### 詳細 NoRippleフラグにより特定のパスが無効になり、無効になったパスは支払に使用できなくなります。パスが無効であると見なされるのは、パスが、あるアドレスに対してNoRippleが有効となっているトラストラインを通じて、そのアドレスノードに入り**かつ**そのノードから出た場合に限られます。 [](/assets/noripple-06.ja.5bf3e059e91fdcfbe469638504ff0a8dd3b2737b146c01d14414ab04fe280855.ac57e6ef.svg) ## DefaultRippleフラグ DefaultRippleフラグは、デフォルトで着信トラストラインでのRipplingを有効にするアカウント設定です。ゲートウェイやその他の通貨イシュアーは、顧客が通貨を相互に送金できるようにするには、このフラグを有効にする必要があります。 アカウントのDefaultRipple設定は、他者があなたに対してオープンしたトラストラインにのみ影響し、あなたが作成するトラストラインには影響しません。アカウントのDefaultRipple設定を変更する場合、変更前に作成したトラストラインでは既存のNoRipple設定が維持されます。アドレスの新しいデフォルトに合わせてトラストラインのNoRipple設定を変更するには、[TrustSetトランザクション](/ja/docs/references/protocol/transactions/types/trustset)を使用します。 ## NoRippleを使用する ### NoRippleを有効/無効にする トラストライン上のNoRippleフラグは、トラストライン上のアドレスの残高がプラスまたはゼロの場合に限り、有効にできます。これにより、この機能を悪用してトラストラインの残高に示される債務を不履行にすることができなくなります。(ただし、アドレスを放棄すれば債務を不履行にできます。) [`rippled` API](/ja/docs/references/http-websocket-apis)でNoRippleフラグを有効にするには、`tfSetNoRipple`フラグを設定した[TrustSetトランザクション](/ja/docs/references/protocol/transactions/types/trustset)を送信します。NoRippleを無効にする(Ripplingを有効にする)には、`tfClearNoRipple`フラグを使用します。 ### NoRippleステータスの確認 相互に信頼し合っている2つのアカウントの場合、NoRippleフラグはアカウントごとに管理されます。 [`rippled` API](/ja/docs/references/http-websocket-apis)でアドレスに関連付けられているトラストラインを確認するには、[account_linesメソッド](/ja/docs/references/http-websocket-apis/public-api-methods/account-methods/account_lines)を使用します。各トラストラインの`no_ripple`フィールドには、現在のアドレスがそのトラストラインに対してNoRippleフラグを有効にしているか否かが表示され、`no_ripple_peer`フィールドには、取引相手がNoRippleフラグを有効にしているか否かが表示されます。 ## 関連項目 - **コンセプト:** - [パス](/ja/docs/concepts/tokens/fungible-tokens/paths) - **リファレンス:** - [account_linesメソッド](/ja/docs/references/http-websocket-apis/public-api-methods/account-methods/account_lines) - [account_infoメソッド](/ja/docs/references/http-websocket-apis/public-api-methods/account-methods/account_info) - [AccountSetトランザクション](/ja/docs/references/protocol/transactions/types/accountset) - [TrustSetトランザクション](/ja/docs/references/protocol/transactions/types/trustset) - [AccountRootのフラグ](/ja/docs/references/protocol/ledger-data/ledger-entry-types/accountroot#accountroot%E3%81%AE%E3%83%95%E3%83%A9%E3%82%B0) - [RippleState(トラストライン)のフラグ](/ja/docs/references/protocol/ledger-data/ledger-entry-types/ripplestate#ripplestate%E3%81%AE%E3%83%95%E3%83%A9%E3%82%B0)