blob: 85529a190a9d2773b734b22dc4bdba341cc08d9e [file] [log] [blame]
// Copyright 2017 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 "ash/system/network/sms_observer.h"
#include <memory>
#include "ash/public/cpp/notification_utils.h"
#include "ash/resources/vector_icons/vector_icons.h"
#include "ash/system/tray/tray_constants.h"
#include "base/strings/string_util.h"
#include "base/strings/utf_string_conversions.h"
#include "chromeos/network/network_event_log.h"
#include "chromeos/network/network_handler.h"
#include "ui/gfx/paint_vector_icon.h"
#include "ui/message_center/message_center.h"
using chromeos::NetworkHandler;
namespace ash {
namespace {
const char kNotifierSms[] = "ash.sms";
// Send the |message| to notification center to display to users. Note that each
// notification will be assigned with different |message_id| as notification id.
void ShowNotification(const base::DictionaryValue* message,
const std::string& message_text,
const std::string& message_number,
int message_id) {
message_center::MessageCenter* message_center =
message_center::MessageCenter::Get();
if (!message_center)
return;
const char kNotificationId[] = "chrome://network/sms";
std::unique_ptr<message_center::Notification> notification;
// TODO(estade): should SMS notifications really be shown to all users?
notification = ash::CreateSystemNotification(
message_center::NOTIFICATION_TYPE_SIMPLE,
kNotificationId + std::to_string(message_id),
base::ASCIIToUTF16(message_number),
base::CollapseWhitespace(base::UTF8ToUTF16(message_text),
false /* trim_sequences_with_line_breaks */),
base::string16(), GURL(),
message_center::NotifierId(message_center::NotifierType::SYSTEM_COMPONENT,
kNotifierSms),
message_center::RichNotificationData(), nullptr, kNotificationSmsSyncIcon,
message_center::SystemNotificationWarningLevel::NORMAL);
message_center->AddNotification(std::move(notification));
}
} // namespace
SmsObserver::SmsObserver() {
// TODO(armansito): SMS could be a special case for cellular that requires a
// user (perhaps the owner) to be logged in. If that is the case, then an
// additional check should be done before subscribing for SMS notifications.
if (NetworkHandler::IsInitialized())
NetworkHandler::Get()->network_sms_handler()->AddObserver(this);
}
SmsObserver::~SmsObserver() {
if (NetworkHandler::IsInitialized()) {
NetworkHandler::Get()->network_sms_handler()->RemoveObserver(this);
}
}
void SmsObserver::MessageReceived(const base::DictionaryValue& message) {
std::string message_text;
if (!message.GetStringWithoutPathExpansion(
chromeos::NetworkSmsHandler::kTextKey, &message_text)) {
NET_LOG(ERROR) << "SMS message contains no content.";
return;
}
// TODO(armansito): A message might be due to a special "Message Waiting"
// state that the message is in. Once SMS handling moves to shill, such
// messages should be filtered there so that this check becomes unnecessary.
if (message_text.empty()) {
NET_LOG(DEBUG) << "SMS has empty content text. Ignoring.";
return;
}
std::string message_number;
if (!message.GetStringWithoutPathExpansion(
chromeos::NetworkSmsHandler::kNumberKey, &message_number)) {
NET_LOG(DEBUG) << "SMS contains no number. Ignoring.";
return;
}
NET_LOG(DEBUG) << "Received SMS from: " << message_number
<< " with text: " << message_text;
message_id_++;
ShowNotification(&message, message_text, message_number, message_id_);
}
} // namespace ash