blob: 69e7e7e3336ef30c5b653445ff9495c72710cb60 [file] [log] [blame]
// Copyright 2015 The Weave 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 "src/notification/notification_parser.h"
#include <base/logging.h>
namespace weave {
namespace {
// Processes COMMAND_CREATED notifications.
bool ParseCommandCreated(const base::DictionaryValue& notification,
NotificationDelegate* delegate,
const std::string& channel_name) {
const base::DictionaryValue* command = nullptr;
if (!notification.GetDictionary("command", &command)) {
LOG(ERROR) << "COMMAND_CREATED notification is missing 'command' property";
return false;
}
delegate->OnCommandCreated(*command, channel_name);
return true;
}
// Processes DEVICE_DELETED notifications.
bool ParseDeviceDeleted(const base::DictionaryValue& notification,
NotificationDelegate* delegate) {
std::string cloud_id;
if (!notification.GetString("deviceId", &cloud_id)) {
LOG(ERROR) << "DEVICE_DELETED notification is missing 'deviceId' property";
return false;
}
delegate->OnDeviceDeleted(cloud_id);
return true;
}
} // anonymous namespace
bool ParseNotificationJson(const base::DictionaryValue& notification,
NotificationDelegate* delegate,
const std::string& channel_name) {
CHECK(delegate);
std::string kind;
if (!notification.GetString("kind", &kind) || kind != "weave#notification") {
LOG(WARNING) << "Push notification should have 'kind' property set to "
"weave#notification";
return false;
}
std::string type;
if (!notification.GetString("type", &type)) {
LOG(WARNING) << "Push notification should have 'type' property";
return false;
}
if (type == "COMMAND_CREATED")
return ParseCommandCreated(notification, delegate, channel_name);
if (type == "DEVICE_DELETED")
return ParseDeviceDeleted(notification, delegate);
// Here we ignore other types of notifications for now.
LOG(INFO) << "Ignoring push notification of type " << type;
return true;
}
} // namespace weave