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

Premium #264

Draft
wants to merge 13 commits into
base: master
Choose a base branch
from
Draft

Conversation

YusukeShimizu
Copy link
Contributor

@YusukeShimizu YusukeShimizu commented Dec 23, 2023

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

lightning-cli peerswap-swap-out [short channel id] [amount in sats] [asset: btc or lbtc] [premium limit in sats]

lnd

pscli swapout --sat_amt=[sat amount] --channel_id=[chan_id from above] --asset=btc --premium_limit=[premium limit]

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

./bin/pscli peerswap1 swapout --channel_id $CHANID --sat_amt 1000000 --asset btc --premium_limit 100
{
  "swap": {
    "id": "eb5f41a515f737956300a38ab1f5286a67d580c4d3f838afdf48537c1133ed69",
    "created_at": "1702532654",
    "asset": "btc",
    "type": "swap-out",
    "role": "sender",
    "state": "State_SwapOutSender_AwaitTxConfirmation",
    "initiator_node_id": "02ea1fd791bb1b639e7119ac54505e3f553a7bb942877ccbb359affa8547046988",
    "peer_node_id": "034066fecfcdad7cb2f002c8c4234dbab26688db9617509ede4c7372c79ab94d0d",
    "amount": "1000000",
    "channel_id": "110:1:1",
    "opening_tx_id": "83f0b1174a3c55934ca9fa60398dbdfa76394db1450cbe2c1d2369ef80095b15",
    "claim_tx_id": "",
    "cancel_message": "",
    "lnd_chan_id": "120946279120897",
    "premium": "100"
  }
}

@YusukeShimizu YusukeShimizu changed the title Premium feature Premium Dec 23, 2023
@YusukeShimizu YusukeShimizu force-pushed the premium-feature branch 2 times, most recently from dc5b87f to 8870169 Compare December 23, 2023 05:15
@YusukeShimizu YusukeShimizu changed the title Premium [wip]Premium Dec 23, 2023
@YusukeShimizu YusukeShimizu force-pushed the premium-feature branch 7 times, most recently from 6f44cbc to 4c591cc Compare December 24, 2023 04:02
@YusukeShimizu YusukeShimizu changed the title [wip]Premium Premium Dec 25, 2023
@wtogami
Copy link
Contributor

wtogami commented Dec 25, 2023

Asking for opinions: Should we have fine grained configuration to allow for setting certain peers a different premium fee rate?
I suppose that would complicate things a lot and make the configuration look ugly. But is this a highly desirable feature?

@Impa10r
Copy link
Contributor

Impa10r commented Dec 25, 2023

Asking for opinions: Should we have fine grained configuration to allow for setting certain peers a different premium fee rate? I suppose that would complicate things a lot and make the configuration look ugly. But is this a highly desirable feature?

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.

@YusukeShimizu
Copy link
Contributor Author

YusukeShimizu commented Dec 27, 2023

Asking for opinions: Should we have fine grained configuration to allow for setting certain peers a different premium fee rate?
I suppose that would complicate things a lot and make the configuration look ugly. But is this a highly desirable feature?

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.
However, since this has nothing to do with protocol changes, I think there is an option to not implement it in this PR and consider it later.

@YusukeShimizu
Copy link
Contributor Author

But allow separate premiums for received swap ins and swap outs, including negative values. This will allow managing liquidity among BTC, LBTC and Lightning.

It is possible to configure swap in and swap out in policy.conf, including negative values.

@grubles
Copy link
Collaborator

grubles commented Jan 16, 2024

Asking for opinions: Should we have fine grained configuration to allow for setting certain peers a different premium fee rate? I suppose that would complicate things a lot and make the configuration look ugly. But is this a highly desirable feature?

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?

@YusukeShimizu YusukeShimizu force-pushed the premium-feature branch 2 times, most recently from e49ad78 to 65dcce8 Compare January 20, 2024 09:08
@grubles
Copy link
Collaborator

grubles commented Jan 26, 2024

Looks like the premium info is missing from the CLN listpeers:

$ lightning-cli --signet peerswap-listpeers
[
   {
      "nodeid": "035ca2fe4793a5e789ce846062eb4834f573c060d9200ce77544a29b48a0aa5923",
      "swaps_allowed": true,
      "supported_assets": [
         "btc",
         "lbtc"
      ],
      "channels": [
         {
            "short_channel_id": "140490x1x0",
            "local_balance": 224000900,
            "remote_balance": 75999100,
            "state": "CHANNELD_NORMAL"
         },
         {
            "short_channel_id": "162922x1x0",
            "local_balance": 201341,
            "remote_balance": 18668659,
            "state": "CHANNELD_NORMAL"
         }
      ],
      "sent": {
         "total_swaps_out": 0,
         "total_swaps_in": 0,
         "total_sats_swapped_out": 0,
         "total_sats_swapped_in": 0
      },
      "received": {
         "total_swaps_out": 10,
         "total_swaps_in": 12,
         "total_sats_swapped_out": 238000000,
         "total_sats_swapped_in": 144000000
      }
   }
]

@grubles
Copy link
Collaborator

grubles commented Jan 26, 2024

Would it be useful to have the premium rate limit be a config option in policy.conf too?

@grubles
Copy link
Collaborator

grubles commented Jan 26, 2024

Hitting this with CLN as sender:

$ lightning-cli --signet peerswap-swap-out 140490x1x0 100000000 lbtc 1000000
{
   "code": -32603,
   "message": "-32603: Incompatible types: SwapOut.bool (bool) != float64"
}

@grubles
Copy link
Collaborator

grubles commented Jan 26, 2024

CLN plugin crashed when trying a listswaps:

$ lightning-cli --signet peerswap-listswaps
{
   "code": -4,
   "message": "Plugin terminated before replying to RPC call."
}

Looks like peerswapd segfaulted when trying listswaps too:

panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x20 pc=0xdb1460]

goroutine 142825 [running]:
github.com/elementsproject/peerswap/swap.(*SwapData).GetPremium(...)
        /home/user/builds/master_peerswap/swap/swap.go:239
github.com/elementsproject/peerswap/peerswaprpc.PrettyprintFromServiceSwap(0xc0002c5600)
        /home/user/builds/master_peerswap/peerswaprpc/server.go:576 +0x300
github.com/elementsproject/peerswap/peerswaprpc.(*PeerswapServer).ListSwaps(0xf6cf00?, {0xc0006f4120?, 0x498fe6?}, 0x0?)
        /home/user/builds/master_peerswap/peerswaprpc/server.go:321 +0xfd
github.com/elementsproject/peerswap/peerswaprpc._PeerSwap_ListSwaps_Handler({0x10505a0?, 0xc000400840}, {0x12b8dd8, 0xc0006f40f0}, 0xc00043e620, 0x0)
        /home/user/builds/master_peerswap/peerswaprpc/peerswaprpc_grpc.pb.go:357 +0x169
google.golang.org/grpc.(*Server).processUnaryRPC(0xc000320b40, {0x12c0880, 0xc00040e820}, 0xc0006e6360, 0xc00001f8f0, 0x199ffc8, 0x0)
        /home/user/go/pkg/mod/google.golang.org/[email protected]/server.go:1318 +0xb18
google.golang.org/grpc.(*Server).handleStream(0xc000320b40, {0x12c0880, 0xc00040e820}, 0xc0006e6360, 0x0)
        /home/user/go/pkg/mod/google.golang.org/[email protected]/server.go:1659 +0x9e7
google.golang.org/grpc.(*Server).serveStreams.func1.2()
        /home/user/go/pkg/mod/google.golang.org/[email protected]/server.go:955 +0x8d
created by google.golang.org/grpc.(*Server).serveStreams.func1 in goroutine 142824
        /home/user/go/pkg/mod/google.golang.org/[email protected]/server.go:953 +0x246

The logs appear to show that the swap I attempted succeeded however.

2024/01/26 19:03:15 [INFO] [Swap:cdd8bff7205897ad5ed687e830c434a31abf80fdca1f011d32e256bbab836057] Swap claimed with preimage 6fb9a8eb04df189ffe3f78772ff74b29c36ab55ef3923edf5a6b56999cd8cc09

@YusukeShimizu
Copy link
Contributor Author

Thanks for the test.
Perhaps some of the behavior is a bug.
I'll investigate and fix it.

@YusukeShimizu
Copy link
Contributor Author

YusukeShimizu commented Jan 30, 2024

FIXED.

premium info is missing from the CLN listpeers

SwapInPremiumRatePPM and SwapInPremiumRatePPM are added to the ListPeers.
This is an additional information, we are currently managing the peerswapd and the cln-plugin in duplicate, but this will be fixed by #231.

Hitting this with CLN as sender

I rearranged the order of commands.
I think it is natural that the force flag should be at the end.

CLN plugin crashed when trying a listswaps.

The source of the information was an error, which I corrected.

@Impa10r
Copy link
Contributor

Impa10r commented Jan 30, 2024

@YusukeShimizu Hello. Do you plan RPC endpoints to configure premium rates?

@YusukeShimizu
Copy link
Contributor Author

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.)

@grubles
Copy link
Collaborator

grubles commented Jan 31, 2024

At 9c34c47 my peerswapd segfaults when attempting a swap-out.

2024/01/31 15:31:22 [INFO] [Swap:69d53116566e72ac131f343a7dfc492879042c02752c0557369cbd8674703eee] Start new swap-out: peer: 036e680823a129ac9a2eeb8c43514a5b6cb09ae28e3e698a0e34aaa8865d6cc344 chanId: 140490:1:0 initiator: 035ca2fe4793a5e789ce846062eb4834f573c060d9200ce77544a29b48a0aa5923 amount 100000000
2024/01/31 15:31:22 [DEBUG] [FSM] event:id: 69d53116566e72ac131f343a7dfc492879042c02752c0557369cbd8674703eee, Event_ActionSucceeded on State_SwapOutSender_CreateSwap
2024/01/31 15:31:22 [DEBUG] [FSM] event:id: 69d53116566e72ac131f343a7dfc492879042c02752c0557369cbd8674703eee, Event_ActionSucceeded on State_SwapOutSender_SendRequest
2024/01/31 15:31:22 [DEBUG] [Messenger] From: 036e680823a129ac9a2eeb8c43514a5b6cb09ae28e3e698a0e34aaa8865d6cc344 got msgtype: a45b for swap: 69d53116566e72ac131f343a7dfc492879042c02752c0557369cbd8674703eee
2024/01/31 15:31:22 [DEBUG] [FSM] event:id: 69d53116566e72ac131f343a7dfc492879042c02752c0557369cbd8674703eee, Event_OnFeeInvoiceReceived on State_SwapOutSender_AwaitAgreement
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x58 pc=0xcb6c9f]

goroutine 69 [running]:
github.com/elementsproject/peerswap/swap.(*CheckPremiumAmount).Execute(0xc0006bd600?, 0x10ad8bb?, 0xc000318780)
        /home/user/builds/master_peerswap/swap/actions.go:215 +0x11f
github.com/elementsproject/peerswap/swap.(*SwapStateMachine).SendEvent(0xc0006bd600, {0x10a2a12, 0x1a}, {0x12b42d0?, 0xc0001b8e00})
        /home/user/builds/master_peerswap/swap/fsm.go:233 +0x7ae
github.com/elementsproject/peerswap/swap.(*SwapService).OnSwapOutAgreementReceived(0xc00055c2c0?, 0xc0001b8e00)
        /home/user/builds/master_peerswap/swap/service.go:695 +0x92
github.com/elementsproject/peerswap/swap.(*SwapService).OnMessageReceived(0xc0001cfee0?, {0xc000841c20, 0x42}, {0xc0005f5028, 0x4}, {0xc00055c2c0, 0x2b9, 0x2c0})
        /home/user/builds/master_peerswap/swap/service.go:218 +0x906
github.com/elementsproject/peerswap/lnd.(*MessageListener).Start.func1()
        /home/user/builds/master_peerswap/lnd/messagelistener.go:84 +0x473
created by github.com/elementsproject/peerswap/lnd.(*MessageListener).Start in goroutine 1
        /home/user/builds/master_peerswap/lnd/messagelistener.go:60 +0x10b

@YusukeShimizu
Copy link
Contributor Author

I fixed it on d8b683d

@YusukeShimizu
Copy link
Contributor Author

YusukeShimizu commented Oct 16, 2024

In summary, I am planning the following updates:

  1. Change the default value of premium settings to 0ppm
  2. Enable updating premium via API or CLI calls
  3. Implement immediate polling when updating premium

@YusukeShimizu YusukeShimizu force-pushed the premium-feature branch 3 times, most recently from f2fd6c5 to acdc3af Compare December 12, 2024 03:55
@YusukeShimizu YusukeShimizu force-pushed the premium-feature branch 7 times, most recently from f56072d to b80f269 Compare January 1, 2025 02:12
@YusukeShimizu
Copy link
Contributor Author

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.

@tsjk
Copy link

tsjk commented Jan 2, 2025

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
update usage instructions for peerswap-swap-out
to include premium limit.
@grubles
Copy link
Collaborator

grubles commented Jan 22, 2025

The premium docs for CLN seem to use the incorrect command arguments:

$ ./builds/lightning/cli/lightning-cli --signet peerswap-getdefaultpremiumrate --asset lbtc --operation swap_in
./builds/lightning/cli/lightning-cli: --asset: unrecognized option

Omitting the --asset --operation works.

$ ./builds/lightning/cli/lightning-cli --signet peerswap-getdefaultpremiumrate lbtc swap_out
0

@grubles
Copy link
Collaborator

grubles commented Jan 22, 2025

$ ./builds/peerswap/out/pscli swapin --channel_id 248103699313721344 --sat_amt 10000001 --asset lbtc
2025/01/22 11:38:32 rpc error: code = Unknown desc = from the CLN peer: unacceptable premium: 1000, limit: 0

Where do I configure the premium rate limit that is mentioned here?

@YusukeShimizu
Copy link
Contributor Author

The documentation contains an error.
For the CLN (Core Lightning Network) case, it’s correct to omit the parameter.
4795258

Could you try setting the premium limit and testing it, as shown in the example command for CLN’s ⁠swapin?
https://github.com/YusukeShimizu/peerswap/blob/premium-feature/docs/usage.md#swap-in

Swap-in Command Example.

$ ./builds/peerswap/out/pscli swapin --channel_id 248103699313721344 --sat_amt 10000001 --asset lbtc 10000

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants