• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #include "remoting/host/server_log_entry_host.h"
6 
7 #include "base/strings/stringize_macros.h"
8 #include "base/sys_info.h"
9 #include "remoting/signaling/server_log_entry.h"
10 
11 using base::SysInfo;
12 
13 namespace remoting {
14 
15 namespace {
16 const char kValueEventNameSessionState[] = "session-state";
17 const char kValueEventNameHeartbeat[] = "heartbeat";
18 const char kValueEventNameHostStatus[] = "host-status";
19 
20 const char kValueRoleHost[] = "host";
21 
22 const char kKeySessionState[] = "session-state";
23 const char kValueSessionStateConnected[] = "connected";
24 const char kValueSessionStateClosed[] = "closed";
25 
26 const char kStatusName[] = "status";
27 const char kExitCodeName[] = "exit-code";
28 
29 const char kKeyOsName[] = "os-name";
30 
31 #if defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_CHROMEOS)
32 const char kKeyOsVersion[] = "os-version";
33 #endif
34 
35 const char kKeyHostVersion[] = "host-version";
36 
37 const char kKeyConnectionType[] = "connection-type";
38 
GetValueSessionState(bool connected)39 const char* GetValueSessionState(bool connected) {
40   return connected ? kValueSessionStateConnected : kValueSessionStateClosed;
41 }
42 
43 }  // namespace
44 
MakeLogEntryForSessionStateChange(bool connected)45 scoped_ptr<ServerLogEntry> MakeLogEntryForSessionStateChange(
46     bool connected) {
47   scoped_ptr<ServerLogEntry> entry(new ServerLogEntry());
48   entry->AddRoleField(kValueRoleHost);
49   entry->AddEventNameField(kValueEventNameSessionState);
50   entry->Set(kKeySessionState, GetValueSessionState(connected));
51   return entry.Pass();
52 }
53 
MakeLogEntryForHeartbeat()54 scoped_ptr<ServerLogEntry> MakeLogEntryForHeartbeat() {
55   scoped_ptr<ServerLogEntry> entry(new ServerLogEntry());
56   entry->AddRoleField(kValueRoleHost);
57   entry->AddEventNameField(kValueEventNameHeartbeat);
58   return entry.Pass();
59 }
60 
61 // static
MakeLogEntryForHostStatus(HostStatusSender::HostStatus host_status,HostExitCodes exit_code)62 scoped_ptr<ServerLogEntry> MakeLogEntryForHostStatus(
63     HostStatusSender::HostStatus host_status, HostExitCodes exit_code) {
64   scoped_ptr<ServerLogEntry> entry(new ServerLogEntry());
65   entry->AddRoleField(kValueRoleHost);
66   entry->AddEventNameField(kValueEventNameHostStatus);
67   entry->Set(kStatusName, HostStatusSender::HostStatusToString(host_status));
68   if (host_status == HostStatusSender::OFFLINE)
69     entry->Set(kExitCodeName, ExitCodeToString(exit_code));
70   return entry.Pass();
71 }
72 
AddHostFieldsToLogEntry(ServerLogEntry * entry)73 void AddHostFieldsToLogEntry(ServerLogEntry* entry) {
74 #if defined(OS_WIN)
75   entry->Set(kKeyOsName, "Windows");
76 #elif defined(OS_MACOSX)
77   entry->Set(kKeyOsName, "Mac");
78 #elif defined(OS_CHROMEOS)
79   entry->Set(kKeyOsName, "ChromeOS");
80 #elif defined(OS_LINUX)
81   entry->Set(kKeyOsName, "Linux");
82 #endif
83 
84   // SysInfo::OperatingSystemVersionNumbers is only defined for the following
85   // OSes: see base/sys_info_unittest.cc.
86 #if defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_CHROMEOS)
87   std::stringstream os_version;
88   int32 os_major_version = 0;
89   int32 os_minor_version = 0;
90   int32 os_bugfix_version = 0;
91   SysInfo::OperatingSystemVersionNumbers(&os_major_version, &os_minor_version,
92                                          &os_bugfix_version);
93   os_version << os_major_version << "." << os_minor_version << "."
94              << os_bugfix_version;
95   entry->Set(kKeyOsVersion, os_version.str());
96 #endif
97 
98   entry->Set(kKeyHostVersion, STRINGIZE(VERSION));
99   entry->AddCpuField();
100 };
101 
AddConnectionTypeToLogEntry(ServerLogEntry * entry,protocol::TransportRoute::RouteType type)102 void AddConnectionTypeToLogEntry(ServerLogEntry* entry,
103     protocol::TransportRoute::RouteType type) {
104   entry->Set(kKeyConnectionType, protocol::TransportRoute::GetTypeString(type));
105 }
106 
107 }  // namespace remoting
108