@moonpay/cli 0.5.1 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-PBRXVTTG.js → chunk-DCHEUKV7.js} +529 -528
- package/dist/chunk-DCHEUKV7.js.map +1 -0
- package/dist/{chunk-V7MA7WNX.js → chunk-GSAFAKB7.js} +145 -119
- package/dist/chunk-GSAFAKB7.js.map +1 -0
- package/dist/index.js +174 -31
- package/dist/index.js.map +1 -1
- package/dist/{mcp-TDQN25MO.js → mcp-6IZ4QWFM.js} +3 -3
- package/dist/{store-HCN56E6A.js → store-UAGR3DWU.js} +2 -2
- package/package.json +1 -1
- package/skills/moonpay-block-explorer/SKILL.md +123 -0
- package/skills/moonpay-buy-crypto/SKILL.md +1 -1
- package/skills/moonpay-export-data/SKILL.md +111 -0
- package/skills/moonpay-polymarket-ready/SKILL.md +112 -0
- package/skills/moonpay-price-alerts/SKILL.md +167 -0
- package/skills/moonpay-trading-automation/SKILL.md +276 -0
- package/skills/moonpay-virtual-account/SKILL.md +14 -18
- package/dist/chunk-PBRXVTTG.js.map +0 -1
- package/dist/chunk-V7MA7WNX.js.map +0 -1
- /package/dist/{mcp-TDQN25MO.js.map → mcp-6IZ4QWFM.js.map} +0 -0
- /package/dist/{store-HCN56E6A.js.map → store-UAGR3DWU.js.map} +0 -0
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: moonpay-block-explorer
|
|
3
|
+
description: Open transactions, wallets, and tokens in the correct block explorer. Use after swaps, bridges, or transfers to view results in the browser.
|
|
4
|
+
tags: [explorer]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Block explorer
|
|
8
|
+
|
|
9
|
+
## Goal
|
|
10
|
+
|
|
11
|
+
After any swap, bridge, or transfer, open the result in the correct block explorer. Also useful for viewing wallet addresses and token contract pages.
|
|
12
|
+
|
|
13
|
+
## Explorer URLs
|
|
14
|
+
|
|
15
|
+
| Chain | Transaction | Wallet | Token |
|
|
16
|
+
|-------|------------|--------|-------|
|
|
17
|
+
| solana | `https://solscan.io/tx/{sig}` | `https://solscan.io/account/{addr}` | `https://solscan.io/token/{addr}` |
|
|
18
|
+
| ethereum | `https://etherscan.io/tx/{hash}` | `https://etherscan.io/address/{addr}` | `https://etherscan.io/token/{addr}` |
|
|
19
|
+
| base | `https://basescan.org/tx/{hash}` | `https://basescan.org/address/{addr}` | `https://basescan.org/token/{addr}` |
|
|
20
|
+
| polygon | `https://polygonscan.com/tx/{hash}` | `https://polygonscan.com/address/{addr}` | `https://polygonscan.com/token/{addr}` |
|
|
21
|
+
| arbitrum | `https://arbiscan.io/tx/{hash}` | `https://arbiscan.io/address/{addr}` | `https://arbiscan.io/token/{addr}` |
|
|
22
|
+
| optimism | `https://optimistic.etherscan.io/tx/{hash}` | `https://optimistic.etherscan.io/address/{addr}` | `https://optimistic.etherscan.io/token/{addr}` |
|
|
23
|
+
| bnb | `https://bscscan.com/tx/{hash}` | `https://bscscan.com/address/{addr}` | `https://bscscan.com/token/{addr}` |
|
|
24
|
+
| avalanche | `https://snowscan.xyz/tx/{hash}` | `https://snowscan.xyz/address/{addr}` | `https://snowscan.xyz/token/{addr}` |
|
|
25
|
+
| bitcoin | `https://mempool.space/tx/{txid}` | `https://mempool.space/address/{addr}` | — |
|
|
26
|
+
|
|
27
|
+
## Open a transaction
|
|
28
|
+
|
|
29
|
+
After a swap or bridge, extract the chain and tx hash, then open:
|
|
30
|
+
|
|
31
|
+
```bash
|
|
32
|
+
# macOS
|
|
33
|
+
open "https://solscan.io/tx/5rQ52JVb6q7H..."
|
|
34
|
+
|
|
35
|
+
# Linux
|
|
36
|
+
xdg-open "https://etherscan.io/tx/0xabcd..."
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### From swap/bridge output
|
|
40
|
+
|
|
41
|
+
`mp token swap` and `mp token bridge` return a result with the transaction signature. Use the chain to pick the correct explorer.
|
|
42
|
+
|
|
43
|
+
```bash
|
|
44
|
+
RESULT=$(mp -f compact token swap --wallet main --chain solana \
|
|
45
|
+
--from-token EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v \
|
|
46
|
+
--from-amount 1 \
|
|
47
|
+
--to-token So11111111111111111111111111111111111111111)
|
|
48
|
+
|
|
49
|
+
# Open in browser
|
|
50
|
+
SIG=$(echo "$RESULT" | jq -r '.signature')
|
|
51
|
+
open "https://solscan.io/tx/$SIG"
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
### From transaction list
|
|
55
|
+
|
|
56
|
+
`mp transaction list` returns transactions with `from.txHash` and `to.txHash`. Use the chain field to pick the explorer:
|
|
57
|
+
|
|
58
|
+
```bash
|
|
59
|
+
# View most recent transaction
|
|
60
|
+
TX=$(mp -f compact transaction list --wallet <addr> | jq -r '.items[0].from.txHash')
|
|
61
|
+
CHAIN=$(mp -f compact transaction list --wallet <addr> | jq -r '.items[0].from.chain')
|
|
62
|
+
# Build URL from chain → explorer table above
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
## Open a wallet
|
|
66
|
+
|
|
67
|
+
View all on-chain activity for a wallet address:
|
|
68
|
+
|
|
69
|
+
```bash
|
|
70
|
+
# Solana wallet
|
|
71
|
+
open "https://solscan.io/account/N39jn2g1tA7dmdyyoHt9yiQegQoVhnfQzq1ZzuZRF9e"
|
|
72
|
+
|
|
73
|
+
# EVM wallet (same address works on any EVM explorer)
|
|
74
|
+
open "https://etherscan.io/address/0xf9e39F70d7636902e57a89C18B1BE39EBb5b9589"
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
Get wallet addresses from: `mp wallet list` or `mp wallet retrieve --wallet <name>`
|
|
78
|
+
|
|
79
|
+
## Open a token page
|
|
80
|
+
|
|
81
|
+
View token contract, holders, and market data on the explorer:
|
|
82
|
+
|
|
83
|
+
```bash
|
|
84
|
+
# USDC on Solana
|
|
85
|
+
open "https://solscan.io/token/EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v"
|
|
86
|
+
|
|
87
|
+
# USDC on Ethereum
|
|
88
|
+
open "https://etherscan.io/token/0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48"
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
Get token addresses from: `mp token search --query "USDC" --chain solana`
|
|
92
|
+
|
|
93
|
+
## Open a checkout URL
|
|
94
|
+
|
|
95
|
+
`mp buy` returns a checkout URL. Open it directly:
|
|
96
|
+
|
|
97
|
+
```bash
|
|
98
|
+
URL=$(mp -f compact buy --token sol --amount 1 --wallet <addr> --email <email> | jq -r '.url')
|
|
99
|
+
open "$URL"
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
## Platform detection
|
|
103
|
+
|
|
104
|
+
```bash
|
|
105
|
+
if [[ "$OSTYPE" == "darwin"* ]]; then
|
|
106
|
+
open "$URL"
|
|
107
|
+
else
|
|
108
|
+
xdg-open "$URL"
|
|
109
|
+
fi
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
## Tips
|
|
113
|
+
|
|
114
|
+
- After any swap, bridge, or transfer, offer to open the result in the explorer
|
|
115
|
+
- EVM wallets share one address across all EVM chains — the same address works on etherscan, basescan, polygonscan, etc.
|
|
116
|
+
- Bitcoin uses `mempool.space` — no token pages, just transactions and addresses
|
|
117
|
+
- Solana signatures are base58 strings, EVM tx hashes start with `0x`
|
|
118
|
+
|
|
119
|
+
## Related skills
|
|
120
|
+
|
|
121
|
+
- **moonpay-swap-tokens** — Swap and bridge commands that produce transaction signatures
|
|
122
|
+
- **moonpay-buy-crypto** — Buy commands that return checkout URLs
|
|
123
|
+
- **moonpay-check-wallet** — Get wallet addresses to view on explorers
|
|
@@ -22,7 +22,7 @@ mp buy \
|
|
|
22
22
|
|
|
23
23
|
## Supported tokens
|
|
24
24
|
|
|
25
|
-
`
|
|
25
|
+
`btc`, `sol`, `eth`, `trx`, `pol_polygon`, `usdc`, `usdc_sol`, `usdc_base`, `usdc_arbitrum`, `usdc_optimism`, `usdc_polygon`, `usdt_trx`, `eth_polygon`, `eth_optimism`, `eth_base`, `eth_arbitrum`
|
|
26
26
|
|
|
27
27
|
## Example flow
|
|
28
28
|
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: moonpay-export-data
|
|
3
|
+
description: Export portfolio balances and transaction history to CSV or JSON files. Use for spreadsheets, tax reporting, or record-keeping.
|
|
4
|
+
tags: [portfolio, export]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Export data
|
|
8
|
+
|
|
9
|
+
## Goal
|
|
10
|
+
|
|
11
|
+
Save portfolio snapshots and transaction history to CSV or JSON files using `mp` output piped through `jq`. Useful for spreadsheets, tax reporting, and record-keeping.
|
|
12
|
+
|
|
13
|
+
## Prerequisites
|
|
14
|
+
|
|
15
|
+
- `jq` installed: `which jq`
|
|
16
|
+
- Default output directory: `~/Documents/moonpay/` (create if needed)
|
|
17
|
+
|
|
18
|
+
## Portfolio to CSV
|
|
19
|
+
|
|
20
|
+
Export all token balances for a wallet on a specific chain:
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
mkdir -p ~/Documents/moonpay
|
|
24
|
+
|
|
25
|
+
# Header + data
|
|
26
|
+
echo "symbol,name,amount,usd_value,price" > ~/Documents/moonpay/portfolio-$(date +%Y%m%d).csv
|
|
27
|
+
|
|
28
|
+
mp -f compact token balance list --wallet <address> --chain solana \
|
|
29
|
+
| jq -r '.items[] | [.symbol, .name, .balance.amount, .balance.value, .balance.price] | @csv' \
|
|
30
|
+
>> ~/Documents/moonpay/portfolio-$(date +%Y%m%d).csv
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
### Multi-chain portfolio
|
|
34
|
+
|
|
35
|
+
Loop over chains and append to one file:
|
|
36
|
+
|
|
37
|
+
```bash
|
|
38
|
+
FILE=~/Documents/moonpay/portfolio-$(date +%Y%m%d).csv
|
|
39
|
+
echo "chain,symbol,name,amount,usd_value,price" > "$FILE"
|
|
40
|
+
|
|
41
|
+
for CHAIN in solana ethereum base polygon arbitrum; do
|
|
42
|
+
mp -f compact token balance list --wallet <address> --chain "$CHAIN" \
|
|
43
|
+
| jq -r --arg chain "$CHAIN" '.items[] | [$chain, .symbol, .name, .balance.amount, .balance.value, .balance.price] | @csv' \
|
|
44
|
+
>> "$FILE" 2>/dev/null
|
|
45
|
+
done
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
Note: EVM wallets share one address across all EVM chains. Solana uses a different address.
|
|
49
|
+
|
|
50
|
+
## Transaction history to CSV
|
|
51
|
+
|
|
52
|
+
Export swap and bridge history. These are transactions executed via the CLI and registered with swaps.xyz — not all on-chain activity.
|
|
53
|
+
|
|
54
|
+
```bash
|
|
55
|
+
echo "date,type,from_chain,from_token,from_amount,to_chain,to_token,to_amount,usd,status" \
|
|
56
|
+
> ~/Documents/moonpay/transactions-$(date +%Y%m%d).csv
|
|
57
|
+
|
|
58
|
+
mp -f compact transaction list --wallet <address> \
|
|
59
|
+
| jq -r '.items[] | [
|
|
60
|
+
.transactionId,
|
|
61
|
+
.type,
|
|
62
|
+
.from.chain, .from.token, .from.amount,
|
|
63
|
+
.to.chain, .to.token, .to.amount,
|
|
64
|
+
.usd,
|
|
65
|
+
.status
|
|
66
|
+
] | @csv' \
|
|
67
|
+
>> ~/Documents/moonpay/transactions-$(date +%Y%m%d).csv
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### Filter by chain
|
|
71
|
+
|
|
72
|
+
```bash
|
|
73
|
+
mp -f compact transaction list --wallet <address> --chain solana \
|
|
74
|
+
| jq -r '.items[] | ...' >> transactions.csv
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
## Portfolio to JSON
|
|
78
|
+
|
|
79
|
+
For structured data or programmatic use:
|
|
80
|
+
|
|
81
|
+
```bash
|
|
82
|
+
mp -f compact token balance list --wallet <address> --chain solana \
|
|
83
|
+
| jq '.items | map({symbol, amount: .balance.amount, usd: .balance.value})' \
|
|
84
|
+
> ~/Documents/moonpay/portfolio-$(date +%Y%m%d).json
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
## Open exported file
|
|
88
|
+
|
|
89
|
+
After writing the file, open it in the default app:
|
|
90
|
+
|
|
91
|
+
```bash
|
|
92
|
+
# macOS — opens in Numbers/Excel
|
|
93
|
+
open ~/Documents/moonpay/portfolio-$(date +%Y%m%d).csv
|
|
94
|
+
|
|
95
|
+
# Linux
|
|
96
|
+
xdg-open ~/Documents/moonpay/portfolio-$(date +%Y%m%d).csv
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
## Tips
|
|
100
|
+
|
|
101
|
+
- `jq @csv` handles proper CSV escaping (quotes, commas in values)
|
|
102
|
+
- Date-stamp filenames to keep a history: `portfolio-20260222.csv`
|
|
103
|
+
- `mp transaction list` only includes CLI-executed swaps/bridges registered via swaps.xyz, not all on-chain transactions
|
|
104
|
+
- For a quick summary without exporting, use `mp token balance list --wallet <addr> --chain <chain>` directly
|
|
105
|
+
- EVM address is the same across ethereum, base, polygon, arbitrum, optimism, bnb, avalanche
|
|
106
|
+
|
|
107
|
+
## Related skills
|
|
108
|
+
|
|
109
|
+
- **moonpay-check-wallet** — View balances interactively
|
|
110
|
+
- **moonpay-block-explorer** — Open exported transactions in block explorers
|
|
111
|
+
- **moonpay-trading-automation** — Combine with scheduled exports for daily snapshots
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: moonpay-polymarket-ready
|
|
3
|
+
description: Fund a Polygon wallet for Polymarket trading. Buy POL for gas and bridge or buy USDC.e so the wallet is ready to trade.
|
|
4
|
+
tags: [trading, setup]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Polymarket ready
|
|
8
|
+
|
|
9
|
+
## Goal
|
|
10
|
+
|
|
11
|
+
Get a Polygon wallet funded with POL (gas) and USDC.e (trading) so it's ready for Polymarket.
|
|
12
|
+
|
|
13
|
+
Polymarket runs on Polygon. To trade, the user needs:
|
|
14
|
+
- **POL** — native gas token for transaction fees
|
|
15
|
+
- **USDC.e** (`0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174`) — the token Polymarket uses for bets
|
|
16
|
+
|
|
17
|
+
## Key addresses
|
|
18
|
+
|
|
19
|
+
| Token | Chain | Address |
|
|
20
|
+
|-------|-------|---------|
|
|
21
|
+
| POL (native) | Polygon | `0x0000000000000000000000000000000000000000` |
|
|
22
|
+
| USDC.e | Polygon | `0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174` |
|
|
23
|
+
| ETH (native) | Ethereum | `0x0000000000000000000000000000000000000000` |
|
|
24
|
+
|
|
25
|
+
## Workflow
|
|
26
|
+
|
|
27
|
+
### 1. Check or create wallet
|
|
28
|
+
|
|
29
|
+
```bash
|
|
30
|
+
mp wallet list
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
The user's Polygon address is the same as their Ethereum address (EVM wallets share one address across all EVM chains).
|
|
34
|
+
|
|
35
|
+
If no wallets exist, create one:
|
|
36
|
+
|
|
37
|
+
```bash
|
|
38
|
+
mp wallet create --name main
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
### 2. Check existing Polygon balances
|
|
42
|
+
|
|
43
|
+
```bash
|
|
44
|
+
mp token balance list --wallet <eth-address> --chain polygon
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
If the wallet already has POL and USDC.e, they're set.
|
|
48
|
+
|
|
49
|
+
### 3. Get POL for gas
|
|
50
|
+
|
|
51
|
+
Buy POL directly with fiat — easiest way to get gas on Polygon:
|
|
52
|
+
|
|
53
|
+
```bash
|
|
54
|
+
mp buy --token pol_polygon --amount 5 --wallet <eth-address> --email <email>
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
Alternatively, bridge ETH → POL if the user already has ETH:
|
|
58
|
+
|
|
59
|
+
```bash
|
|
60
|
+
mp token bridge \
|
|
61
|
+
--from-wallet <wallet-name> --from-chain ethereum \
|
|
62
|
+
--from-token 0x0000000000000000000000000000000000000000 \
|
|
63
|
+
--from-amount 0.001 \
|
|
64
|
+
--to-chain polygon \
|
|
65
|
+
--to-token 0x0000000000000000000000000000000000000000
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
~$2-5 worth of POL covers hundreds of transactions.
|
|
69
|
+
|
|
70
|
+
### 4. Get USDC.e for trading
|
|
71
|
+
|
|
72
|
+
Bridge ETH on Ethereum to USDC.e on Polygon in one step:
|
|
73
|
+
|
|
74
|
+
```bash
|
|
75
|
+
mp token bridge \
|
|
76
|
+
--from-wallet <wallet-name> --from-chain ethereum \
|
|
77
|
+
--from-token 0x0000000000000000000000000000000000000000 \
|
|
78
|
+
--from-amount 0.005 \
|
|
79
|
+
--to-chain polygon \
|
|
80
|
+
--to-token 0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
Alternatively, if the user already has USDC on Ethereum, bridge it directly:
|
|
84
|
+
|
|
85
|
+
```bash
|
|
86
|
+
mp token bridge \
|
|
87
|
+
--from-wallet <wallet-name> --from-chain ethereum \
|
|
88
|
+
--from-token 0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48 \
|
|
89
|
+
--from-amount 10 \
|
|
90
|
+
--to-chain polygon \
|
|
91
|
+
--to-token 0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
### 5. Verify
|
|
95
|
+
|
|
96
|
+
```bash
|
|
97
|
+
mp token balance list --wallet <eth-address> --chain polygon
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
Confirm both POL and USDC.e are present.
|
|
101
|
+
|
|
102
|
+
## Tips
|
|
103
|
+
|
|
104
|
+
- Bridge times from Ethereum → Polygon are typically 5-20 seconds
|
|
105
|
+
- POL is very cheap for gas — a few dollars covers hundreds of transactions
|
|
106
|
+
- The fiat buy option (`mp buy`) is the fastest path if the user has no crypto yet
|
|
107
|
+
|
|
108
|
+
## Related skills
|
|
109
|
+
|
|
110
|
+
- **moonpay-swap-tokens** — Bridge commands and supported chains
|
|
111
|
+
- **moonpay-check-wallet** — Check Polygon balances
|
|
112
|
+
- **moonpay-buy-crypto** — Buy POL or ETH with fiat
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: moonpay-price-alerts
|
|
3
|
+
description: Set up desktop price alerts that notify you when tokens hit target prices. Observe-only — no trading, just notifications.
|
|
4
|
+
tags: [alerts, research]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Price alerts
|
|
8
|
+
|
|
9
|
+
## Goal
|
|
10
|
+
|
|
11
|
+
Monitor token prices and get desktop notifications when they cross a threshold. Uses `mp token retrieve` for price checks and OS notifications (`osascript`/`notify-send`) for alerts. Observe-only — no funds at risk.
|
|
12
|
+
|
|
13
|
+
## Prerequisites
|
|
14
|
+
|
|
15
|
+
- `mp` binary on PATH: `which mp`
|
|
16
|
+
- `jq` installed: `which jq`
|
|
17
|
+
- macOS: `osascript` (built-in) or Linux: `notify-send` (`sudo apt install libnotify-bin`)
|
|
18
|
+
|
|
19
|
+
## One-shot alert
|
|
20
|
+
|
|
21
|
+
"Tell me when SOL drops below $80" — checks every 5 minutes, fires once, then disables itself.
|
|
22
|
+
|
|
23
|
+
### Script: `~/.config/moonpay/scripts/alert-sol-below-80.sh`
|
|
24
|
+
|
|
25
|
+
```bash
|
|
26
|
+
#!/bin/bash
|
|
27
|
+
set -euo pipefail
|
|
28
|
+
|
|
29
|
+
MP="$(which mp)"
|
|
30
|
+
LOG="$HOME/.config/moonpay/logs/alerts.log"
|
|
31
|
+
mkdir -p "$(dirname "$LOG")"
|
|
32
|
+
log() { echo "[$(date -u +%Y-%m-%dT%H:%M:%SZ)] $*" >> "$LOG"; }
|
|
33
|
+
|
|
34
|
+
# --- Config ---
|
|
35
|
+
TOKEN="So11111111111111111111111111111111111111111"
|
|
36
|
+
CHAIN="solana"
|
|
37
|
+
SYMBOL="SOL"
|
|
38
|
+
TARGET=80
|
|
39
|
+
DIRECTION="below" # "above" or "below"
|
|
40
|
+
SCRIPT_NAME="alert-sol-below-80"
|
|
41
|
+
|
|
42
|
+
# --- Check price ---
|
|
43
|
+
PRICE=$("$MP" -f compact token retrieve --token "$TOKEN" --chain "$CHAIN" | jq -r '.marketData.price')
|
|
44
|
+
|
|
45
|
+
if [ -z "$PRICE" ] || [ "$PRICE" = "null" ]; then
|
|
46
|
+
log "ALERT $SCRIPT_NAME: price fetch failed, skipping"
|
|
47
|
+
exit 0
|
|
48
|
+
fi
|
|
49
|
+
|
|
50
|
+
# --- Compare ---
|
|
51
|
+
TRIGGERED=false
|
|
52
|
+
if [ "$DIRECTION" = "below" ] && (( $(echo "$PRICE < $TARGET" | bc -l) )); then
|
|
53
|
+
TRIGGERED=true
|
|
54
|
+
elif [ "$DIRECTION" = "above" ] && (( $(echo "$PRICE > $TARGET" | bc -l) )); then
|
|
55
|
+
TRIGGERED=true
|
|
56
|
+
fi
|
|
57
|
+
|
|
58
|
+
if [ "$TRIGGERED" = true ]; then
|
|
59
|
+
MSG="$SYMBOL is $DIRECTION \$$TARGET — currently \$$PRICE"
|
|
60
|
+
log "ALERT $SCRIPT_NAME: $MSG"
|
|
61
|
+
|
|
62
|
+
# Desktop notification
|
|
63
|
+
if [[ "$OSTYPE" == "darwin"* ]]; then
|
|
64
|
+
osascript -e "display notification \"$MSG\" with title \"MoonPay Alert\" sound name \"Glass\""
|
|
65
|
+
else
|
|
66
|
+
notify-send "MoonPay Alert" "$MSG"
|
|
67
|
+
fi
|
|
68
|
+
|
|
69
|
+
# Self-disable (one-shot)
|
|
70
|
+
if [[ "$OSTYPE" == "darwin"* ]]; then
|
|
71
|
+
launchctl unload "$HOME/Library/LaunchAgents/com.moonpay.${SCRIPT_NAME}.plist" 2>/dev/null || true
|
|
72
|
+
else
|
|
73
|
+
crontab -l | grep -v "$SCRIPT_NAME" | crontab -
|
|
74
|
+
fi
|
|
75
|
+
log "ALERT $SCRIPT_NAME: disabled after trigger"
|
|
76
|
+
else
|
|
77
|
+
log "ALERT $SCRIPT_NAME: $SYMBOL at \$$PRICE — not triggered ($DIRECTION $TARGET)"
|
|
78
|
+
fi
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
### Schedule
|
|
82
|
+
|
|
83
|
+
Check every 5 minutes:
|
|
84
|
+
|
|
85
|
+
```bash
|
|
86
|
+
# cron (Linux)
|
|
87
|
+
*/5 * * * * ~/.config/moonpay/scripts/alert-sol-below-80.sh # moonpay:alert-sol-below-80
|
|
88
|
+
|
|
89
|
+
# launchd (macOS) — use StartInterval of 300 seconds in the plist
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
Launchd plist at `~/Library/LaunchAgents/com.moonpay.alert-sol-below-80.plist`:
|
|
93
|
+
|
|
94
|
+
```xml
|
|
95
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
96
|
+
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
97
|
+
<plist version="1.0">
|
|
98
|
+
<dict>
|
|
99
|
+
<key>Label</key>
|
|
100
|
+
<string>com.moonpay.alert-sol-below-80</string>
|
|
101
|
+
<key>ProgramArguments</key>
|
|
102
|
+
<array>
|
|
103
|
+
<string>/bin/bash</string>
|
|
104
|
+
<string>/Users/USERNAME/.config/moonpay/scripts/alert-sol-below-80.sh</string>
|
|
105
|
+
</array>
|
|
106
|
+
<key>StartInterval</key>
|
|
107
|
+
<integer>300</integer>
|
|
108
|
+
<key>StandardErrorPath</key>
|
|
109
|
+
<string>/Users/USERNAME/.config/moonpay/logs/alert-sol-below-80.err</string>
|
|
110
|
+
</dict>
|
|
111
|
+
</plist>
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
Load: `launchctl load ~/Library/LaunchAgents/com.moonpay.alert-sol-below-80.plist`
|
|
115
|
+
|
|
116
|
+
**Important:** Replace `USERNAME` with the actual username. Tilde does not expand in plist files.
|
|
117
|
+
|
|
118
|
+
## Recurring alert
|
|
119
|
+
|
|
120
|
+
"Alert me every hour while ETH is above $2000" — keeps firing on each check, doesn't self-disable.
|
|
121
|
+
|
|
122
|
+
Same script as above but remove the self-disable block. The alert fires every time the condition is met, until the user manually removes it.
|
|
123
|
+
|
|
124
|
+
## Managing alerts
|
|
125
|
+
|
|
126
|
+
### List active alerts
|
|
127
|
+
|
|
128
|
+
```bash
|
|
129
|
+
# macOS
|
|
130
|
+
launchctl list | grep moonpay
|
|
131
|
+
|
|
132
|
+
# Linux
|
|
133
|
+
crontab -l | grep moonpay
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
### Remove an alert
|
|
137
|
+
|
|
138
|
+
```bash
|
|
139
|
+
# macOS
|
|
140
|
+
launchctl unload ~/Library/LaunchAgents/com.moonpay.alert-sol-below-80.plist
|
|
141
|
+
rm ~/Library/LaunchAgents/com.moonpay.alert-sol-below-80.plist
|
|
142
|
+
|
|
143
|
+
# Linux
|
|
144
|
+
crontab -l | grep -v "alert-sol-below-80" | crontab -
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
### View alert history
|
|
148
|
+
|
|
149
|
+
```bash
|
|
150
|
+
tail -50 ~/.config/moonpay/logs/alerts.log
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
## Tips
|
|
154
|
+
|
|
155
|
+
- Price checks via `mp token retrieve` are free — no gas costs
|
|
156
|
+
- 5-minute intervals are reasonable; don't go below 1 minute
|
|
157
|
+
- Use `mp token search --query "SOL" --chain solana` to resolve token addresses
|
|
158
|
+
- Alerts log to `~/.config/moonpay/logs/alerts.log` — check this to verify they're running
|
|
159
|
+
- The machine must be logged in for notifications and keychain access to work
|
|
160
|
+
- `bc -l` handles decimal comparison; if unavailable, use `awk "BEGIN {exit !($PRICE < $TARGET)}"`
|
|
161
|
+
- This skill is observe-only — for automated buying/selling, see **moonpay-trading-automation**
|
|
162
|
+
|
|
163
|
+
## Related skills
|
|
164
|
+
|
|
165
|
+
- **moonpay-trading-automation** — Automated trading (DCA, limit orders, stop losses)
|
|
166
|
+
- **moonpay-discover-tokens** — Research tokens and get current prices
|
|
167
|
+
- **moonpay-check-wallet** — Check portfolio before setting alerts
|