Skip to content

Commit

Permalink
Merge pull request #537 from lightninglabs/federation-sync-config
Browse files Browse the repository at this point in the history
Add federation sync configuration SQL table and RPC endpoints
  • Loading branch information
Roasbeef authored Oct 11, 2023
2 parents dbafc97 + 95b03be commit 28e4a6b
Show file tree
Hide file tree
Showing 20 changed files with 2,009 additions and 216 deletions.
4 changes: 4 additions & 0 deletions itest/test_list_on_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,10 @@ var testCases = []*testCase{
name: "burn test",
test: testBurnAssets,
},
{
name: "federation sync config",
test: testFederationSyncConfig,
},
}

var optionalTestCases = []*testCase{
Expand Down
132 changes: 132 additions & 0 deletions itest/universe_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,12 @@ import (
"encoding/hex"
"fmt"
"io"
prand "math/rand"

"github.com/btcsuite/btcd/btcec/v2"
"github.com/btcsuite/btcd/btcec/v2/schnorr"
"github.com/lightninglabs/taproot-assets/internal/test"

tap "github.com/lightninglabs/taproot-assets"
"github.com/lightninglabs/taproot-assets/asset"
"github.com/lightninglabs/taproot-assets/fn"
Expand All @@ -18,6 +21,7 @@ import (
"github.com/lightninglabs/taproot-assets/taprpc/mintrpc"
unirpc "github.com/lightninglabs/taproot-assets/taprpc/universerpc"
"github.com/lightninglabs/taproot-assets/universe"

"github.com/lightningnetwork/lnd/lntest/wait"
"github.com/stretchr/testify/require"
"golang.org/x/exp/maps"
Expand Down Expand Up @@ -527,3 +531,131 @@ func testUniverseFederation(t *harnessTest) {
require.NoError(t.t, err)
require.Equal(t.t, 0, len(fedNodes.Servers))
}

// testFederationSyncConfig tests that we can properly set and query the
// federation sync config.
func testFederationSyncConfig(t *harnessTest) {
ctx := context.Background()

// Generate a random asset ID in order to generate a universe ID.
rand := prand.New(prand.NewSource(1))

// Generate universe ID #1.
assetIDBytes1 := make([]byte, 32)
_, _ = rand.Read(assetIDBytes1)

var assetID1 asset.ID
copy(assetID1[:], assetIDBytes1)

uniID1 := universe.Identifier{
AssetID: assetID1,
ProofType: universe.ProofTypeIssuance,
}
uniIdRpc1 := unirpc.MarshalUniverseID(assetIDBytes1, nil)
uniIdRpc1.ProofType = unirpc.ProofType_PROOF_TYPE_ISSUANCE

// Generate universe ID #2.
groupKey2 := test.RandPubKey(t.t)
groupKeyBytes2 := groupKey2.SerializeCompressed()

uniID2 := universe.Identifier{
GroupKey: groupKey2,
ProofType: universe.ProofTypeTransfer,
}
uniIdRpc2 := unirpc.MarshalUniverseID(nil, groupKeyBytes2)
uniIdRpc2.ProofType = unirpc.ProofType_PROOF_TYPE_TRANSFER

// Set both the global and a universe specific federation sync configs.
globalConfigs := []*unirpc.GlobalFederationSyncConfig{
{
ProofType: unirpc.ProofType_PROOF_TYPE_ISSUANCE,
AllowSyncInsert: true,
AllowSyncExport: false,
},
{
ProofType: unirpc.ProofType_PROOF_TYPE_TRANSFER,
AllowSyncInsert: false,
AllowSyncExport: true,
},
}

assetSyncConfigs := []*unirpc.AssetFederationSyncConfig{
{
Id: uniIdRpc1,
AllowSyncInsert: false,
AllowSyncExport: true,
},
{
Id: uniIdRpc2,
AllowSyncInsert: true,
AllowSyncExport: false,
},
}

_, err := t.tapd.UniverseClient.SetFederationSyncConfig(
ctx, &unirpc.SetFederationSyncConfigRequest{
GlobalSyncConfigs: globalConfigs,
AssetSyncConfigs: assetSyncConfigs,
},
)
require.NoError(t.t, err)

resp, err := t.tapd.UniverseClient.QueryFederationSyncConfig(
ctx, &unirpc.QueryFederationSyncConfigRequest{},
)
require.NoError(t.t, err)

// Ensure that the global configs are set as expected.
require.Equal(t.t, len(resp.GlobalSyncConfigs), 2)

for i := range resp.GlobalSyncConfigs {
config := resp.GlobalSyncConfigs[i]

// Match proof type.
switch config.ProofType {
case unirpc.ProofType_PROOF_TYPE_ISSUANCE:
require.True(t.t, config.AllowSyncInsert)
require.False(t.t, config.AllowSyncExport)

case unirpc.ProofType_PROOF_TYPE_TRANSFER:
require.False(t.t, config.AllowSyncInsert)
require.True(t.t, config.AllowSyncExport)

default:
t.Fatalf("unexpected global proof type: %s",
config.ProofType)
}
}

// Ensure that the universe specific config is set as expected.
require.Equal(t.t, len(resp.AssetSyncConfigs), 2)

for i := range resp.AssetSyncConfigs {
config := resp.AssetSyncConfigs[i]

// Unmarshal the universe ID.
uniID, err := tap.UnmarshalUniID(config.Id)
require.NoError(t.t, err)

switch uniID.String() {
case uniID1.String():
require.Equal(
t.t, uniID.ProofType,
universe.ProofTypeIssuance,
)
require.False(t.t, config.AllowSyncInsert)
require.True(t.t, config.AllowSyncExport)

case uniID2.String():
require.Equal(
t.t, uniID.ProofType,
universe.ProofTypeTransfer,
)
require.True(t.t, config.AllowSyncInsert)
require.False(t.t, config.AllowSyncExport)

default:
t.Fatalf("unexpected universe ID: %v", config.Id)
}
}
}
8 changes: 8 additions & 0 deletions perms/perms.go
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,14 @@ var (
Entity: "universe",
Action: "read",
}},
"/universerpc.Universe/SetFederationSyncConfig": {{
Entity: "universe",
Action: "write",
}},
"/universerpc.Universe/QueryFederationSyncConfig": {{
Entity: "universe",
Action: "read",
}},
"/tapdevrpc.TapDev/ImportProof": {{
Entity: "proofs",
Action: "write",
Expand Down
Loading

0 comments on commit 28e4a6b

Please sign in to comment.