-
Notifications
You must be signed in to change notification settings - Fork 91
/
msg_server_update_market_prices.go
38 lines (32 loc) · 1.26 KB
/
msg_server_update_market_prices.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
package keeper
import (
"context"
"fmt"
"github.com/cosmos/cosmos-sdk/telemetry"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/dydxprotocol/v4-chain/protocol/lib/metrics"
"github.com/dydxprotocol/v4-chain/protocol/x/prices/types"
)
func (k msgServer) UpdateMarketPrices(
goCtx context.Context,
msg *types.MsgUpdateMarketPrices,
) (*types.MsgUpdateMarketPricesResponse, error) {
ctx := sdk.UnwrapSDKContext(goCtx)
// Validate.
// Note that non-deterministic validation is skipped, because the prices have been deemed
// valid w/r/t index prices in `ProcessProposal` in order for the msg to reach this step.
if err := k.Keeper.PerformStatefulPriceUpdateValidation(ctx, msg, false); err != nil {
errMsg := fmt.Sprintf("PerformStatefulPriceUpdateValidation failed, err = %v", err)
k.Keeper.Logger(ctx).Error(errMsg)
panic(err)
}
// Update state.
if err := k.Keeper.UpdateMarketPrices(ctx, msg.MarketPriceUpdates); err != nil {
// This should never happen, because the updates were validated above.
errMsg := fmt.Sprintf("UpdateMarketPrices failed, err = %v", err)
k.Keeper.Logger(ctx).Error(errMsg)
panic(err)
}
telemetry.IncrCounter(1, types.ModuleName, metrics.UpdateMarketPrices, metrics.Success)
return &types.MsgUpdateMarketPricesResponse{}, nil
}