code.vegaprotocol.io/vega@v0.79.0/core/events/margin_levels.go (about) 1 // Copyright (C) 2023 Gobalsky Labs Limited 2 // 3 // This program is free software: you can redistribute it and/or modify 4 // it under the terms of the GNU Affero General Public License as 5 // published by the Free Software Foundation, either version 3 of the 6 // License, or (at your option) any later version. 7 // 8 // This program is distributed in the hope that it will be useful, 9 // but WITHOUT ANY WARRANTY; without even the implied warranty of 10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11 // GNU Affero General Public License for more details. 12 // 13 // You should have received a copy of the GNU Affero General Public License 14 // along with this program. If not, see <http://www.gnu.org/licenses/>. 15 16 package events 17 18 import ( 19 "context" 20 21 "code.vegaprotocol.io/vega/core/types" 22 proto "code.vegaprotocol.io/vega/protos/vega" 23 eventspb "code.vegaprotocol.io/vega/protos/vega/events/v1" 24 ) 25 26 // MarginLevels - the margin levels event. 27 type MarginLevels struct { 28 *Base 29 l proto.MarginLevels 30 } 31 32 func NewMarginLevelsEvent(ctx context.Context, l types.MarginLevels) *MarginLevels { 33 return &MarginLevels{ 34 Base: newBase(ctx, MarginLevelsEvent), 35 l: *l.IntoProto(), 36 } 37 } 38 39 func (m MarginLevels) MarginLevels() proto.MarginLevels { 40 return m.l 41 } 42 43 func (m MarginLevels) IsParty(id string) bool { 44 return m.l.PartyId == id 45 } 46 47 func (m MarginLevels) PartyID() string { 48 return m.l.PartyId 49 } 50 51 func (m MarginLevels) MarketID() string { 52 return m.l.MarketId 53 } 54 55 func (m MarginLevels) Asset() string { 56 return m.l.Asset 57 } 58 59 func (m MarginLevels) Proto() proto.MarginLevels { 60 return m.l 61 } 62 63 func (m MarginLevels) StreamMessage() *eventspb.BusEvent { 64 busEvent := newBusEventFromBase(m.Base) 65 busEvent.Event = &eventspb.BusEvent_MarginLevels{ 66 MarginLevels: &m.l, 67 } 68 69 return busEvent 70 } 71 72 func MarginLevelsEventFromStream(ctx context.Context, be *eventspb.BusEvent) *MarginLevels { 73 return &MarginLevels{ 74 Base: newBaseFromBusEvent(ctx, MarginLevelsEvent, be), 75 l: *be.GetMarginLevels(), 76 } 77 }