diff --git a/_code-samples/add-amm-lp/js/add-amm-lp.js b/_code-samples/add-amm-lp/js/add-amm-lp.js deleted file mode 100644 index be6697873a0..00000000000 --- a/_code-samples/add-amm-lp/js/add-amm-lp.js +++ /dev/null @@ -1,185 +0,0 @@ -const xrpl = require('xrpl') - -const WS_URL = 'wss://s.altnet.rippletest.net:51233/' -const EXPLORER = 'testnet.xrpl.org' // Optional, for linking - -async function main() { - -// Define the network client -const client = new xrpl.Client(WS_URL) -await client.connect() - -// Get an address funded with XRP from the Faucet -console.log("Requesting address from the faucet...") -const wallet = (await client.fundWallet()).wallet - -// To use an existing account, use code such as the following: -// const wallet = xrpl.Wallet.fromSeed(process.env['USE_SEED']) - -// Acquire TST tokens -console.log("------- Acquire TST tokens ---------") - -const offer = { - "TransactionType": "OfferCreate", - "Account": wallet.address, - "TakerPays": { - currency: "TST", - issuer: "rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd", - value: "5" - }, - // Drops calculation is (amount to buy * price per token * amm trading fees) - "TakerGets": xrpl.xrpToDrops(58) -} - -const prepared_offer = await client.autofill(offer) -console.log("Prepared transaction:", JSON.stringify(prepared_offer, null, 2)) -const signed_offer = wallet.sign(prepared_offer) -console.log("Sending OfferCreate transaction...") -const result_offer = await client.submitAndWait(signed_offer.tx_blob) -console.log(result_offer) -if (result_offer.result.meta.TransactionResult == "tesSUCCESS") { - console.log(`Transaction succeeded: - https://${EXPLORER}/transactions/${signed_offer.hash}`) -} else { - throw `Error sending transaction: ${result_offer}` -} - -// Deposit assets into AMM -console.log("------- Put more assets into the AMM -------") - -const ammdeposit = { - "TransactionType": "AMMDeposit", - "Asset": { - currency: "XRP" - }, - "Asset2": { - currency: "TST", - issuer: "rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd" - }, - "Account": wallet.address, - // Drops calculation is (amount to deposit * price per token) - "Amount": xrpl.xrpToDrops(25), - "Amount2": { - currency: "TST", - issuer: "rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd", - value: "2.5" - }, - "Flags": 0x00100000 -} - -const prepared_deposit = await client.autofill(ammdeposit) -console.log("Prepared transaction:", JSON.stringify(prepared_deposit, null, 2)) -const signed_deposit = wallet.sign(prepared_deposit) -console.log(`Sending AMMDeposit transaction ...`) -const lp_deposit = await client.submitAndWait(signed_deposit.tx_blob) -console.log(lp_deposit) - -if (lp_deposit.result.meta.TransactionResult == "tesSUCCESS") { - console.log(`Transaction succeeded: - https://${EXPLORER}/transactions/${signed_deposit.hash}`) -} else { - throw `Error sending transaction: ${lp_deposit}` -} - -// Vote on fees -console.log("------- Vote for a 0.6% trading fee -------") - -const ammvote = { - "TransactionType": "AMMVote", - "Asset": { - "currency": "XRP" - }, - "Asset2": { - "currency": "TST", - "issuer": "rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd" - }, - "Account": wallet.address, - "TradingFee": 600 -} - -const prepared_vote = await client.autofill(ammvote) -console.log("Prepared transaction:", JSON.stringify(prepared_vote, null, 2)) -const signed_vote = wallet.sign(prepared_vote) -console.log(`Sending AMMVote transaction ...`) -const response_vote = await client.submitAndWait(signed_vote.tx_blob) -if (response_vote.result.meta.TransactionResult == "tesSUCCESS") { - console.log(`Transaction succeeded: - https://${EXPLORER}/transactions/${signed_vote.hash}`) -} else { - console.error("Error sending transaction:", response_vote) -} - -// Get LP tokens value -console.log("------- Calculate value of my LP tokens -------") - -const lp_deposit_data = lp_deposit.result.meta.AffectedNodes - -let LPTokens = null; - -for (const node of lp_deposit_data) { - if (node.CreatedNode) { - LPTokens = Math.abs(node.CreatedNode.NewFields.Balance.value); - break; - } -} - -const amm_info = (await client.request({ - "command": "amm_info", - "asset": { - "currency": "XRP" - }, - "asset2": { - "currency": "TST", - "issuer": "rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd" - } -})) - -const my_share = LPTokens / amm_info.result.amm.lp_token.value - -const my_asset1 = (amm_info.result.amm.amount * my_share) / 1000000 -const my_asset2 = amm_info.result.amm.amount2.value * my_share - -console.log(`My ${LPTokens} LP tokens are worth: - XRP: ${my_asset1} - ${amm_info.result.amm.amount2.currency}: ${my_asset2}`) - -// Withdraw by redeeming LP tokens -console.log("------- Pull some money out of AMM -------") - -const ammwithdraw = { - "TransactionType": "AMMWithdraw", - "Asset": { - "currency": "XRP" - }, - "Asset2": { - "currency": "TST", - "issuer": "rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd" - }, - "Account": wallet.address, - "LPTokenIn": { - currency: "039C99CD9AB0B70B32ECDA51EAAE471625608EA2", - issuer: "rhQWjbT5CQJ2fgHKn6FjRrYbGPKmoS3EhD", - value: "2940" - }, - "Flags": 0x00010000 -} - -const prepared_withdraw = await client.autofill(ammwithdraw) -console.log("Prepared transaction:", JSON.stringify(prepared_withdraw, null, 2)) -const signed_withdraw = wallet.sign(prepared_withdraw) -console.log(`Sending AMMWithdraw transaction ...`) -const response_withdraw = await client.submitAndWait(signed_withdraw.tx_blob) - -if (response_withdraw.result.meta.TransactionResult == "tesSUCCESS") { - console.log(`Transaction succeeded: - https://${EXPLORER}/transactions/${signed_withdraw.hash}`) -} else { - console.error("Error sending transaction:", response_withdraw) -} - -// Disconnect when done (If you omit this, Node.js won't end the process) -await client.disconnect() - -} - -main() diff --git a/_code-samples/add-amm-lp/js/package.json b/_code-samples/add-amm-lp/js/package.json deleted file mode 100644 index e0e9b83e712..00000000000 --- a/_code-samples/add-amm-lp/js/package.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "dependencies": { - "xrpl": "^3.0.0" - } -} diff --git a/docs/tutorials/javascript/trade-on-ledger/earn-passive-income-as-a-liquidity-provider.md b/docs/tutorials/javascript/trade-on-ledger/earn-passive-income-as-a-liquidity-provider.md deleted file mode 100644 index bfc1c6d8d0a..00000000000 --- a/docs/tutorials/javascript/trade-on-ledger/earn-passive-income-as-a-liquidity-provider.md +++ /dev/null @@ -1,68 +0,0 @@ ---- -seo: - description: Provide liquidity for an Automated Market Maker (AMM) and earn income from trading fees. -labels: - - Decentralized Exchange - - Tokens - - AMM ---- -# Earn Passive Income as a Liquidity Provider - -Providing liquidity for an [Automated Market Maker (AMM)](../../../concepts/tokens/decentralized-exchange/automated-market-makers.md) can be a great way to earn passive income. By depositing assets into an AMM pool, you'll earn a percentage of the trading fees generated. This tutorial shows how to deposit assets, vote on fees, and withdraw assets. - - -## Prerequisites - -- You should be familiar with basic usage of the [xrpl.js client library](https://github.com/XRPLF/xrpl.js/). See [Get Started Using JavaScript](../build-apps/get-started.md) for setup steps. -- The AMM for the asset pair you want to trade must already exist in the ledger. This tutorial uses an AMM on Testnet which has been set up in advance, connecting the following assets: - -| Currency Code | Issuer | Notes | -|---|---|---| -| XRP | N/A | Testnet XRP is functionally similar to XRP, but holds no real-world value. You can get it for free from a [faucet](/resources/dev-tools/xrp-faucets). -| TST | `rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd` | A test token pegged to XRP at a rate of approximately 10 XRP per 1 TST. The issuer has existing Offers on the XRP Ledger Testnet to buy and sell these tokens. This token has no [transfer fee](../../../concepts/tokens/transfer-fees.md) or [Tick Size](../../../concepts/tokens/decentralized-exchange/ticksize.md) set. | - -For instructions on creating an AMM for a different currency pair, see [Create an Automated Market Maker](../../how-tos/use-tokens/create-an-automated-market-maker.md). - - -## Source Code - -See {% repo-link path="_code-samples/add-amm-lp/js/" %}Code Samples: Add AMM LP{% /repo-link %} for the full source code for this tutorial. - - -## Steps - -### 1. Connect to the network and generate credentials - -{% code-snippet file="/_code-samples/add-amm-lp/js/add-amm-lp.js" language="js" from="// Define the network client" before="// Acquire TST tokens" /%} - - -### 2. Acquire TST tokens - -{% code-snippet file="/_code-samples/add-amm-lp/js/add-amm-lp.js" language="js" from="// Acquire TST tokens" before="// Deposit assets into AMM" /%} - - -### 3. Deposit assets to the AMM - -You can contribute either one or both assets to an AMM pool. Contributing just one asset can be easier, but incurs a fee that is debited from the LP Tokens paid out. If you contribute both assets in the pool, you aren't charged a fee. - -{% code-snippet file="/_code-samples/add-amm-lp/js/add-amm-lp.js" language="js" from="// Deposit assets into AMM" before="// Vote on fees" /%} - - -### 4. Vote on trading fees - -This step is optional, but you're encouraged to submit a vote for a fee structure you believe makes sense. - -{% code-snippet file="/_code-samples/add-amm-lp/js/add-amm-lp.js" language="js" from="// Vote on fees" before="// Get LP tokens value" /%} - - -### 5. Wait for your LP Tokens to accrue value - -This step is optional, but is useful for checking on your LP token values without withdrawing the assets. - -{% code-snippet file="/_code-samples/add-amm-lp/js/add-amm-lp.js" language="js" from="// Get LP tokens value" before="// Withdraw by redeeming LP tokens" /%} - -### 6. Withdraw assets from the AMM - -Similar to depositing assets, you can withdraw either one or both assets from the AMM pool. Withdrawing a single asset incurs a fee, while withdrawing both does not. When you withdraw by redeeming LP Tokens, you are paid out in both assets. - -{% code-snippet file="/_code-samples/add-amm-lp/js/add-amm-lp.js" language="js" from="// Withdraw by redeeming LP tokens" before="// Disconnect when done" /%} diff --git a/docs/tutorials/javascript/trade-on-ledger/index.md b/docs/tutorials/javascript/trade-on-ledger/index.md deleted file mode 100644 index 73dd4176c9a..00000000000 --- a/docs/tutorials/javascript/trade-on-ledger/index.md +++ /dev/null @@ -1,9 +0,0 @@ ---- -metadata: - indexPage: true ---- -# Trade On-Ledger - -Use the XRP Ledger's built-in Decentralized Exchange (DEX) to trade assets. - -{% child-pages /%} diff --git a/docs/tutorials/javascript/trade-on-ledger/use-amm-auction-slot-for-lower-fees.md b/docs/tutorials/javascript/trade-on-ledger/use-amm-auction-slot-for-lower-fees.md deleted file mode 100644 index 4c86f8dc90e..00000000000 --- a/docs/tutorials/javascript/trade-on-ledger/use-amm-auction-slot-for-lower-fees.md +++ /dev/null @@ -1,218 +0,0 @@ -# Use the AMM Auction Slot for Lower Fees - -When trading on the XRP Ledger's decentralized exchange (DEX), you can sometimes save on trading fees by buying the auction slot built into an [Automated Market Maker (AMM)](../../../concepts/tokens/decentralized-exchange/automated-market-makers.md). This tutorial shows how to identify when the auction slot can save you money and what transactions to send to use it, with example code in JavaScript. - -For a simpler example of trading currencies in the XRP Ledger's DEX, see [Trade in the Decentralized Exchange](../../how-tos/use-tokens/trade-in-the-decentralized-exchange.md). - -{% admonition type="warning" name="Caution" %} -This tutorial does not exhaustively cover all possible market conditions and circumstances. Always exercise caution and trade at your own risk. -{% /admonition %} - -## Prerequisites - -- You need a connection to the XRP Ledger network. As shown in this tutorial, you can use public servers for testing. -- You should be familiar with basic usage of the [xrpl.js client library](https://github.com/XRPLF/xrpl.js/). See [Get Started Using JavaScript](../build-apps/get-started.md) for setup steps. -- The AMM for the asset pair you want to trade must already exist in the ledger. This tutorial uses an AMM instance that has been set up on the XRP Ledger Testnet in advance, connecting the following assets: - - | Currency Code | Issuer | Notes | - |---|---|---| - | XRP | N/A | Testnet XRP is functionally similar to XRP, but holds no real-world value. You can get it for free from a [faucet](/resources/dev-tools/xrp-faucets). - | TST | `rP9jPyP5kyvFRb6ZiRghAGw5u8SGAmU4bd` | A test token pegged to XRP at a rate of approximately 10 XRP per 1 TST. The issuer has existing Offers on the XRP Ledger Testnet to buy and sell these tokens. This token has no [transfer fee](../../../concepts/tokens/transfer-fees.md) or [Tick Size](../../../concepts/tokens/decentralized-exchange/ticksize.md) set. | - - For instructions on creating an AMM for a different currency pair, see [Create an Automated Market Maker](../../how-tos/use-tokens/create-an-automated-market-maker.md). - -## Source Code - -See {% repo-link path="_code-samples/auction-slot/js/" %}Code Samples: Auction Slot{% /repo-link %} for the full source code for this tutorial. - - -## Steps - -At a high level, the steps involved in using an AMM auction slot to save money on trading are as follows: - -- **Step 1:** Connect to the ledger so can query the current state. -- **Steps 2-4:** Estimate how much your desired trade would cost in AMM trading fees. -- **Step 5:** Compare against the cost to win the current auction slot. -- **Steps 6-7:** If winning the auction slot is cheaper, use AMMDeposit to acquire some LPTokens and then use AMMBid to spend those tokens on winning the auction slot. -- **Step 8:** Make the intended trade using an OfferCreate transaction. - -For simplicity, this tutorial assumes that you have XRP, you want to acquire a fixed amount of TST in a single trade, and that the entire trade will execute using the AMM. Real-life situations are more complicated. For example, part of your trade may execute by consuming Offers rather than using the AMM, or you may want to do a series of trades over a period of time. If one or both of the assets you are trading has a transfer fee or tick size set, those details can also affect the calculations. - -### 1. Setup - -For this use case, you need a high-precision number library such as [Bignumber.js](https://mikemcl.github.io/bignumber.js/) for correctly performing calculations on currency amounts you may find in the ledger. - -The following `package.json` file lists the necessary dependencies: - -{% code-snippet file="/_code-samples/auction-slot/js/package.json" language="json" /%} - -After copying this file, run `npm install` from the same folder to download the appropriate dependencies. - -Start your JavaScript file with the following code to import dependencies: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" before="async function main()" /%} - -You should also create the `amm-formulas.js` file, which defines several AMM-related helper functions. See the [Appendix](#appendix-amm-formulas) for the implementations of these functions. - -After that, you should connect to the network and set up a `Wallet` instance in the usual way. For example: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="async function main()" before="// Look up AMM status" /%} - - -### 2. Look Up AMM Status - -To determine if your trade could benefit from the reduced fees of the AMM auction slot, you must first look up the current state of the AMM. To get the latest information, use the `amm_info` method and query the `current` (pending) ledger version. - -{% admonition type="warning" name="Caution" %}The `current` ledger incorporates recently-sent transactions that are likely to be confirmed; it is the most up-to-date picture of the ledger state, but the details may change when the ledger is validated. You can also use the `validated` ledger, which returns only the latest confirmed data.{% /admonition %} - -The following code snippet reads the `amm_info` result and saves some of the details for later use: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Look up AMM status" before="// Calculate price in XRP" /%} - - -### 3. Estimate the cost of AMM trading fees - -This tutorial shows how to estimate the cost, in XRP, to buy a fixed amount of TST using the AMM. The calculations are different for other types of trades, such as a "sell" trade that buys as much TST as possible with a fixed amount of XRP, or for assets with other complications such as transfer fees. - -First, define the target amount of TST and check that the AMM can even fulfill the trade: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Calculate price in XRP" before="// Use AMM's SwapOut formula" /%} - -Then, you use the AMM _SwapOut_ formula to calculate how much XRP you need to pay to receive the target amount of TST out. See [SwapOut in the Appendix](#swapout) for the implementation of this formula. - -To estimate the cost of trading fees, call SwapOut twice: once with the full fee, and once with the discounted fee of the auction slot. The difference between the two represents the maximum possible savings from the auction slot for this trade. The actual savings will be less because of the costs of winning the auction slot. - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Use AMM's SwapOut formula" before="// Calculate the cost of winning" /%} - -{% admonition type="info" name="Note" %}For illustrative purposes, this code assumes that the entire trade will execute using the AMM and not by consuming Offers. In reality, a trade can use both in combination to achieve a better rate.{% /admonition %} - - -### 4. Calculate the cost of winning the auction slot - -The cost to win the auction slot depends on how long the current holder has held it and how much they paid, but it's always denominated in LP tokens. If you currently only have XRP and you want to win the auction slot, you must first deposit some of your XRP to get LP Tokens. - -The price of winning the auction slot is defined in XLS-0030 section 4.1.1. However, the minimum bid scales with the number of LP Tokens issued. If you calculate the auction price and _then_ deposit exactly enough to pay for it, the auction price increases proportionally to the new LP Tokens you gained. - -This is similar to cases where you want to deliver exactly $100 after subtracting a 3% fee. If you calculate $100 + (0.03 * $100) = $103, only $99.91 will arrive because the extra $3 is also subject to the fee. Instead, you divide 100 ÷ 0.97 ≈ $103.10 (rounding up to make sure). - -The _AuctionDeposit_ formula represents the inverted form of the auction price formula so that you can calulate how much to deposit to match the auction price. See [Appendix: AuctionDeposit](#auctiondeposit) for the implementation. - -You use the function like this: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Calculate the cost of winning the auction slot" before="// Calculate how much XRP to deposit" /%} - - -### 5. Compare the costs and savings - -The previous step gives a cost for the auction slot in the form of LP Tokens. To compare against your potential savings, you need to convert this to the XRP cost of the deposit. If the XRP cost of making the deposit and winning the auction slot is greater than your savings, then you should not go through with it. - -You use the AMM _AssetIn_ formula to estimate how much XRP you have to deposit to receive the target amount of TST. See [Appendix: AssetIn](#assetin) for the implementation. - -The following code uses AssetIn to estimate the cost of the deposit: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Calculate how much XRP to deposit" before="// Optional. Allow for costs" /%} - -Since the XRP Ledger's decentralized exchange is always open to other traders using it too, new transactions can change the current state at the same time that you are doing these calculations and sending your own transactions. You should allow for some amount of _slippage_, the change in rates between when you checked them and when your transaction executes. The following example allows up to 1% slippage: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Optional. Allow for costs" before="// Compare price of deposit+bid" /%} - -Finally, you take the slippage-adjusted cost in XRP, add the transaction costs in XRP burned for sending two transactions, and compare that total to the potential savings calculated back in step 3. If the total cost is higher than the savings, you won't save money using the auction slot, so you stop here. - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Compare price of deposit+bid" before="// Do a single-asset deposit" /%} - -{% admonition type="success" name="Tip" %} You may still be able to save money if you plan to do additional trades for a larger total amount. Also, if the auction slot is currently occupied, the cost of outbidding the current slot holder decreases over 24 hours, so you can wait and try again later.{% /admonition %} - - -### 6. Send an AMMDeposit transaction to get LP Tokens - -Assuming you determined that you could make money, it's now time to send actual transactions to the XRP Ledger, starting with an [AMMDeposit transaction][] to get the LP Tokens that you'll bid on the auction slot. - -The "One Asset LP Token" deposit type is most convenient here since you can specify exactly how many LP Tokens you want to receive, and you only need to deposit XRP. The following code creates and sends the transaction: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Do a single-asset deposit" before="// Actually bid" /%} - -After the transaction is (or isn't) confirmed by the consensus process, the code displays the results to the console. - - -### 7. Send an AMMBid transaction to win the auction slot - -Assuming the previous transaction was successful, the next step is to use the LP Tokens to bid on the auction slot. To do this, you send an [AMMBid transaction][] with the slippage-adjusted bid amount you calculated earlier in the `BidMax` field, as in the following code: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Actually bid" before="// Trade using the discount" /%} - -{% admonition type="success" name="Tip" %}The amounts that LP Tokens get rounded can be surprising. If you don't plan on holding LP Tokens after bidding, you should set `BidMin` to the same as `BidMax` so that you aren't left with a trust line that contains a very tiny amount of LP Tokens that weren't spent on the auction price, and you don't have to meet the XRP reserve for that trust line.{% /admonition %} - - -### 8. Trade using the discount - -If your previous transaction was successful, you should now be the auction slot holder until you are outbid or 24 hours have passed, whichever comes first. You can immediately use this opportunity to make the XRP for TST trade that you wanted to make in the first place. There are several ways to make trades in the XRP Ledger, but sending an OfferCreate transaction is the most conventional, as in the following code: - -{% code-snippet file="/_code-samples/auction-slot/js/auction-slot.js" language="js" from="// Trade using the discount" before="// Done" /%} - -{% admonition type="success" name="Tip" %}If you are outbid before the auction slot expires, you'll get some of your LP Tokens refunded based on how much time you had left. You can use an [AMMWithdraw transaction][] to convert those to additional XRP, TST, or both as desired.{% /admonition %} - - -## Appendix: AMM Formulas - -The above sample code shows how to use various AMM-related formulas in a particular workflow. Your code must also have implementations of those formulas, which can be in the same file or imported from a separate one as you desire. - -The file {% repo-link path="_code-samples/auction-slot/js/amm-formulas.js" %}`amm-formulas.js`{% /repo-link %} contains the source code for all these formulas. - -### AssetIn - -The _AssetIn_ formula calculates how much of an asset must be deposited to receive a target amount of LP Tokens. - -The following function implements AssetIn in JavaScript: - -{% code-snippet file="/_code-samples/auction-slot/js/amm-formulas.js" language="js" from="/* Implement the AMM single-asset deposit" before="/* Calculate how much to deposit" /%} - -This function depends on the `feeMult`, `feeMultHalf`, and `solveQuadraticEq` helper functions. - -### AuctionDeposit - -The _AuctionDeposit_ function is an inverted form of the formula for the AMM's auction price, taking into account how the minimum bid value changes as LP Tokens are issued. AuctionDeposit calculates the total amount of LP Tokens you need to receive in a deposit if you want to match the auction price: - -{% code-snippet file="/_code-samples/auction-slot/js/amm-formulas.js" language="js" from="/* Calculate how much to deposit" before="/* Calculate the necessary bid" /%} - -### AuctionPrice - -The _AuctionPrice_ function calculates the cost of the auction slot for current LP Token holders. **It is not used in this tutorial,** which assumes the user does not hold LP Tokens, but is presented here for completeness: - -{% code-snippet file="/_code-samples/auction-slot/js/amm-formulas.js" language="js" from="/* Calculate the necessary bid" before="module.exports =" /%} - - -### SwapOut - -The _SwapOut_ formula, defined in the XRPL-0030 specification as formula 10, calculates how much of one asset you have to swap in to the AMM to receive a target amount of the other asset out from the AMM. - -The following function implements SwapOut in JavaScript: - -{% code-snippet file="/_code-samples/auction-slot/js/amm-formulas.js" language="js" from="/* Implement the AMM SwapOut formula" before="/* Compute the quadratic formula" /%} - -### feeDecimal, feeMult, and feeMultHalf - -These helper functions are used in other AMM formulas to convert from a trading fee value in the ledger (integer from 0 to 1000) to a decimal representation that can be multiplied by a total to apply the fee. - -The following functions implement `feeMult`, `feeMultHalf`, and `feeDecimal` in JavaScript: - -{% code-snippet file="/_code-samples/auction-slot/js/amm-formulas.js" language="js" from="/* Convert a trading fee to a value that" before="/* Implement the AMM SwapOut formula" /%} - -The AssetIn and SwapOut functions depend on these helper functions. - -### solveQuadraticEq - -This helper function implements the quadratic equation in JavaScript: - -{% code-snippet file="/_code-samples/auction-slot/js/amm-formulas.js" language="js" from="/* Compute the quadratic formula." before="/* Implement the AMM single-asset deposit" /%} - -The AssetIn formula depends on this. - - -## Conclusion - -Trading assets is never risk-free, and Automated Market Makers are no exception. However, the XRP Ledger's fast, low-cost transactions can be helpful in reducing the costs and fees associated with currency exchange. This tutorial demonstrates a minimal approach to using the auction slot to save money, but of course more creative uses are possible. - -The details depend on your specific circumstances and the types of trades you are doing, or expect to do in the future, as well as the state of the market, the XRP Ledger network, and the AMM instances in particular. See the [Code Samples](/resources/code-samples) for additional related use cases, and feel free to contribute your own samples as well to show the community what can be done on the XRP Ledger. - - -{% raw-partial file="/docs/_snippets/common-links.md" /%} diff --git a/redirects.yaml b/redirects.yaml index aadb28bed5d..1d75985b1dd 100644 --- a/redirects.yaml +++ b/redirects.yaml @@ -1,3 +1,6 @@ +/docs/tutorials/javascript/trade-on-ledger/: + to: /docs/tutorials/javascript/amm/ + type: 301 /docs/tutorials/javascript/trade-on-ledger/earn-passive-income-as-a-liquidity-provider: to: /docs/tutorials/javascript/amm/add-assets-to-amm type: 301