Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

📝 Refresh six classic guides #723

Draft
wants to merge 105 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
105 commits
Select commit Hold shift + click to select a range
a125983
🔁 Channel accounts: explain resolutions
JFWooten4 Jun 20, 2024
01424db
🔁 Channel accounts: simplify narrative
JFWooten4 Jun 22, 2024
37e38c3
🔁 Channel accounts: specify cards
JFWooten4 Jun 23, 2024
9ed2a0a
🔁 Channel accounts: finalize visuals
JFWooten4 Jun 23, 2024
44309a2
🔁 Channel accounts: simplify narrative
JFWooten4 Jun 26, 2024
dd7d761
🔁 Channel accounts: expand details
JFWooten4 Jun 26, 2024
c4a46dc
Merge branch 'stellar:main' into refresh-classic-guides
JFWooten4 Jul 5, 2024
68f165d
🔁 Channel accounts: hyperlinks, context
JFWooten4 Jul 7, 2024
07e613a
🔁 Channel accounts: initial diagrams
JFWooten4 Jul 9, 2024
bf6e15f
🔁 Channel accounts: reference configuration
JFWooten4 Jul 9, 2024
15d1288
🔁 Channel accounts: KaTeX formatting
JFWooten4 Jul 10, 2024
b874bc7
🔁 Channel accounts: context, links
JFWooten4 Jul 10, 2024
e290fb3
🔁 Channel accounts: conceptual images
JFWooten4 Jul 12, 2024
1f8a904
🔁 Channel accounts: simplify image
JFWooten4 Jul 12, 2024
46f49c6
🔁 Channel accounts: prioritize readability
JFWooten4 Jul 14, 2024
3f2e731
🔁 Channel accounts: overload example
JFWooten4 Jul 14, 2024
8a3d963
🔁 Channel accounts: configuration example
JFWooten4 Jul 15, 2024
cd7f447
🫴🏽 Claimable balances: first example
JFWooten4 Jul 18, 2024
e2248db
🫴🏽 Claimable balances: second example
JFWooten4 Jul 29, 2024
1992240
🫴🏽 Claimable balances: third example
JFWooten4 Jul 29, 2024
ee6175a
🫴🏽 Claimable balances: expand precomputation
JFWooten4 Aug 2, 2024
95ffe3c
🔎 Refresh: asset design considerations
JFWooten4 Aug 5, 2024
d93ae63
🦞 Clawbacks: confer readable diction
JFWooten4 Aug 5, 2024
e1611fc
🦞 Clawbacks: minor example diction
JFWooten4 Aug 5, 2024
03ac66d
🦞 Clawbacks: format account names
JFWooten4 Aug 5, 2024
86f3ca8
🦞 Clawbacks: format more names
JFWooten4 Aug 5, 2024
d1a9252
🦞 Clawbacks: apply name diction
JFWooten4 Aug 5, 2024
eb0e9be
🦞 Clawbacks: translate preamble example
JFWooten4 Aug 6, 2024
f4ad468
🦞 Clawbacks: expand example one
JFWooten4 Aug 6, 2024
e72e4a8
🦞 Clawbacks: translate next instances
JFWooten4 Aug 6, 2024
09fa456
🦞 Clawbacks: continue example dev
JFWooten4 Aug 6, 2024
b3e3230
💱 Trading examples: add lumenaut
JFWooten4 Aug 8, 2024
ee66e13
⏬ Prep for GH sync
JFWooten4 Aug 12, 2024
364f656
Merge remote-tracking branch 'upstream/main' into refresh-classic-guides
JFWooten4 Aug 12, 2024
6e866b7
Merge remote-tracking branch 'upstream/main' into refresh-classic-guides
JFWooten4 Aug 21, 2024
080ec03
💱 Trading examples: clarify narrative
JFWooten4 Sep 13, 2024
b529869
💱 Trading examples: contextualize sources
JFWooten4 Sep 13, 2024
127142e
↕️ Merge branch with self
JFWooten4 Sep 13, 2024
fea178f
🙌 Missed a reference link
JFWooten4 Sep 13, 2024
1a12877
💱 Trading examples: sell offers
JFWooten4 Sep 16, 2024
550b941
💱 Trading examples: level two
JFWooten4 Sep 16, 2024
fff2713
💱 Trading examples: time & sales
JFWooten4 Sep 16, 2024
06d249d
Merge remote-tracking branch 'upstream/main' into refresh-classic-guides
JFWooten4 Sep 30, 2024
4658706
🔁 Sync, move work items
JFWooten4 Sep 30, 2024
760d423
🔁 Clarify channel context links
JFWooten4 Oct 1, 2024
3d30353
🔁 Further advance text flow
JFWooten4 Oct 4, 2024
f6691fa
🔁 Start last code examples
JFWooten4 Oct 7, 2024
b273d71
🔁 Remove random channel generation
JFWooten4 Oct 7, 2024
954210d
🔁 Rest of authorization example
JFWooten4 Oct 7, 2024
ce8d61e
🔁 Remove adding channel custody
JFWooten4 Oct 7, 2024
7cb4b01
🔁 Clear up last tasks
JFWooten4 Oct 7, 2024
56c608a
🔁 Start state rotation example
JFWooten4 Oct 7, 2024
f83f4ad
🔁 Temporary merge, nonfinal publication
JFWooten4 Oct 11, 2024
1a91082
🔗 Minimum compilation link requirements
JFWooten4 Oct 15, 2024
11555a0
🖌️ Prettier compilation demo fixes
JFWooten4 Oct 15, 2024
d521205
🔁 Clarify base fee, miscellaneous 🤝🏻
JFWooten4 Oct 16, 2024
33f342e
Merge branch 'stellar:main' into refresh-classic-guides
JFWooten4 Oct 17, 2024
09fffca
👽 Translate java to JS
JFWooten4 Oct 19, 2024
03d2199
🔁 Last example java & go
JFWooten4 Oct 22, 2024
1c8851d
Merge branch 'stellar:main' into refresh-classic-guides
JFWooten4 Oct 22, 2024
cb9687a
🔁 Closing example explanation, diagrams
JFWooten4 Oct 22, 2024
06183cc
🔁 Put back `set timeouts`
JFWooten4 Oct 22, 2024
cbe3aca
🔁 Cleanup remaining frame items
JFWooten4 Oct 23, 2024
b45f8b2
🔁 Comment active-tense transitive verbs
JFWooten4 Oct 23, 2024
a73d966
🔁 Finalize the story flow
JFWooten4 Oct 23, 2024
a3c5d64
🔁 Polish off minor syntax
JFWooten4 Oct 23, 2024
eac05da
🔗 Remove depricated community link
JFWooten4 Oct 27, 2024
91b40fd
🔎 Clarify note on trustlines
JFWooten4 Oct 27, 2024
7109cb5
🫴🏽 Finish most cleaning up
JFWooten4 Nov 4, 2024
320de48
Merge branch 'main' into refresh-classic-guides
JFWooten4 Nov 4, 2024
0948700
🔗 Update simplified syntax reference
JFWooten4 Nov 4, 2024
19fbf45
🦞 Clean up final examples
JFWooten4 Nov 4, 2024
75a3ea0
💱 Remove items explicitly moved
JFWooten4 Nov 5, 2024
9bc3c63
💱 Remove duplicate placeholder drafts
JFWooten4 Nov 5, 2024
2a2638c
💱 Sidebar section intro description
JFWooten4 Nov 5, 2024
9d01898
💱 First rewrite run through
JFWooten4 Nov 6, 2024
32455bb
💱 Clean up scaffolding leftovers
JFWooten4 Nov 19, 2024
da7e8a3
💱 Translate starting AMM preamble
JFWooten4 Nov 19, 2024
a5c1874
💱 Capital pool > liquidity pool
JFWooten4 Nov 19, 2024
f8a304f
💱 Translate two AMM steps
JFWooten4 Nov 20, 2024
535b09b
📍 Follow up on this
JFWooten4 Nov 24, 2024
be7abb0
💱 Translate removing AMM liquidity
JFWooten4 Nov 24, 2024
eb18115
💱 Translate Java wrap-up example
JFWooten4 Nov 24, 2024
f871bab
💱 Last legacy, 535b09babed7a2afef37d58250f13ff01c2544fa fix
JFWooten4 Nov 24, 2024
b7f4a07
💱 Clean up go conclusion
JFWooten4 Nov 24, 2024
5492eb3
📌 Simplify starting frame, independence
JFWooten4 Nov 24, 2024
80784d8
💱 Seperate preliminary config, example
JFWooten4 Nov 25, 2024
f1a50e2
🖌️ Update prettier config note
JFWooten4 Nov 26, 2024
a4bdaeb
💱 Optimize, clarify global declarations
JFWooten4 Nov 26, 2024
ddd80c6
Merge branch 'main' into refresh-classic-guides
JFWooten4 Dec 6, 2024
81efcf5
💱 DEX code examples setup
JFWooten4 Dec 8, 2024
c7865bb
💱 Initial sell offer examples
JFWooten4 Dec 8, 2024
1f31ba4
💱 Example resolving limit OB
JFWooten4 Dec 8, 2024
34fb3b0
💱 Pricing point local calculation
JFWooten4 Dec 9, 2024
8417495
💱 Start prepping final flow
JFWooten4 Dec 10, 2024
d6d2335
💱 Continue on the intro
JFWooten4 Dec 11, 2024
2dc7db6
💱 Start of execution chat
JFWooten4 Dec 12, 2024
7f9bdc6
💱 Migrate some ancillary points
JFWooten4 Dec 12, 2024
909911a
💱 Introduce the OB outreach
JFWooten4 Dec 12, 2024
62b35af
💱 Translate pricing calculation examples
JFWooten4 Dec 13, 2024
24e3bb4
🖋 Some primative punctuation upgrades
JFWooten4 Dec 31, 2024
59d3686
💱 Remove elementary explanation diction
JFWooten4 Dec 31, 2024
873423e
Merge branch 'refresh-classic-guides' of https://github.com/JFWooten4…
JFWooten4 Dec 31, 2024
49477f8
🐛 Reinstate space line seperators
JFWooten4 Dec 31, 2024
2cbe9ab
Merge branch 'refresh-classic-guides' of https://github.com/JFWooten4…
JFWooten4 Dec 31, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
📌 Simplify starting frame, independence
  • Loading branch information
JFWooten4 committed Nov 24, 2024
commit 5492eb346cf66cf49110be4eef3540c4d61b1883
2 changes: 1 addition & 1 deletion docs/learn/encyclopedia/sdex/README.mdx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: The SDEX
title: Liquidity on Stellar
sidebar_position: 90
---

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: "Liquidity on Stellar: the SDEX and Liquidity Pools"
title: "The SDEX and Automated Market Makers"
---

import { CodeExample } from "@site/src/components/CodeExample";
Expand Down Expand Up @@ -391,8 +391,6 @@ streamling also works for trading-history data, among other ledger updates. mark

Since all oreders for a currency pari fall into the same SDEX order book, you cna know that you're getting the best exchange rate between two explicit assets. Accordingly, you can analyze the past valuation of a currency by reading its exchanged trades feed. We'll continue our exmaple and set up a recent trading price query:

EX for the price query (getting best ex impl, see L72 at 9bc3c637047c8d1b010228d29876f2b92783074b):

<CodeExample>

```python
Expand Down Expand Up @@ -608,7 +606,55 @@ However, users don’t need to participate in the pool to take advantage of what

Instead of relying on the buy and sell orders of the SDEX, AMMs keep assets liquid 24/7 using pooled capital and a mathematical equation. AMMs hold two different assets in a liquidity pool, and the quantities of those assets (or reserves) are inputs for that equation (Asset A \* Asset B = k). If an AMM holds more of the reserve assets, the asset prices move less in response to a trade.

When you submit an
When you submit an..

<CodeExample>

```python
def getSpotPrice():
resp = server.liquidity_pools().liquidity_pool(poolId).call()
amountA = resp["reserves"][0]["amount"]
amountB = resp["reserves"][1]["amount"]
spotPrice = Decimal(amountA) / Decimal(amountB)
print(f"Price: {amountA}/{amountB} = {spotPrice:.7f}") # Max network precision
```

```js
async function getSpotPrice() {
const pool = await server.liquidityPools().liquidityPoolId(poolId).call();
const [a, b] = pool.reserves.map((r) => r.amount);
const spotPrice = new BigNumber(a).div(b);
console.log(`Price: ${a}/${b} = ${spotPrice.toFormat(7)}`);
}
```

```java
public static void getSpotPrice(String[] args) throws Exception {
LiquidityPoolResponse poolInfo = server.liquidityPools().liquidityPool(poolId).execute();
double reserveA = Double.parseDouble(poolInfo.getReserves().get(0).getAmount());
double reserveB = Double.parseDouble(poolInfo.getReserves().get(1).getAmount());
double spotPrice = reserveA / reserveB;
System.out.printf("Price: %.7f/%7f = %.7f%n", reserveA, reserveB, spotPrice);
}
```

```go
func getSpotPrice(server *horizonclient.Client, poolID string) {
poolRequest := horizonclient.LiquidityPoolRequest{LiquidityPoolID: poolID}
pool, err := server.LiquidityPoolDetail(poolRequest)
check(err)

reserveA, err := strconv.ParseFloat(pool.Reserves[0].Amount, 64)
check(err)
reserveB, err := strconv.ParseFloat(pool.Reserves[1].Amount, 64)
check(err)

spotPrice := reserveA / reserveB
fmt.Printf("Price: %.7f/%.7f = %.7f\n", reserveA, reserveB, spotPrice)
}
```

</CodeExample>

#### AMM Calculations

Expand Down Expand Up @@ -1399,7 +1445,6 @@ Finally, we can combine these pieces together to simulate some participation in
<CodeExample>

```python

# Step 1: kp1 adds liquidity
establishPoolTrustline(kps[1], poolAsset)
addLiquidity(
Expand Down Expand Up @@ -1433,13 +1478,6 @@ if not balance:
raise Exception("No liquidity pool shares found for kp1")
removeLiquidity(kps[1], poolId, balance)
getSpotPrice()

def getSpotPrice():
resp = server.liquidity_pools().liquidity_pool(poolId).call()
amountA = resp["reserves"][0]["amount"]
amountB = resp["reserves"][1]["amount"]
spotPrice = Decimal(amountA) / Decimal(amountB)
print(f"Price: {amountA}/{amountB} = {spotPrice:.7f}") # Max network precision
```

```js
Expand Down Expand Up @@ -1477,13 +1515,6 @@ async function main() {
await getSpotPrice();
}

async function getSpotPrice() {
const pool = await server.liquidityPools().liquidityPoolId(poolId).call();
const [a, b] = pool.reserves.map((r) => r.amount);
const spotPrice = new BigNumber(a).div(b);
console.log(`Price: ${a}/${b} = ${spotPrice.toFormat(7)}`);
}

preamble().then(main);
```

Expand Down Expand Up @@ -1518,14 +1549,6 @@ public static void main(String[] args) throws Exception {
removeLiquidity(kp1, poolId, balance);
getSpotPrice();
}

public static void getSpotPrice(String[] args) throws Exception {
LiquidityPoolResponse poolInfo = server.liquidityPools().liquidityPool(poolId).execute();
double reserveA = Double.parseDouble(poolInfo.getReserves().get(0).getAmount());
double reserveB = Double.parseDouble(poolInfo.getReserves().get(1).getAmount());
double spotPrice = reserveA / reserveB;
System.out.printf("Price: %.7f/%7f = %.7f%n", reserveA, reserveB, spotPrice);
}
```

```go
Expand Down Expand Up @@ -1569,20 +1592,6 @@ func main() {
removeLiquidity(kp1, poolID, balance)
getSpotPrice(poolID)
}

func getSpotPrice(server *horizonclient.Client, poolID string) {
poolRequest := horizonclient.LiquidityPoolRequest{LiquidityPoolID: poolID}
pool, err := server.LiquidityPoolDetail(poolRequest)
check(err)

reserveA, err := strconv.ParseFloat(pool.Reserves[0].Amount, 64)
check(err)
reserveB, err := strconv.ParseFloat(pool.Reserves[1].Amount, 64)
check(err)

spotPrice := reserveA / reserveB
fmt.Printf("Price: %.7f/%.7f = %.7f\n", reserveA, reserveB, spotPrice)
}
```

</CodeExample>
Loading