void run() { while (receiving_thread != null) { TcpMessage m = receive_message(); Log.Main.Inform("Tcp message received: " + m.Name + "\r\n" + m.BodyAsText); UiApi.Message(MessageType.INFORM, "Tcp message received: " + m.Name + "\r\n" + m.BodyAsText); string reply = TcpMessage.Success; try { switch (m.Name) { case TcpMessage.FfmpegStart: MpegStream.Start(Service.UserSessionId, m.BodyAsText); break; case TcpMessage.FfmpegStop: MpegStream.Stop(); break; case TcpMessage.SslStart: if (stream is SslStream) { throw new Exception("SSL is already started."); } break; case TcpMessage.Poll: lock (errors) { if (errors.Count > 0) { reply = string.Join("\r\n", errors); errors.Clear(); } } break; default: throw new Exception("Unknown message: " + m.Name); } } catch (Exception e) { reply = e.Message; Log.Main.Error("Tcp message processing: ", e); } Log.Main.Inform("Tcp message sending: " + m.Name + "\r\n" + reply); TcpMessage m2 = new TcpMessage(m.Name, reply); send_message(m2); if (m.Name == TcpMessage.SslStart && reply == TcpMessage.Success) { startSsl(); } } }
void run() { while (thread != null) { TcpMessage m = TcpMessage.Receive(stream); Log.Main.Inform("Tcp message received: " + m.Name + "\r\n" + m.BodyAsText); CisteraScreenCaptureService.ExposedEvents.UiMessage.Info("Tcp message received: " + m.Name + "\r\n" + m.BodyAsText); string reply = TcpMessage.Success; try { switch (m.Name) { case TcpMessage.FfmpegStart: MpegStream.Start(Service.UserSessionId, m.BodyAsText); break; case TcpMessage.FfmpegStop: MpegStream.Stop(); break; case TcpMessage.SslStart: if (stream is SslStream) { throw new Exception("SSL is already started."); } break; default: throw new Exception("Unknown message: " + m.Name); } } catch (Exception e) { reply = e.Message; Log.Main.Error("Tcp message processing: ", e); } Log.Main.Inform("Tcp message sending: " + m.Name + "\r\n" + reply); m.Reply(stream, reply); if (m.Name == TcpMessage.SslStart && reply == TcpMessage.Success) { startSsl(); } } }
static void Main() { try { Log.Main.Inform("Version: " + AssemblyRoutines.GetAppVersion()); string user = ProcessRoutines.GetProcessUserName(); string m = "User: "******" (as administrator)"; } Log.Main.Inform(m); #if !test ServiceBase.Run(new Service()); #else MpegStream.Start(1, "-f gdigrab -framerate 10 -f rtp_mpegts -srtp_out_suite AES_CM_128_HMAC_SHA1_80 -srtp_out_params aMg7BqN047lFN72szkezmPyN1qSMilYCXbqP/sCt srtp://127.0.0.1:5920"); //Service.sessionChanged(1, true); //System.Threading.Thread.Sleep(1000000); //s.Stop //MpegStream.Start(1, ""); UserSessionApi.OpenApi(); UiApi.OpenApi(); ServiceControllerStatus scs = ServiceControllerStatus.Running; for (; ;) { System.Threading.Thread.Sleep(10000); UiApi.Message(MessageType.INFORM, "test"); scs = scs == ServiceControllerStatus.Running ? ServiceControllerStatus.Stopped : ServiceControllerStatus.Running; } #endif } catch (Exception e) { Log.Main.Error(e); } }