Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(96)

Unified Diff: remoting/host/host_event_logger_linux.cc

Issue 9567010: Making the me2me host compiling and running on Windows. This includes making it a window applicatio… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: - Created 8 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « remoting/host/host_event_logger.cc ('k') | remoting/host/host_event_logger_win.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: remoting/host/host_event_logger_linux.cc
diff --git a/remoting/host/host_event_logger_linux.cc b/remoting/host/host_event_logger_linux.cc
new file mode 100644
index 0000000000000000000000000000000000000000..caf1a602c5ebae3da100633575522e8871c04cc1
--- /dev/null
+++ b/remoting/host/host_event_logger_linux.cc
@@ -0,0 +1,96 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "remoting/host/host_event_logger.h"
+
+#include "base/memory/ref_counted.h"
+#include "base/memory/scoped_ptr.h"
+#include "net/base/ip_endpoint.h"
+#include "remoting/host/chromoting_host.h"
+#include "remoting/host/host_status_observer.h"
+#include "remoting/host/system_event_logger.h"
+
+namespace remoting {
+
+namespace {
+
+class HostEventLoggerLinux : public HostEventLogger, public HostStatusObserver {
+ public:
+ HostEventLoggerLinux(ChromotingHost* host,
+ const std::string& application_name);
+
+ virtual ~HostEventLoggerLinux();
+
+ // HostStatusObserver implementation. These methods will be called from the
+ // network thread.
+ virtual void OnClientAuthenticated(const std::string& jid) OVERRIDE;
+ virtual void OnClientDisconnected(const std::string& jid) OVERRIDE;
+ virtual void OnAccessDenied(const std::string& jid) OVERRIDE;
+ virtual void OnClientRouteChange(
+ const std::string& jid,
+ const std::string& channel_name,
+ const net::IPEndPoint& remote_end_point,
+ const net::IPEndPoint& local_end_point) OVERRIDE;
+ virtual void OnShutdown() OVERRIDE;
+
+ private:
+ void Log(const std::string& message);
+
+ scoped_refptr<ChromotingHost> host_;
+ scoped_ptr<SystemEventLogger> system_event_logger_;
+
+ DISALLOW_COPY_AND_ASSIGN(HostEventLoggerLinux);
+};
+
+} //namespace
+
+HostEventLoggerLinux::HostEventLoggerLinux(ChromotingHost* host,
+ const std::string& application_name)
+ : host_(host),
+ system_event_logger_(SystemEventLogger::Create(application_name)) {
+ host_->AddStatusObserver(this);
+}
+
+HostEventLoggerLinux::~HostEventLoggerLinux() {
+ host_->RemoveStatusObserver(this);
+}
+
+void HostEventLoggerLinux::OnClientAuthenticated(const std::string& jid) {
+ Log("Client connected: " + jid);
+}
+
+void HostEventLoggerLinux::OnClientDisconnected(const std::string& jid) {
+ Log("Client disconnected: " + jid);
+}
+
+void HostEventLoggerLinux::OnAccessDenied(const std::string& jid) {
+ Log("Access denied for client: " + jid);
+}
+
+void HostEventLoggerLinux::OnClientRouteChange(
+ const std::string& jid,
+ const std::string& channel_name,
+ const net::IPEndPoint& remote_end_point,
+ const net::IPEndPoint& local_end_point) {
+ Log("Channel IP for client: " + jid +
+ " ip='" + remote_end_point.ToString() +
+ "' host_ip='" + local_end_point.ToString() +
+ "' channel='" + channel_name + "'");
+}
+
+void HostEventLoggerLinux::OnShutdown() {
+}
+
+void HostEventLoggerLinux::Log(const std::string& message) {
+ system_event_logger_->Log(message);
+}
+
+// static
+scoped_ptr<HostEventLogger> HostEventLogger::Create(
+ ChromotingHost* host, const std::string& application_name) {
+ return scoped_ptr<HostEventLogger>(
+ new HostEventLoggerLinux(host, application_name));
+}
+
+} // namespace remoting
« no previous file with comments | « remoting/host/host_event_logger.cc ('k') | remoting/host/host_event_logger_win.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698