// Generated by the protocol buffer compiler.  DO NOT EDIT!
// source: keyapis/watchdog/v1/keyapis_watchdog_events_v1.proto

#ifndef GOOGLE_PROTOBUF_INCLUDED_keyapis_2fwatchdog_2fv1_2fkeyapis_5fwatchdog_5fevents_5fv1_2eproto_2epb_2eh
#define GOOGLE_PROTOBUF_INCLUDED_keyapis_2fwatchdog_2fv1_2fkeyapis_5fwatchdog_5fevents_5fv1_2eproto_2epb_2eh

#include <limits>
#include <string>
#include <type_traits>

#include "google/protobuf/port_def.inc"
#if PROTOBUF_VERSION < 4023000
#error "This file was generated by a newer version of protoc which is"
#error "incompatible with your Protocol Buffer headers. Please update"
#error "your headers."
#endif  // PROTOBUF_VERSION

#if 4023001 < PROTOBUF_MIN_PROTOC_VERSION
#error "This file was generated by an older version of protoc which is"
#error "incompatible with your Protocol Buffer headers. Please"
#error "regenerate this file with a newer version of protoc."
#endif  // PROTOBUF_MIN_PROTOC_VERSION
#include "google/protobuf/port_undef.inc"
#include "google/protobuf/io/coded_stream.h"
#include "google/protobuf/arena.h"
#include "google/protobuf/arenastring.h"
#include "google/protobuf/generated_message_util.h"
#include "google/protobuf/metadata_lite.h"
#include "google/protobuf/message_lite.h"
#include "google/protobuf/repeated_field.h"  // IWYU pragma: export
#include "google/protobuf/extension_set.h"  // IWYU pragma: export
#include "google/protobuf/generated_enum_util.h"
#include "google/api/field_behavior.pb.h"
// @@protoc_insertion_point(includes)

// Must be included last.
#include "google/protobuf/port_def.inc"

#define PROTOBUF_INTERNAL_EXPORT_keyapis_2fwatchdog_2fv1_2fkeyapis_5fwatchdog_5fevents_5fv1_2eproto

PROTOBUF_NAMESPACE_OPEN
namespace internal {
class AnyMetadata;
}  // namespace internal
PROTOBUF_NAMESPACE_CLOSE

// Internal implementation detail -- do not use these members.
struct TableStruct_keyapis_2fwatchdog_2fv1_2fkeyapis_5fwatchdog_5fevents_5fv1_2eproto {
  static const ::uint32_t offsets[];
};
namespace keyapis {
namespace watchdog {
namespace v1 {
class DeviceAvailabilityTask;
struct DeviceAvailabilityTaskDefaultTypeInternal;
extern DeviceAvailabilityTaskDefaultTypeInternal _DeviceAvailabilityTask_default_instance_;
}  // namespace v1
}  // namespace watchdog
}  // namespace keyapis
PROTOBUF_NAMESPACE_OPEN
template <>
::keyapis::watchdog::v1::DeviceAvailabilityTask* Arena::CreateMaybeMessage<::keyapis::watchdog::v1::DeviceAvailabilityTask>(Arena*);
PROTOBUF_NAMESPACE_CLOSE

namespace keyapis {
namespace watchdog {
namespace v1 {
enum DeviceAvailabilityTask_AvailabilityType : int {
  DeviceAvailabilityTask_AvailabilityType_AVAILABILITY_TYPE_UNKNOWN = 0,
  DeviceAvailabilityTask_AvailabilityType_ONLINE = 1,
  DeviceAvailabilityTask_AvailabilityType_OFFLINE = 2,
  DeviceAvailabilityTask_AvailabilityType_DeviceAvailabilityTask_AvailabilityType_INT_MIN_SENTINEL_DO_NOT_USE_ =
      std::numeric_limits<::int32_t>::min(),
  DeviceAvailabilityTask_AvailabilityType_DeviceAvailabilityTask_AvailabilityType_INT_MAX_SENTINEL_DO_NOT_USE_ =
      std::numeric_limits<::int32_t>::max(),
};

bool DeviceAvailabilityTask_AvailabilityType_IsValid(int value);
constexpr DeviceAvailabilityTask_AvailabilityType DeviceAvailabilityTask_AvailabilityType_AvailabilityType_MIN = static_cast<DeviceAvailabilityTask_AvailabilityType>(0);
constexpr DeviceAvailabilityTask_AvailabilityType DeviceAvailabilityTask_AvailabilityType_AvailabilityType_MAX = static_cast<DeviceAvailabilityTask_AvailabilityType>(2);
constexpr int DeviceAvailabilityTask_AvailabilityType_AvailabilityType_ARRAYSIZE = 2 + 1;
const std::string& DeviceAvailabilityTask_AvailabilityType_Name(DeviceAvailabilityTask_AvailabilityType value);
template <typename T>
const std::string& DeviceAvailabilityTask_AvailabilityType_Name(T value) {
  static_assert(std::is_same<T, DeviceAvailabilityTask_AvailabilityType>::value ||
                    std::is_integral<T>::value,
                "Incorrect type passed to AvailabilityType_Name().");
  return DeviceAvailabilityTask_AvailabilityType_Name(static_cast<DeviceAvailabilityTask_AvailabilityType>(value));
}
const std::string& DeviceAvailabilityTask_AvailabilityType_Name(DeviceAvailabilityTask_AvailabilityType value);
bool DeviceAvailabilityTask_AvailabilityType_Parse(absl::string_view name, DeviceAvailabilityTask_AvailabilityType* value);

// ===================================================================


// -------------------------------------------------------------------

class DeviceAvailabilityTask final :
    public ::PROTOBUF_NAMESPACE_ID::MessageLite /* @@protoc_insertion_point(class_definition:keyapis.watchdog.v1.DeviceAvailabilityTask) */ {
 public:
  inline DeviceAvailabilityTask() : DeviceAvailabilityTask(nullptr) {}
  ~DeviceAvailabilityTask() override;
  template<typename = void>
  explicit PROTOBUF_CONSTEXPR DeviceAvailabilityTask(::PROTOBUF_NAMESPACE_ID::internal::ConstantInitialized);

  DeviceAvailabilityTask(const DeviceAvailabilityTask& from);
  DeviceAvailabilityTask(DeviceAvailabilityTask&& from) noexcept
    : DeviceAvailabilityTask() {
    *this = ::std::move(from);
  }

  inline DeviceAvailabilityTask& operator=(const DeviceAvailabilityTask& from) {
    CopyFrom(from);
    return *this;
  }
  inline DeviceAvailabilityTask& operator=(DeviceAvailabilityTask&& from) noexcept {
    if (this == &from) return *this;
    if (GetOwningArena() == from.GetOwningArena()
  #ifdef PROTOBUF_FORCE_COPY_IN_MOVE
        && GetOwningArena() != nullptr
  #endif  // !PROTOBUF_FORCE_COPY_IN_MOVE
    ) {
      InternalSwap(&from);
    } else {
      CopyFrom(from);
    }
    return *this;
  }

  inline const std::string& unknown_fields() const {
    return _internal_metadata_.unknown_fields<std::string>(::PROTOBUF_NAMESPACE_ID::internal::GetEmptyString);
  }
  inline std::string* mutable_unknown_fields() {
    return _internal_metadata_.mutable_unknown_fields<std::string>();
  }

  static const DeviceAvailabilityTask& default_instance() {
    return *internal_default_instance();
  }
  static inline const DeviceAvailabilityTask* internal_default_instance() {
    return reinterpret_cast<const DeviceAvailabilityTask*>(
               &_DeviceAvailabilityTask_default_instance_);
  }
  static constexpr int kIndexInFileMessages =
    0;

  friend void swap(DeviceAvailabilityTask& a, DeviceAvailabilityTask& b) {
    a.Swap(&b);
  }
  inline void Swap(DeviceAvailabilityTask* other) {
    if (other == this) return;
  #ifdef PROTOBUF_FORCE_COPY_IN_SWAP
    if (GetOwningArena() != nullptr &&
        GetOwningArena() == other->GetOwningArena()) {
   #else  // PROTOBUF_FORCE_COPY_IN_SWAP
    if (GetOwningArena() == other->GetOwningArena()) {
  #endif  // !PROTOBUF_FORCE_COPY_IN_SWAP
      InternalSwap(other);
    } else {
      ::PROTOBUF_NAMESPACE_ID::internal::GenericSwap(this, other);
    }
  }
  void UnsafeArenaSwap(DeviceAvailabilityTask* other) {
    if (other == this) return;
    ABSL_DCHECK(GetOwningArena() == other->GetOwningArena());
    InternalSwap(other);
  }

  // implements Message ----------------------------------------------

  DeviceAvailabilityTask* New(::PROTOBUF_NAMESPACE_ID::Arena* arena = nullptr) const final {
    return CreateMaybeMessage<DeviceAvailabilityTask>(arena);
  }
  void CheckTypeAndMergeFrom(const ::PROTOBUF_NAMESPACE_ID::MessageLite& from)  final;
  void CopyFrom(const DeviceAvailabilityTask& from);
  void MergeFrom(const DeviceAvailabilityTask& from);
  PROTOBUF_ATTRIBUTE_REINITIALIZES void Clear() final;
  bool IsInitialized() const final;

  ::size_t ByteSizeLong() const final;
  const char* _InternalParse(const char* ptr, ::PROTOBUF_NAMESPACE_ID::internal::ParseContext* ctx) final;
  ::uint8_t* _InternalSerialize(
      ::uint8_t* target, ::PROTOBUF_NAMESPACE_ID::io::EpsCopyOutputStream* stream) const final;
  int GetCachedSize() const final { return _impl_._cached_size_.Get(); }

  private:
  void SharedCtor(::PROTOBUF_NAMESPACE_ID::Arena* arena);
  void SharedDtor();
  void SetCachedSize(int size) const;
  void InternalSwap(DeviceAvailabilityTask* other);

  private:
  friend class ::PROTOBUF_NAMESPACE_ID::internal::AnyMetadata;
  static ::absl::string_view FullMessageName() {
    return "keyapis.watchdog.v1.DeviceAvailabilityTask";
  }
  protected:
  explicit DeviceAvailabilityTask(::PROTOBUF_NAMESPACE_ID::Arena* arena);
  public:

  std::string GetTypeName() const final;

  // nested types ----------------------------------------------------

  using AvailabilityType = DeviceAvailabilityTask_AvailabilityType;
  static constexpr AvailabilityType AVAILABILITY_TYPE_UNKNOWN = DeviceAvailabilityTask_AvailabilityType_AVAILABILITY_TYPE_UNKNOWN;
  static constexpr AvailabilityType ONLINE = DeviceAvailabilityTask_AvailabilityType_ONLINE;
  static constexpr AvailabilityType OFFLINE = DeviceAvailabilityTask_AvailabilityType_OFFLINE;
  static inline bool AvailabilityType_IsValid(int value) {
    return DeviceAvailabilityTask_AvailabilityType_IsValid(value);
  }
  static constexpr AvailabilityType AvailabilityType_MIN = DeviceAvailabilityTask_AvailabilityType_AvailabilityType_MIN;
  static constexpr AvailabilityType AvailabilityType_MAX = DeviceAvailabilityTask_AvailabilityType_AvailabilityType_MAX;
  static constexpr int AvailabilityType_ARRAYSIZE = DeviceAvailabilityTask_AvailabilityType_AvailabilityType_ARRAYSIZE;
  template <typename T>
  static inline const std::string& AvailabilityType_Name(T value) {
    return DeviceAvailabilityTask_AvailabilityType_Name(value);
  }
  static inline bool AvailabilityType_Parse(absl::string_view name, AvailabilityType* value) {
    return DeviceAvailabilityTask_AvailabilityType_Parse(name, value);
  }

  // accessors -------------------------------------------------------

  enum : int {
    kRequestIdFieldNumber = 1,
    kDeviceIdFieldNumber = 2,
    kAvailabilityTypeFieldNumber = 3,
  };
  // string request_id = 1 [(.google.api.field_behavior) = REQUIRED];
  void clear_request_id() ;
  const std::string& request_id() const;




  template <typename Arg_ = const std::string&, typename... Args_>
  void set_request_id(Arg_&& arg, Args_... args);
  std::string* mutable_request_id();
  PROTOBUF_NODISCARD std::string* release_request_id();
  void set_allocated_request_id(std::string* ptr);

  private:
  const std::string& _internal_request_id() const;
  inline PROTOBUF_ALWAYS_INLINE void _internal_set_request_id(
      const std::string& value);
  std::string* _internal_mutable_request_id();

  public:
  // int32 device_id = 2 [(.google.api.field_behavior) = REQUIRED];
  void clear_device_id() ;
  ::int32_t device_id() const;
  void set_device_id(::int32_t value);

  private:
  ::int32_t _internal_device_id() const;
  void _internal_set_device_id(::int32_t value);

  public:
  // .keyapis.watchdog.v1.DeviceAvailabilityTask.AvailabilityType availability_type = 3 [(.google.api.field_behavior) = REQUIRED];
  void clear_availability_type() ;
  ::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType availability_type() const;
  void set_availability_type(::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType value);

  private:
  ::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType _internal_availability_type() const;
  void _internal_set_availability_type(::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType value);

  public:
  // @@protoc_insertion_point(class_scope:keyapis.watchdog.v1.DeviceAvailabilityTask)
 private:
  class _Internal;

  template <typename T> friend class ::PROTOBUF_NAMESPACE_ID::Arena::InternalHelper;
  typedef void InternalArenaConstructable_;
  typedef void DestructorSkippable_;
  struct Impl_ {
    ::PROTOBUF_NAMESPACE_ID::internal::ArenaStringPtr request_id_;
    ::int32_t device_id_;
    int availability_type_;
    mutable ::PROTOBUF_NAMESPACE_ID::internal::CachedSize _cached_size_;
  };
  union { Impl_ _impl_; };
  friend struct ::TableStruct_keyapis_2fwatchdog_2fv1_2fkeyapis_5fwatchdog_5fevents_5fv1_2eproto;
};

// ===================================================================




// ===================================================================


#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wstrict-aliasing"
#endif  // __GNUC__
// -------------------------------------------------------------------

// DeviceAvailabilityTask

// string request_id = 1 [(.google.api.field_behavior) = REQUIRED];
inline void DeviceAvailabilityTask::clear_request_id() {
  _impl_.request_id_.ClearToEmpty();
}
inline const std::string& DeviceAvailabilityTask::request_id() const {
  // @@protoc_insertion_point(field_get:keyapis.watchdog.v1.DeviceAvailabilityTask.request_id)
  return _internal_request_id();
}
template <typename Arg_, typename... Args_>
inline PROTOBUF_ALWAYS_INLINE void DeviceAvailabilityTask::set_request_id(Arg_&& arg,
                                                     Args_... args) {
  ;
  _impl_.request_id_.Set(static_cast<Arg_&&>(arg), args..., GetArenaForAllocation());
  // @@protoc_insertion_point(field_set:keyapis.watchdog.v1.DeviceAvailabilityTask.request_id)
}
inline std::string* DeviceAvailabilityTask::mutable_request_id() {
  std::string* _s = _internal_mutable_request_id();
  // @@protoc_insertion_point(field_mutable:keyapis.watchdog.v1.DeviceAvailabilityTask.request_id)
  return _s;
}
inline const std::string& DeviceAvailabilityTask::_internal_request_id() const {
  return _impl_.request_id_.Get();
}
inline void DeviceAvailabilityTask::_internal_set_request_id(const std::string& value) {
  ;


  _impl_.request_id_.Set(value, GetArenaForAllocation());
}
inline std::string* DeviceAvailabilityTask::_internal_mutable_request_id() {
  ;
  return _impl_.request_id_.Mutable( GetArenaForAllocation());
}
inline std::string* DeviceAvailabilityTask::release_request_id() {
  // @@protoc_insertion_point(field_release:keyapis.watchdog.v1.DeviceAvailabilityTask.request_id)
  return _impl_.request_id_.Release();
}
inline void DeviceAvailabilityTask::set_allocated_request_id(std::string* value) {
  _impl_.request_id_.SetAllocated(value, GetArenaForAllocation());
  #ifdef PROTOBUF_FORCE_COPY_DEFAULT_STRING
        if (_impl_.request_id_.IsDefault()) {
          _impl_.request_id_.Set("", GetArenaForAllocation());
        }
  #endif  // PROTOBUF_FORCE_COPY_DEFAULT_STRING
  // @@protoc_insertion_point(field_set_allocated:keyapis.watchdog.v1.DeviceAvailabilityTask.request_id)
}

// int32 device_id = 2 [(.google.api.field_behavior) = REQUIRED];
inline void DeviceAvailabilityTask::clear_device_id() {
  _impl_.device_id_ = 0;
}
inline ::int32_t DeviceAvailabilityTask::device_id() const {
  // @@protoc_insertion_point(field_get:keyapis.watchdog.v1.DeviceAvailabilityTask.device_id)
  return _internal_device_id();
}
inline void DeviceAvailabilityTask::set_device_id(::int32_t value) {
  _internal_set_device_id(value);
  // @@protoc_insertion_point(field_set:keyapis.watchdog.v1.DeviceAvailabilityTask.device_id)
}
inline ::int32_t DeviceAvailabilityTask::_internal_device_id() const {
  return _impl_.device_id_;
}
inline void DeviceAvailabilityTask::_internal_set_device_id(::int32_t value) {
  ;
  _impl_.device_id_ = value;
}

// .keyapis.watchdog.v1.DeviceAvailabilityTask.AvailabilityType availability_type = 3 [(.google.api.field_behavior) = REQUIRED];
inline void DeviceAvailabilityTask::clear_availability_type() {
  _impl_.availability_type_ = 0;
}
inline ::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType DeviceAvailabilityTask::availability_type() const {
  // @@protoc_insertion_point(field_get:keyapis.watchdog.v1.DeviceAvailabilityTask.availability_type)
  return _internal_availability_type();
}
inline void DeviceAvailabilityTask::set_availability_type(::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType value) {
   _internal_set_availability_type(value);
  // @@protoc_insertion_point(field_set:keyapis.watchdog.v1.DeviceAvailabilityTask.availability_type)
}
inline ::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType DeviceAvailabilityTask::_internal_availability_type() const {
  return static_cast<::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType>(_impl_.availability_type_);
}
inline void DeviceAvailabilityTask::_internal_set_availability_type(::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType value) {
  ;
  _impl_.availability_type_ = value;
}

#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif  // __GNUC__

// @@protoc_insertion_point(namespace_scope)
}  // namespace v1
}  // namespace watchdog
}  // namespace keyapis


PROTOBUF_NAMESPACE_OPEN

template <>
struct is_proto_enum<::keyapis::watchdog::v1::DeviceAvailabilityTask_AvailabilityType> : std::true_type {};

PROTOBUF_NAMESPACE_CLOSE

// @@protoc_insertion_point(global_scope)

#include "google/protobuf/port_undef.inc"

#endif  // GOOGLE_PROTOBUF_INCLUDED_keyapis_2fwatchdog_2fv1_2fkeyapis_5fwatchdog_5fevents_5fv1_2eproto_2epb_2eh
