private void WebSocket_Error(WsClientErrorMessage e) { bool announceExtendedError = !ObsWebsocketConnection.Instance.Client.AutoReconnect; if (e.ReconnectDelay > 0 && ObsWebsocketConnection.Instance.Client.AutoReconnect && e.Error != null) { TextBlock_AnnounceChanged(tbReconnectCountdown); // Announce extended error for connection failure if // exponential back-off minimum is greater than or equal to 20 seconds // or if reconnect delay is between 20 and 40 seconds. if ((Preferences.Default.obs_reconnect_min_seconds >= 20 && e.ReconnectDelay == Preferences.Default.obs_reconnect_min_seconds) || (e.ReconnectDelay >= 20 && e.ReconnectDelay < 40)) { announceExtendedError = true; } } if (e.Error != null) { TextBlock_AnnounceChanged(tbStatus); if (announceExtendedError && e.Error.InnerException != null) { TextBlock_AnnounceChanged(tbStatusExtended); } } }
private void WebSocket_ErrorMessage(WsClientErrorMessage errorMessage) { if (errorMessage.Error == null) { return; } txtOutput.Text += $"{errorMessage.Error.Message}\n{errorMessage.Error.InnerException?.Message}\n\n"; if (errorMessage.ReconnectDelay > 0) { reconnectDelay = errorMessage.ReconnectDelay; } }
private async Task ParseReply(MemoryStream message, ObsReplyObject obsReply) { message.Seek(0, SeekOrigin.Begin); if (obsReply.Status == "ok" && Enum.IsDefined(typeof(ObsRequestType), obsReply.RequestType)) { obsReply.MessageObject = await JsonSerializer.DeserializeAsync(message, ObsWsRequestReply.GetType(obsReply.RequestType)).ConfigureAwait(false); object settingsObject; ReadOnlyMemory <char> settingsJson; ObsSourceType sourceType; switch (obsReply.RequestType) { case ObsRequestType.GetAuthRequired: GetAuthRequiredReply getAuthRequiredReply = obsReply.MessageObject as GetAuthRequiredReply; CanSend = !getAuthRequiredReply.AuthRequired; if (!CanSend) { AuthenticateRequest authRequest = new AuthenticateRequest(); if (PasswordPreference == null || PasswordPreference.Length == 0) { AutoReconnect = false; OnErrorState(new Exception(rm.GetString("auth_required_no_password", CultureInfo.CurrentCulture)), -1); break; } PopulateAuthenticateRequest(ref authRequest, getAuthRequiredReply); await ObsSend(authRequest).ConfigureAwait(true); } else { await OBS_EnableHeartBeat().ConfigureAwait(true); } break; case ObsRequestType.GetSourceTypesList: foreach (ObsWsReplyType type in (obsReply.MessageObject as GetSourceTypesListReply).Types) { if (!CanDeserializeSourceType(ObsTypes.ObsTypeNameDictionary[type.TypeId], type.DefaultSettings.GetRawText().AsMemory(), out settingsObject)) { Trace.WriteLine($"Unknown source type: {type.DisplayName} ({type.TypeId}) is not defined but the server supports it."); continue; } type.DefaultSettingsObj = settingsObject; } break; case ObsRequestType.GetSourceSettings: GetJsonElementFromObjectProperty(obsReply.MessageObject, "SourceSettings", out settingsJson); if (!CanDeserializeSourceType(obsReply.SourceType, settingsJson, out settingsObject)) { break; } (obsReply.MessageObject as GetSourceSettingsReply).SourceSettingsObj = settingsObject; break; case ObsRequestType.SetSourceSettings: GetJsonElementFromObjectProperty(obsReply.MessageObject, "SourceSettings", out settingsJson); if (!CanDeserializeSourceType(obsReply.SourceType, settingsJson, out settingsObject)) { break; } (obsReply.MessageObject as SetSourceSettingsReply).SourceSettingsObj = settingsObject; break; case ObsRequestType.GetSourceFilters: foreach (ObsWsReplyFilter filter in (obsReply.MessageObject as GetSourceFiltersReply).Filters) { settingsJson = filter.Settings.GetRawText().AsMemory(); sourceType = ObsTypes.ObsTypeNameDictionary[filter.Type]; if (!CanDeserializeSourceType(sourceType, settingsJson, out settingsObject)) { continue; } filter.SettingsObj = settingsObject; } break; case ObsRequestType.GetSourceFilterInfo: GetJsonElementFromObjectProperty(obsReply.MessageObject, "Settings", out settingsJson); if (!CanDeserializeSourceType(obsReply.SourceType, settingsJson, out settingsObject)) { break; } (obsReply.MessageObject as GetSourceFilterInfoReply).SettingsObj = settingsObject; break; case ObsRequestType.Authenticate: CanSend = true; await OBS_EnableHeartBeat().ConfigureAwait(true); break; default: break; } NewObsReply(obsReply); } else if (obsReply.Status == "error") { ObsError replyModel = (ObsError)await JsonSerializer.DeserializeAsync(message, typeof(ObsError)).ConfigureAwait(false); if (obsReply.RequestType == ObsRequestType.Authenticate && !CanSend) { AutoReconnect = false; } WsClientErrorMessage errorMessage = new WsClientErrorMessage() { Error = new Exception( replyModel.Error, new Exception(String.Format(CultureInfo.CurrentCulture, Properties.Resources.exception_obs_error_format, obsReply.RequestMetadata.OriginalRequestType, obsReply.MessageId, obsReply.Status)) ), ReconnectDelay = -1 }; OnErrorState(errorMessage.Error, errorMessage.ReconnectDelay); } }
private void WebSocket_ErrorMessage_ContextSwitch(object sender, WsClientErrorMessage errorMessage) { _Context.Send( x => WebSocket_ErrorMessage(errorMessage), null); }