/
market.go
78 lines (62 loc) · 2.14 KB
/
market.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
package keeper
import (
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/sge-network/sge/utils"
"github.com/sge-network/sge/x/market/types"
)
// SetMarket sets a specific market in the store
func (k Keeper) SetMarket(ctx sdk.Context, market types.Market) {
store := k.getMarketsStore(ctx)
b := k.cdc.MustMarshal(&market)
store.Set(utils.StrBytes(market.UID), b)
}
// GetMarket returns a specific market by its UID
func (k Keeper) GetMarket(ctx sdk.Context, marketUID string) (val types.Market, found bool) {
marketsStore := k.getMarketsStore(ctx)
b := marketsStore.Get(utils.StrBytes(marketUID))
if b == nil {
return val, false
}
k.cdc.MustUnmarshal(b, &val)
return val, true
}
// MarketExists checks if a specific market exists or not
func (k Keeper) MarketExists(ctx sdk.Context, marketUID string) bool {
_, found := k.GetMarket(ctx, marketUID)
return found
}
// GetMarkets returns all markets
func (k Keeper) GetMarkets(ctx sdk.Context) (list []types.Market, err error) {
store := k.getMarketsStore(ctx)
iterator := sdk.KVStorePrefixIterator(store, []byte{})
defer func() {
err = iterator.Close()
}()
for ; iterator.Valid(); iterator.Next() {
var val types.Market
k.cdc.MustUnmarshal(iterator.Value(), &val)
list = append(list, val)
}
return
}
// Resolve updates a market with its resolution
func (k Keeper) Resolve(
ctx sdk.Context,
storedMarket types.Market,
resolutionMarket *types.MarketResolutionTicketPayload,
) *types.Market {
storedMarket.ResolutionTS = resolutionMarket.ResolutionTS
storedMarket.Status = resolutionMarket.Status
// if the result is declared for the market, we need to update the winner odds uids.
if resolutionMarket.Status == types.MarketStatus_MARKET_STATUS_RESULT_DECLARED {
storedMarket.WinnerOddsUIDs = resolutionMarket.WinnerOddsUIDs
}
// if the result is declared or the market is canceled or aborted, it should be added
// to the unsettled resolved market list in the state.
if storedMarket.IsResolved() {
// append market id to the unsettled resolved in statistics.
k.appendUnsettledResolvedMarket(ctx, storedMarket.UID)
}
k.SetMarket(ctx, storedMarket)
return &storedMarket
}