blob: 8374981adec2c3a8738112d20a98cb7b8ad5df19 [file] [log] [blame]
// Copyright 2015 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 "google_apis/gcm/engine/gcm_unregistration_request_handler.h"
#include "base/metrics/histogram_macros.h"
#include "base/stl_util.h"
#include "google_apis/gcm/base/gcm_util.h"
#include "net/url_request/url_fetcher.h"
namespace gcm {
namespace {
// Request constants.
const char kUnregistrationCallerKey[] = "gcm_unreg_caller";
// We are going to set the value to "false" in order to forcefully unregister
// the application.
const char kUnregistrationCallerValue[] = "false";
// Response constants.
const char kDeletedPrefix[] = "deleted=";
} // namespace
GCMUnregistrationRequestHandler::GCMUnregistrationRequestHandler(
const std::string& app_id)
: app_id_(app_id) {
}
GCMUnregistrationRequestHandler::~GCMUnregistrationRequestHandler() {}
void GCMUnregistrationRequestHandler::BuildRequestBody(std::string* body){
BuildFormEncoding(kUnregistrationCallerKey, kUnregistrationCallerValue, body);
}
UnregistrationRequest::Status GCMUnregistrationRequestHandler::ParseResponse(
const std::string& response) {
DVLOG(1) << "Parsing unregistration response.";
if (response.find(kDeletedPrefix) != std::string::npos) {
std::string deleted_app_id = response.substr(
response.find(kDeletedPrefix) + base::size(kDeletedPrefix) - 1);
return deleted_app_id == app_id_ ?
UnregistrationRequest::SUCCESS :
UnregistrationRequest::INCORRECT_APP_ID;
}
DVLOG(1) << "Not able to parse a meaningful output from response body."
<< response;
return UnregistrationRequest::RESPONSE_PARSING_FAILED;
}
void GCMUnregistrationRequestHandler::ReportUMAs(
UnregistrationRequest::Status status,
int retry_count,
base::TimeDelta complete_time) {
UMA_HISTOGRAM_ENUMERATION("GCM.UnregistrationRequestStatus",
status,
UnregistrationRequest::UNREGISTRATION_STATUS_COUNT);
// Other UMAs are only reported when the request succeeds.
if (status != UnregistrationRequest::SUCCESS)
return;
UMA_HISTOGRAM_COUNTS_1M("GCM.UnregistrationRetryCount", retry_count);
UMA_HISTOGRAM_TIMES("GCM.UnregistrationCompleteTime", complete_time);
}
} // namespace gcm