blob: ede74627267b021742993255989989a151d88df3 [file] [log] [blame]
// 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 "components/sync/base/syncer_error.h"
#include "base/logging.h"
#include "base/strings/string_number_conversions.h"
#include "net/base/net_errors.h"
#include "net/http/http_status_code.h"
namespace syncer {
namespace {
#define ENUM_CASE(x) \
case SyncerError::x: \
return #x; \
break;
std::string GetSyncerErrorString(SyncerError::Value value) {
switch (value) {
ENUM_CASE(UNSET);
ENUM_CASE(CANNOT_DO_WORK);
ENUM_CASE(NETWORK_CONNECTION_UNAVAILABLE);
ENUM_CASE(NETWORK_IO_ERROR);
ENUM_CASE(SYNC_SERVER_ERROR);
ENUM_CASE(SYNC_AUTH_ERROR);
ENUM_CASE(SERVER_RETURN_INVALID_CREDENTIAL);
ENUM_CASE(SERVER_RETURN_UNKNOWN_ERROR);
ENUM_CASE(SERVER_RETURN_THROTTLED);
ENUM_CASE(SERVER_RETURN_TRANSIENT_ERROR);
ENUM_CASE(SERVER_RETURN_MIGRATION_DONE);
ENUM_CASE(SERVER_RETURN_CLEAR_PENDING);
ENUM_CASE(SERVER_RETURN_NOT_MY_BIRTHDAY);
ENUM_CASE(SERVER_RETURN_CONFLICT);
ENUM_CASE(SERVER_RESPONSE_VALIDATION_FAILED);
ENUM_CASE(SERVER_RETURN_DISABLED_BY_ADMIN);
ENUM_CASE(SERVER_RETURN_USER_ROLLBACK);
ENUM_CASE(SERVER_RETURN_PARTIAL_FAILURE);
ENUM_CASE(SERVER_RETURN_CLIENT_DATA_OBSOLETE);
ENUM_CASE(SERVER_MORE_TO_DOWNLOAD);
ENUM_CASE(DATATYPE_TRIGGERED_RETRY);
ENUM_CASE(SYNCER_OK);
}
NOTREACHED();
return "INVALID";
}
#undef ENUM_CASE
} // namespace
SyncerError::SyncerError(Value value) : value_(value) {
// NETWORK_CONNECTION_UNAVAILABLE error must be created via the separate
// factory method NetworkConnectionUnavailable().
DCHECK_NE(value_, NETWORK_CONNECTION_UNAVAILABLE);
// SYNC_SERVER_ERROR and SYNC_AUTH_ERROR both correspond to HTTP errors, and
// must be created via HttpError().
DCHECK_NE(value_, SYNC_SERVER_ERROR);
DCHECK_NE(value_, SYNC_AUTH_ERROR);
}
// static
SyncerError SyncerError::NetworkConnectionUnavailable(int net_error_code) {
return SyncerError(NETWORK_CONNECTION_UNAVAILABLE, net_error_code,
/*http_status_code=*/0);
}
// static
SyncerError SyncerError::HttpError(int http_status_code) {
return SyncerError((http_status_code == net::HTTP_UNAUTHORIZED)
? SYNC_AUTH_ERROR
: SYNC_SERVER_ERROR,
/*net_error_code=*/0, http_status_code);
}
std::string SyncerError::ToString() const {
std::string result = GetSyncerErrorString(value_);
if (value_ == NETWORK_CONNECTION_UNAVAILABLE) {
result += " (" + net::ErrorToShortString(net_error_code_) + ")";
} else if (value_ == SYNC_SERVER_ERROR || value_ == SYNC_AUTH_ERROR) {
result += " (HTTP " + base::NumberToString(http_status_code_) + ")";
}
return result;
}
bool SyncerError::IsActualError() const {
return value_ != UNSET && value_ != SYNCER_OK &&
value_ != SERVER_MORE_TO_DOWNLOAD;
}
} // namespace syncer