-
Notifications
You must be signed in to change notification settings - Fork 0
/
handler.go
72 lines (64 loc) · 3.04 KB
/
handler.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package server
import (
sdk "github.com/cosmos/cosmos-sdk/types"
channeltypes "github.com/cosmos/cosmos-sdk/x/ibc/core/04-channel/types"
commontypes "github.com/datachainlab/cosmos-sdk-interchain-dns/x/ibc-dns/common/types"
"github.com/datachainlab/cosmos-sdk-interchain-dns/x/ibc-dns/server/keeper"
"github.com/datachainlab/cosmos-sdk-interchain-dns/x/ibc-dns/server/types"
)
// NewPacketReceiver returns a receiver to handle received packets
func NewPacketReceiver(keeper keeper.Keeper) commontypes.PacketReceiver {
return func(ctx sdk.Context, packet channeltypes.Packet) (*sdk.Result, []byte, error) {
data, err := commontypes.DeserializeJSONPacketData(types.PacketCdc(), packet.GetData())
if err != nil {
return nil, nil, err
}
switch data := data.(type) {
case *types.RegisterDomainPacketData:
return handlePacketRegisterChannelDomain(ctx, keeper, packet, data)
case *types.DomainAssociationCreatePacketData:
return handleDomainAssociationCreatePacketData(ctx, keeper, packet, data)
default:
return nil, nil, commontypes.ErrUnknownRequest
}
}
}
func handlePacketRegisterChannelDomain(ctx sdk.Context, keeper keeper.Keeper, packet channeltypes.Packet, data *types.RegisterDomainPacketData) (*sdk.Result, []byte, error) {
var status uint32
if err := keeper.ReceivePacketRegisterDomain(ctx, packet, data); err != nil {
ctx.Logger().Info("failed to handle a packet 'PacketRegisterChannelDomain'", "err", err)
status = types.STATUS_FAILED
} else {
status = types.STATUS_OK
}
ack := types.NewRegisterDomainPacketAcknowledgement(status, data.DomainName)
return &sdk.Result{Events: ctx.EventManager().ABCIEvents()}, ack.GetBytes(), nil
}
func handleDomainAssociationCreatePacketData(ctx sdk.Context, keeper keeper.Keeper, packet channeltypes.Packet, data *types.DomainAssociationCreatePacketData) (*sdk.Result, []byte, error) {
ack, completed := keeper.ReceiveDomainAssociationCreatePacketData(ctx, packet, data)
if completed {
err := keeper.SendDomainAssociationResultPacketData(ctx, ack.Status, data.SrcClient, data.DstClient)
if err != nil {
return nil, nil, err
}
}
return &sdk.Result{Events: ctx.EventManager().ABCIEvents()}, ack.GetBytes(), nil
}
// NewPacketAcknowledgementReceiver returns a receiver to handle received acks
func NewPacketAcknowledgementReceiver(keeper keeper.Keeper) commontypes.PacketAcknowledgementReceiver {
return func(ctx sdk.Context, packet channeltypes.Packet, ack []byte) (*sdk.Result, error) {
ackData, err := commontypes.DeserializeJSONPacketAck(types.PacketCdc(), packet.GetData())
if err != nil {
return nil, err
}
switch ackData := ackData.(type) {
case *types.DomainAssociationResultPacketAcknowledgement:
return handleDomainAssociationResultPacketAcknowledgement(ctx, keeper, ackData)
default:
return nil, commontypes.ErrUnknownRequest
}
}
}
func handleDomainAssociationResultPacketAcknowledgement(ctx sdk.Context, k keeper.Keeper, ackData *types.DomainAssociationResultPacketAcknowledgement) (*sdk.Result, error) {
return &sdk.Result{Events: ctx.EventManager().ABCIEvents()}, nil
}