-
Notifications
You must be signed in to change notification settings - Fork 42
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
Premium #264
base: master
Are you sure you want to change the base?
Premium #264
Conversation
dc5b87f
to
8870169
Compare
6f44cbc
to
4c591cc
Compare
Asking for opinions: Should we have fine grained configuration to allow for setting certain peers a different premium fee rate? |
I think no. But allow separate premiums for received swap ins and swap outs, including negative values. This will allow managing liquidity among BTC, LBTC and Lightning. |
In the future, it may be better to allow premiums to be set according to the degree of use, such as channels that flow easily in both directions or channels that flow only in one direction. |
It is possible to configure swap in and swap out in |
Yes I think so. Channels may have different characteristics that would benefit from having individual premium/discount rates to incentivize swapping in one direction or the other, similar to how routing fee rates can be used to influence how a channel is used? |
e49ad78
to
65dcce8
Compare
Looks like the premium info is missing from the CLN
|
Would it be useful to have the premium rate limit be a config option in |
Hitting this with CLN as sender:
|
CLN plugin crashed when trying a
Looks like
The logs appear to show that the swap I attempted succeeded however.
|
Thanks for the test. |
FIXED. SwapInPremiumRatePPM and SwapInPremiumRatePPM are added to the ListPeers. I rearranged the order of commands. The source of the information was an error, which I corrected. |
@YusukeShimizu Hello. Do you plan RPC endpoints to configure premium rates? |
I have no definite plan. There are some opinions that a fine-grained premium setting is needed, so I may need to think about an appropriate design for that (such as having RPC endpoints, etc.) |
At 9c34c47 my
|
75fb65c
to
d8b683d
Compare
I fixed it on d8b683d |
In summary, I am planning the following updates:
|
f2fd6c5
to
acdc3af
Compare
f56072d
to
b80f269
Compare
I have implemented #264 (comment). To make it easier to update the premium, I have updated the architecture from using policy.conf to using a key-value store for configuration. For usage instructions, please refer to https://github.com/YusukeShimizu/peerswap/blob/premium-feature/docs/usage.md#premium. The gRPC interface can be found here: https://github.com/YusukeShimizu/peerswap/blob/premium-feature/peerswaprpc/peerswaprpc.proto#L35-L42. |
Swap-Outs also support a premium limit parameter, I suppose. |
This commit adds protocol update and impl of premium. * Swap In * Responder/Taker requests Premium, Maker adds it to Opening Tx (Taker collects Premium in Claim tx) * Swap Out * Responder/Maker requests Premium and Taker tops it up on Claim invoice (Maker collects Premium on Claim invoice)
This commit includes the premium rate in the poll message so that the premium set for each peer can be confirmed.
This commit adds premium options. Also, the sample settings and document have been updated accordingly.
This commit is to modify and add integration tests for the addition of premium.
Add item to peerSwapPeer to display Premium Rate Ppm. Set the value retrieved from the poll so that it can be checked with the ListPeers command.
Corrected where to get premium limit at swapout in CheckPremiumAmount and OnSwapOutRequestReceived. Also, unit tests for CheckPremiumAmount have been added.
I rearranged the order of commands for swapin.
When the reload policy was done, the configuration values were updated, but they were not displayed. Definitions are being added so that they are displayed.
Allow setting different premium values for BTC and LBTC. This change also enables users to configure individual premiums for each peer, providing more granular control over pricing and liquidity. - Added separate premium fields for BTC and LBTC. - Implemented logic to apply peer-specific premiums.
Remove policy.conf management and switch to bbolt db for managing premium settings. Provide APIs for cln and lnd to interact with premium. - Implement Observer for premium updates - Poller detects updates and performs polling
7223f72
to
17b0abc
Compare
update usage instructions for peerswap-swap-out to include premium limit.
The premium docs for CLN seem to use the incorrect command arguments:
Omitting the
|
Where do I configure the premium rate limit that is mentioned here? |
The documentation contains an error. Could you try setting the premium limit and testing it, as shown in the example command for CLN’s swapin? Swap-in Command Example. $ ./builds/peerswap/out/pscli swapin --channel_id 248103699313721344 --sat_amt 10000001 --asset lbtc 10000 |
This PR adds premium to peerswap.
design doc
Usage
doing swap
A premium limit will be added to the existing swap command.
If not set, default is 0.
cln
lnd
configure premium rate
The premium rate is pert per million and can be set for swapin and swapout respectively.
swap_amount * premium_rate_ppm / 1000000
is the premium.Negative values can also be set to give a discount
For usage instructions, please refer to YusukeShimizu/peerswap@premium-feature/docs/usage.md#premium.
The gRPC interface can be found here: YusukeShimizu/peerswap@premium-feature/peerswaprpc/peerswaprpc.proto#L35-L42.
examples
If the max_acceptable_premium is lower than responder.
./bin/pscli peerswap1 swapout --channel_id $CHANID --sat_amt 1000000 --asset btc --premium_limit 1 2023/12/23 02:02:36 rpc error: code = Unknown desc = from the LND peer: unacceptable premium: 100, limit: 1
success