Class OrderSubmissionTrade


  • public class OrderSubmissionTrade
    extends UserTrade

    A single OrderSubmissionTrade active in the system.

    A Trade is initiated by a client and is tied to a TradeChannel. The lifecycle of a Trade consists of a number of messages, represented by TradeEvents, being sent between the client and the Trading System in both directions. These messages cause the Trade to transition between a number of predefined states.

    Trades are comprised of one or more trade legs, which each leg representing the exchange of a financial instrument and the resultant cash flow. It is possible to add, remove and update trades from the client or from the TradingDataSource.

    A Trade is uniquely identified in two ways: by RequestId set by the client and a TradeId set by the Trading System.

    • Constructor Detail

      • OrderSubmissionTrade

        public OrderSubmissionTrade​(@NotNull
                                    @NotNull com.caplin.trading.Trade backingTrade,
                                    @NotNull
                                    @NotNull java.util.concurrent.ScheduledExecutorService executorService)

        Constructor used by the generated code.

        Parameters:
        backingTrade - To be used for the parent constructor
        executorService - To be used for the parent constructor (What service is going execute the backingTrade)
    • Method Detail

      • createErrorTradeEvent

        @NotNull
        public @NotNull ErrorTradeEvent createErrorTradeEvent()

        Create a TradeEvent that can be used to trigger the trade to transition into the Error state.

        Returns:
        A new instance of ErrorTradeEvent.
      • sendErrorEvent

        public void sendErrorEvent​(@NotNull
                                   @NotNull ErrorTradeEvent event)

        Send a TradeEvent to trigger the trade to transition into the Error state.

        Parameters:
        event - The event to send.
      • sendErrorEvent

        public void sendErrorEvent​(@NotNull
                                   @NotNull Message message)

        Send a TradeEvent to trigger the trade to transition into the Error state.

        Parameters:
        message - The message to send.
      • createErrorTradeEvent

        @NotNull
        public @NotNull ErrorTradeEvent createErrorTradeEvent​(@NotNull
                                                              @NotNull Message message)

        Create a TradeEvent that can be used to trigger the trade to transition into the Error state.

        Parameters:
        message - a Message to be passed to the TradeEvent
        Returns:
        A new instance of ErrorTradeEvent.
      • createSubmitAckTradeEvent

        @NotNull
        public @NotNull SubmitAckTradeEvent createSubmitAckTradeEvent()

        Create a TradeEvent that can be used to trigger the trade to transition into the SubmitAck state.

        Returns:
        A new instance of SubmitAckTradeEvent.
      • sendSubmitAckEvent

        public void sendSubmitAckEvent​(@NotNull
                                       @NotNull SubmitAckTradeEvent event)

        Send a TradeEvent to trigger the trade to transition into the SubmitAck state.

        Parameters:
        event - The event to send.
      • sendSubmitAckEvent

        public void sendSubmitAckEvent()

        Send a TradeEvent with no fields to trigger the trade to transition into the SubmitAck state.

      • createAcceptTradeEvent

        @NotNull
        public @NotNull AcceptTradeEvent createAcceptTradeEvent()

        Create a TradeEvent that can be used to trigger the trade to transition into the Accept state.

        Returns:
        A new instance of AcceptTradeEvent.
      • sendAcceptEvent

        public void sendAcceptEvent​(@NotNull
                                    @NotNull AcceptTradeEvent event)

        Send a TradeEvent to trigger the trade to transition into the Accept state.

        Parameters:
        event - The event to send.
      • sendAcceptEvent

        public void sendAcceptEvent​(@NotNull
                                    @NotNull Message message)

        Send a TradeEvent to trigger the trade to transition into the Accept state.

        Parameters:
        message - The message to send.
      • createAcceptTradeEvent

        @NotNull
        public @NotNull AcceptTradeEvent createAcceptTradeEvent​(@NotNull
                                                                @NotNull Message message)

        Create a TradeEvent that can be used to trigger the trade to transition into the Accept state.

        Parameters:
        message - a Message to be passed to the TradeEvent
        Returns:
        A new instance of AcceptTradeEvent.
      • createAcceptingTradeEvent

        @NotNull
        public @NotNull AcceptingTradeEvent createAcceptingTradeEvent()

        Create a TradeEvent that can be used to trigger the trade to transition into the Accepting state.

        Returns:
        A new instance of AcceptingTradeEvent.
      • sendAcceptingEvent

        public void sendAcceptingEvent​(@NotNull
                                       @NotNull AcceptingTradeEvent event)

        Send a TradeEvent to trigger the trade to transition into the Accepting state.

        Parameters:
        event - The event to send.
      • sendAcceptingEvent

        public void sendAcceptingEvent()

        Send a TradeEvent with no fields to trigger the trade to transition into the Accepting state.