Lean  $LEAN_TAG$
IMessagingHandler.cs
1 /*
2  * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
3  * Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  *
15 */
16 
17 using System;
18 using System.ComponentModel.Composition;
20 using QuantConnect.Packets;
21 
23 {
24  /// <summary>
25  /// Messaging System Plugin Interface.
26  /// Provides a common messaging pattern between desktop and cloud implementations of QuantConnect.
27  /// </summary>
28  [InheritedExport(typeof(IMessagingHandler))]
29  public interface IMessagingHandler : IDisposable
30  {
31  /// <summary>
32  /// Gets or sets whether this messaging handler has any current subscribers.
33  /// When set to false, messages won't be sent.
34  /// </summary>
35  bool HasSubscribers { get; set; }
36 
37  /// <summary>
38  /// Initialize the Messaging System Plugin.
39  /// </summary>
40  /// <param name="initializeParameters">The parameters required for initialization</param>
41  void Initialize(MessagingHandlerInitializeParameters initializeParameters);
42 
43  /// <summary>
44  /// Set the user communication channel
45  /// </summary>
46  /// <param name="job">The job packet</param>
48 
49  /// <summary>
50  /// Send any message with a base type of Packet.
51  /// </summary>
52  /// <param name="packet">Packet of data to send via the messaging system plugin</param>
53  void Send(Packet packet);
54 
55  /// <summary>
56  /// Send any notification with a base type of Notification.
57  /// </summary>
58  /// <param name="notification">The notification to be sent.</param>
59  void SendNotification(Notification notification);
60  }
61 }