//
// Copyright (C) 2012 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#ifndef SHILL_ERROR_H_
#define SHILL_ERROR_H_
#include <memory>
#include <string>
#include <base/location.h>
#include <base/macros.h>
namespace DBus {
class Error;
} // namespace DBus
namespace brillo {
class Error;
using ErrorPtr = std::unique_ptr<Error>;
} // namespace brillo
namespace shill {
class Error {
public:
enum Type {
kSuccess = 0, // No error.
kOperationFailed, // failure, otherwise unspecified
kAlreadyConnected,
kAlreadyExists,
kIncorrectPin,
kInProgress,
kInternalError,
kInvalidApn,
kInvalidArguments,
kInvalidNetworkName,
kInvalidPassphrase,
kInvalidProperty,
kNoCarrier,
kNotConnected,
kNotFound,
kNotImplemented,
kNotOnHomeNetwork,
kNotRegistered,
kNotSupported,
kOperationAborted,
kOperationInitiated,
kOperationTimeout,
kPassphraseRequired,
kPermissionDenied,
kPinBlocked,
kPinRequired,
kWrongState,
kNumErrors
};
Error(); // Success by default.
explicit Error(Type type); // Uses the default message for |type|.
Error(Type type, const std::string& message);
~Error();
void Populate(Type type); // Uses the default message for |type|.
void Populate(Type type, const std::string& message);
void Populate(Type type,
const std::string& message,
const tracked_objects::Location& location);
void Reset();
void CopyFrom(const Error& error);
// Sets the Chromeos |error| and returns true if Error represents failure.
// Leaves error unchanged, and returns false otherwise.
bool ToChromeosError(brillo::ErrorPtr* error) const;
Type type() const { return type_; }
const std::string& message() const { return message_; }
bool IsSuccess() const { return type_ == kSuccess; }
bool IsFailure() const { return !IsSuccess() && !IsOngoing(); }
bool IsOngoing() const { return type_ == kOperationInitiated; }
static std::string GetDBusResult(Type type);
static std::string GetDefaultMessage(Type type);
// Log an error message from |from_here|. If |error| is non-NULL, also
// populate it.
static void PopulateAndLog(const tracked_objects::Location& from_here,
Error* error, Type type,
const std::string& message);
private:
struct Info {
const char* dbus_result; // Error type name.
const char* message; // Default Error type message.
};
static const Info kInfos[kNumErrors];
Type type_;
std::string message_;
tracked_objects::Location location_;
DISALLOW_COPY_AND_ASSIGN(Error);
};
} // namespace shill
// stream operator provided to facilitate logging
std::ostream& operator<<(std::ostream& stream, const shill::Error& error);
#endif // SHILL_ERROR_H_