SocketOptions.cs 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. #if !BESTHTTP_DISABLE_SOCKETIO
  2. using System;
  3. using System.Text;
  4. using PlatformSupport.Collections.ObjectModel;
  5. #if !NETFX_CORE
  6. using PlatformSupport.Collections.Specialized;
  7. #else
  8. using System.Collections.Specialized;
  9. #endif
  10. namespace BestHTTP.SocketIO
  11. {
  12. public sealed class SocketOptions
  13. {
  14. #region Properties
  15. /// <summary>
  16. /// The SocketManager will try to connect with this transport.
  17. /// </summary>
  18. public Transports.TransportTypes ConnectWith { get; set; }
  19. /// <summary>
  20. /// Whether to reconnect automatically after a disconnect (default true)
  21. /// </summary>
  22. public bool Reconnection { get; set; }
  23. /// <summary>
  24. /// Number of attempts before giving up (default Int.MaxValue)
  25. /// </summary>
  26. public int ReconnectionAttempts { get; set; }
  27. /// <summary>
  28. /// How long to initially wait before attempting a new reconnection (default 1000ms).
  29. /// Affected by +/- RandomizationFactor, for example the default initial delay will be between 500ms to 1500ms.
  30. /// </summary>
  31. public TimeSpan ReconnectionDelay { get; set; }
  32. /// <summary>
  33. /// Maximum amount of time to wait between reconnections (default 5000ms).
  34. /// Each attempt increases the reconnection delay along with a randomization as above.
  35. /// </summary>
  36. public TimeSpan ReconnectionDelayMax { get; set; }
  37. /// <summary>
  38. /// (default 0.5`), [0..1]
  39. /// </summary>
  40. public float RandomizationFactor { get { return randomizationFactor; } set { randomizationFactor = Math.Min(1.0f, Math.Max(0.0f, value)); } }
  41. private float randomizationFactor;
  42. /// <summary>
  43. /// Connection timeout before a connect_error and connect_timeout events are emitted (default 20000ms)
  44. /// </summary>
  45. public TimeSpan Timeout { get; set; }
  46. /// <summary>
  47. /// By setting this false, you have to call SocketManager's Open() whenever you decide it's appropriate.
  48. /// </summary>
  49. public bool AutoConnect { get; set; }
  50. /// <summary>
  51. /// Additional query parameters that will be passed for the handshake uri. If the value is null, or an empty string it will be not appended to the query only the key.
  52. /// <remarks>The keys and values must be escaped properly, as the plugin will not escape these. </remarks>
  53. /// </summary>
  54. public ObservableDictionary<string, string> AdditionalQueryParams
  55. {
  56. get { return additionalQueryParams; }
  57. set
  58. {
  59. // Unsubscribe from previous dictionary's events
  60. if (additionalQueryParams != null)
  61. additionalQueryParams.CollectionChanged -= AdditionalQueryParams_CollectionChanged;
  62. additionalQueryParams = value;
  63. // Clear out the cached value
  64. BuiltQueryParams = null;
  65. // Subscribe to the collection changed event
  66. if (value != null)
  67. value.CollectionChanged += AdditionalQueryParams_CollectionChanged;
  68. }
  69. }
  70. private ObservableDictionary<string, string> additionalQueryParams;
  71. /// <summary>
  72. /// If it's false, the parameters in the AdditionalQueryParams will be passed for all HTTP requests. Its default value is true.
  73. /// </summary>
  74. public bool QueryParamsOnlyForHandshake { get; set; }
  75. #endregion
  76. /// <summary>
  77. /// The cached value of the result of the BuildQueryParams() call.
  78. /// </summary>
  79. private string BuiltQueryParams;
  80. /// <summary>
  81. /// Constructor, setting the default option values.
  82. /// </summary>
  83. public SocketOptions()
  84. {
  85. ConnectWith = Transports.TransportTypes.Polling;
  86. Reconnection = true;
  87. ReconnectionAttempts = int.MaxValue;
  88. ReconnectionDelay = TimeSpan.FromMilliseconds(1000);
  89. ReconnectionDelayMax = TimeSpan.FromMilliseconds(5000);
  90. RandomizationFactor = 0.5f;
  91. Timeout = TimeSpan.FromMilliseconds(20000);
  92. AutoConnect = true;
  93. QueryParamsOnlyForHandshake = true;
  94. }
  95. #region Helper Functions
  96. /// <summary>
  97. /// Builds the keys and values from the AdditionalQueryParams to an key=value form. If AdditionalQueryParams is null or empty, it will return an empty string.
  98. /// </summary>
  99. internal string BuildQueryParams()
  100. {
  101. if (AdditionalQueryParams == null || AdditionalQueryParams.Count == 0)
  102. return string.Empty;
  103. if (!string.IsNullOrEmpty(BuiltQueryParams))
  104. return BuiltQueryParams;
  105. StringBuilder sb = new StringBuilder(AdditionalQueryParams.Count * 4);
  106. foreach(var kvp in AdditionalQueryParams)
  107. {
  108. sb.Append("&");
  109. sb.Append(kvp.Key);
  110. if (!string.IsNullOrEmpty(kvp.Value))
  111. {
  112. sb.Append("=");
  113. sb.Append(kvp.Value);
  114. }
  115. }
  116. return BuiltQueryParams = sb.ToString();
  117. }
  118. /// <summary>
  119. /// This event will be called when the AdditonalQueryPrams dictionary changed. We have to reset the cached values.
  120. /// </summary>
  121. private void AdditionalQueryParams_CollectionChanged(object sender, NotifyCollectionChangedEventArgs e)
  122. {
  123. BuiltQueryParams = null;
  124. }
  125. #endregion
  126. }
  127. }
  128. #endif