private void updateHasTelemachusPart(Vessel vessel) { try { hasTelemachusPart = vessel.parts.FindAll(p => p.Modules.Contains("TelemachusDataLink")).Count > 0; } catch (Exception e) { PluginLogger.debug(e.Message + " " + e.StackTrace); } }
public void Update() { delayedAPIRunner.execute(); if (FlightGlobals.fetch != null) { vesselChangeDetector.update(FlightGlobals.ActiveVessel); } else { PluginLogger.debug("Flight globals was null during start up; skipping update of vessel change."); } }
public void Update() { delayedAPIRunner.execute(); if (FlightGlobals.fetch != null) { vesselChangeDetector.update(FlightGlobals.ActiveVessel); kspWebSocketDataStreamer.update(new UpdateTimerEventArgs(Time.time * MICRO_SECONDS)); } else { PluginLogger.debug("Flight globals was null during start up; skipping update of vessel change."); } }
public bool process(Servers.AsynchronousServer.ClientConnection cc, HTTPRequest request) { DataSources dataSources = new DataSources(); if (request.path.StartsWith(PAGE_PREFIX)) { if (request.requestType == HTTPRequest.GET) { dataRates.addUpLinkPoint(System.DateTime.Now, request.path.Length * UpLinkDownLinkRate.BITS_PER_BYTE); } else if (request.requestType == HTTPRequest.POST) { dataRates.addUpLinkPoint(System.DateTime.Now, request.content.Length * UpLinkDownLinkRate.BITS_PER_BYTE); } try { dataSources.vessel = kspAPI.getVessel(); } catch (Exception e) { PluginLogger.debug(e.Message + " " + e.StackTrace); } if (request.requestType == HTTPRequest.GET) { dataRates.addDownLinkPoint( System.DateTime.Now, ((Servers.MinimalHTTPServer.ClientConnection)cc).Send(new OKResponsePage( argumentsParse(request.path.Remove(0, request.path.IndexOf(ARGUMENTS_START) + 1), dataSources) )) * UpLinkDownLinkRate.BITS_PER_BYTE); } else if (request.requestType == HTTPRequest.POST) { dataRates.addDownLinkPoint( System.DateTime.Now, ((Servers.MinimalHTTPServer.ClientConnection)cc).Send(new OKResponsePage( argumentsParse(request.content, dataSources) )) * UpLinkDownLinkRate.BITS_PER_BYTE); } return(true); } return(false); }
private void rate(string p) { int proposedRate = 0; try { proposedRate = int.Parse(p); if (proposedRate >= MAX_STREAM_RATE) { streamRate = proposedRate; } } catch (Exception) { PluginLogger.debug("Swallowing integer parse failure when setting stream rate."); } }
public void Update() { delayedAPIRunner.execute(); if (FlightGlobals.fetch != null) { vesselChangeDetector.update(FlightGlobals.ActiveVessel); foreach (var client in webServer.WebSocketServices["/datalink"].Sessions.Sessions.OfType <KSPWebSocketService>()) { if (client.UpdateRequired(Time.time)) { client.SendDataUpdate(); } } } else { PluginLogger.debug("Flight globals was null during start up; skipping update of vessel change."); } }
public void parseParams(ref String arg, ref DataSources dataSources) { dataSources.args.Clear(); try { if (arg.Contains("[")) { String[] argsSplit = arg.Split('['); argsSplit[1] = argsSplit[1].Substring(0, argsSplit[1].Length - 1); arg = argsSplit[0]; String[] paramSplit = argsSplit[1].Split(','); for (int i = 0; i < paramSplit.Length; i++) { dataSources.args.Add(paramSplit[i]); } } } catch (Exception e) { PluginLogger.debug(e.Message + " " + e.StackTrace); } }
private void streamData(object sender, ElapsedEventArgs e) { streamTimer.Interval = streamRate; DataSources dataSources = new DataSources(); if (toRun.Count + subscriptions.Count > 0) { try { List <string> entries = new List <string>(); APIEntry entry = null; lock (subscriptionLock) { dataSources.vessel = kspAPI.getVessel(); //Only parse the paused argument if the active vessel is null if (dataSources.vessel != null) { toRun.UnionWith(subscriptions); foreach (string s in toRun) { DataSources dataSourcesClone = dataSources.Clone(); string trimedQuotes = s.Trim(); string refArg = trimedQuotes; kspAPI.parseParams(ref refArg, ref dataSourcesClone); kspAPI.process(refArg, out entry); if (entry != null) { dataSourcesClone.setVarName(trimedQuotes); entries.Add(entry.formatter.format(entry.function(dataSourcesClone), dataSourcesClone.getVarName())); } } toRun.Clear(); if (entry != null) { WebSocketFrame frame = new WebSocketFrame(ASCIIEncoding.UTF8.GetBytes(entry.formatter.pack(entries))); byte[] bFrame = frame.AsBytes(); dataRates.addDownLinkPoint(System.DateTime.Now, bFrame.Length * UpLinkDownLinkRate.BITS_PER_BYTE); clientConnection.Send(bFrame); } } else { sendNullMessage(); } } } catch (NullReferenceException) { PluginLogger.debug("Swallowing null reference exception, potentially due to async game state change."); sendNullMessage(); } catch (Exception ex) { PluginLogger.debug("Closing socket due to potential client disconnect:" + ex.GetType().ToString()); close(); } } else { sendNullMessage(); } }
private static void WebSocketServerNotify(object sender, Servers.NotifyEventArgs e) { PluginLogger.debug(e.message); }