/
handler.go
executable file
·80 lines (70 loc) · 2.86 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
73
74
75
76
77
78
79
80
package nameservice
import (
"fmt"
"github.com/usetech-llc/polka_cosmos_bridge_poc/cosmos/x/nameservice/internal/types"
sdk "github.com/cosmos/cosmos-sdk/types"
)
// NewHandler returns a handler for "nameservice" type messages.
func NewHandler(keeper Keeper) sdk.Handler {
return func(ctx sdk.Context, msg sdk.Msg) sdk.Result {
switch msg := msg.(type) {
case MsgSetName:
return handleMsgSetName(ctx, keeper, msg)
case MsgBuyName:
return handleMsgBuyName(ctx, keeper, msg)
case MsgDeleteName:
return handleMsgDeleteName(ctx, keeper, msg)
case MsgForwardFunds:
return handleMsgForwardFunds(ctx, keeper, msg)
default:
errMsg := fmt.Sprintf("Unrecognized nameservice Msg type: %v", msg.Type())
return sdk.ErrUnknownRequest(errMsg).Result()
}
}
}
// Handle a message to set name
func handleMsgSetName(ctx sdk.Context, keeper Keeper, msg MsgSetName) sdk.Result {
if !msg.Owner.Equals(keeper.GetOwner(ctx, msg.Name)) { // Checks if the the msg sender is the same as the current owner
return sdk.ErrUnauthorized("Incorrect Owner").Result() // If not, throw an error
}
keeper.SetName(ctx, msg.Name, msg.Value) // If so, set the name to the value specified in the msg.
return sdk.Result{} // return
}
// Handle a message to buy name
func handleMsgBuyName(ctx sdk.Context, keeper Keeper, msg MsgBuyName) sdk.Result {
// Checks if the the bid price is greater than the price paid by the current owner
if keeper.GetPrice(ctx, msg.Name).IsAllGT(msg.Bid) {
return sdk.ErrInsufficientCoins("Bid not high enough").Result() // If not, throw an error
}
if keeper.HasOwner(ctx, msg.Name) {
err := keeper.CoinKeeper.SendCoins(ctx, msg.Buyer, keeper.GetOwner(ctx, msg.Name), msg.Bid)
if err != nil {
return sdk.ErrInsufficientCoins("Buyer does not have enough coins").Result()
}
} else {
_, err := keeper.CoinKeeper.SubtractCoins(ctx, msg.Buyer, msg.Bid) // If so, deduct the Bid amount from the sender
if err != nil {
return sdk.ErrInsufficientCoins("Buyer does not have enough coins").Result()
}
}
keeper.SetOwner(ctx, msg.Name, msg.Buyer)
keeper.SetPrice(ctx, msg.Name, msg.Bid)
return sdk.Result{}
}
// Handle a message to delete name
func handleMsgDeleteName(ctx sdk.Context, keeper Keeper, msg MsgDeleteName) sdk.Result {
if !keeper.IsNamePresent(ctx, msg.Name) {
return types.ErrNameDoesNotExist(types.DefaultCodespace).Result()
}
if !msg.Owner.Equals(keeper.GetOwner(ctx, msg.Name)) {
return sdk.ErrUnauthorized("Incorrect Owner").Result()
}
keeper.DeleteWhois(ctx, msg.Name)
return sdk.Result{}
}
///////////////////////////////////////////////////////////////////////////////////////////////
// BRIDGE: Handle a message to forward funds
func handleMsgForwardFunds(ctx sdk.Context, keeper Keeper, msg MsgForwardFunds) sdk.Result {
keeper.CoinKeeper.SendCoins(ctx, msg.Relay, msg.Caller, msg.Amount)
return sdk.Result{}
}