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

#ifndef GOOGLE_PROTOBUF_INCLUDED_keyapis_2faudit_2fv1_2fkeyapis_5faudit_5fevents_5fv1_2eproto_2epb_2eh
#define GOOGLE_PROTOBUF_INCLUDED_keyapis_2faudit_2fv1_2fkeyapis_5faudit_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/api/annotations.pb.h"
#include "google/api/field_behavior.pb.h"
#include "google/protobuf/descriptor.pb.h"
#include "google/protobuf/timestamp.pb.h"
// @@protoc_insertion_point(includes)

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

#define PROTOBUF_INTERNAL_EXPORT_keyapis_2faudit_2fv1_2fkeyapis_5faudit_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_2faudit_2fv1_2fkeyapis_5faudit_5fevents_5fv1_2eproto {
  static const ::uint32_t offsets[];
};
namespace keyapis {
namespace audit {
namespace v1 {
class AuditEvent;
struct AuditEventDefaultTypeInternal;
extern AuditEventDefaultTypeInternal _AuditEvent_default_instance_;
}  // namespace v1
}  // namespace audit
}  // namespace keyapis
PROTOBUF_NAMESPACE_OPEN
template <>
::keyapis::audit::v1::AuditEvent* Arena::CreateMaybeMessage<::keyapis::audit::v1::AuditEvent>(Arena*);
PROTOBUF_NAMESPACE_CLOSE

namespace keyapis {
namespace audit {
namespace v1 {

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


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

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

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

  inline AuditEvent& operator=(const AuditEvent& from) {
    CopyFrom(from);
    return *this;
  }
  inline AuditEvent& operator=(AuditEvent&& 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 AuditEvent& default_instance() {
    return *internal_default_instance();
  }
  static inline const AuditEvent* internal_default_instance() {
    return reinterpret_cast<const AuditEvent*>(
               &_AuditEvent_default_instance_);
  }
  static constexpr int kIndexInFileMessages =
    0;

  friend void swap(AuditEvent& a, AuditEvent& b) {
    a.Swap(&b);
  }
  inline void Swap(AuditEvent* 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(AuditEvent* other) {
    if (other == this) return;
    ABSL_DCHECK(GetOwningArena() == other->GetOwningArena());
    InternalSwap(other);
  }

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

  AuditEvent* New(::PROTOBUF_NAMESPACE_ID::Arena* arena = nullptr) const final {
    return CreateMaybeMessage<AuditEvent>(arena);
  }
  void CheckTypeAndMergeFrom(const ::PROTOBUF_NAMESPACE_ID::MessageLite& from)  final;
  void CopyFrom(const AuditEvent& from);
  void MergeFrom(const AuditEvent& 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(AuditEvent* other);

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

  std::string GetTypeName() const final;

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

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

  enum : int {
    kKindFieldNumber = 2,
    kPreviousDataFieldNumber = 3,
    kCurrentDataFieldNumber = 4,
    kServiceNameFieldNumber = 5,
    kTimeFieldNumber = 1,
    kUserIdFieldNumber = 6,
  };
  // string kind = 2 [(.google.api.field_behavior) = REQUIRED];
  void clear_kind() ;
  const std::string& kind() const;




  template <typename Arg_ = const std::string&, typename... Args_>
  void set_kind(Arg_&& arg, Args_... args);
  std::string* mutable_kind();
  PROTOBUF_NODISCARD std::string* release_kind();
  void set_allocated_kind(std::string* ptr);

  private:
  const std::string& _internal_kind() const;
  inline PROTOBUF_ALWAYS_INLINE void _internal_set_kind(
      const std::string& value);
  std::string* _internal_mutable_kind();

  public:
  // string previous_data = 3;
  void clear_previous_data() ;
  const std::string& previous_data() const;




  template <typename Arg_ = const std::string&, typename... Args_>
  void set_previous_data(Arg_&& arg, Args_... args);
  std::string* mutable_previous_data();
  PROTOBUF_NODISCARD std::string* release_previous_data();
  void set_allocated_previous_data(std::string* ptr);

  private:
  const std::string& _internal_previous_data() const;
  inline PROTOBUF_ALWAYS_INLINE void _internal_set_previous_data(
      const std::string& value);
  std::string* _internal_mutable_previous_data();

  public:
  // string current_data = 4 [(.google.api.field_behavior) = REQUIRED];
  void clear_current_data() ;
  const std::string& current_data() const;




  template <typename Arg_ = const std::string&, typename... Args_>
  void set_current_data(Arg_&& arg, Args_... args);
  std::string* mutable_current_data();
  PROTOBUF_NODISCARD std::string* release_current_data();
  void set_allocated_current_data(std::string* ptr);

  private:
  const std::string& _internal_current_data() const;
  inline PROTOBUF_ALWAYS_INLINE void _internal_set_current_data(
      const std::string& value);
  std::string* _internal_mutable_current_data();

  public:
  // string service_name = 5;
  void clear_service_name() ;
  const std::string& service_name() const;




  template <typename Arg_ = const std::string&, typename... Args_>
  void set_service_name(Arg_&& arg, Args_... args);
  std::string* mutable_service_name();
  PROTOBUF_NODISCARD std::string* release_service_name();
  void set_allocated_service_name(std::string* ptr);

  private:
  const std::string& _internal_service_name() const;
  inline PROTOBUF_ALWAYS_INLINE void _internal_set_service_name(
      const std::string& value);
  std::string* _internal_mutable_service_name();

  public:
  // int64 time = 1;
  void clear_time() ;
  ::int64_t time() const;
  void set_time(::int64_t value);

  private:
  ::int64_t _internal_time() const;
  void _internal_set_time(::int64_t value);

  public:
  // int32 user_id = 6;
  void clear_user_id() ;
  ::int32_t user_id() const;
  void set_user_id(::int32_t value);

  private:
  ::int32_t _internal_user_id() const;
  void _internal_set_user_id(::int32_t value);

  public:
  // @@protoc_insertion_point(class_scope:keyapis.audit.v1.AuditEvent)
 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 kind_;
    ::PROTOBUF_NAMESPACE_ID::internal::ArenaStringPtr previous_data_;
    ::PROTOBUF_NAMESPACE_ID::internal::ArenaStringPtr current_data_;
    ::PROTOBUF_NAMESPACE_ID::internal::ArenaStringPtr service_name_;
    ::int64_t time_;
    ::int32_t user_id_;
    mutable ::PROTOBUF_NAMESPACE_ID::internal::CachedSize _cached_size_;
  };
  union { Impl_ _impl_; };
  friend struct ::TableStruct_keyapis_2faudit_2fv1_2fkeyapis_5faudit_5fevents_5fv1_2eproto;
};

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




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


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

// AuditEvent

// int64 time = 1;
inline void AuditEvent::clear_time() {
  _impl_.time_ = ::int64_t{0};
}
inline ::int64_t AuditEvent::time() const {
  // @@protoc_insertion_point(field_get:keyapis.audit.v1.AuditEvent.time)
  return _internal_time();
}
inline void AuditEvent::set_time(::int64_t value) {
  _internal_set_time(value);
  // @@protoc_insertion_point(field_set:keyapis.audit.v1.AuditEvent.time)
}
inline ::int64_t AuditEvent::_internal_time() const {
  return _impl_.time_;
}
inline void AuditEvent::_internal_set_time(::int64_t value) {
  ;
  _impl_.time_ = value;
}

// string kind = 2 [(.google.api.field_behavior) = REQUIRED];
inline void AuditEvent::clear_kind() {
  _impl_.kind_.ClearToEmpty();
}
inline const std::string& AuditEvent::kind() const {
  // @@protoc_insertion_point(field_get:keyapis.audit.v1.AuditEvent.kind)
  return _internal_kind();
}
template <typename Arg_, typename... Args_>
inline PROTOBUF_ALWAYS_INLINE void AuditEvent::set_kind(Arg_&& arg,
                                                     Args_... args) {
  ;
  _impl_.kind_.Set(static_cast<Arg_&&>(arg), args..., GetArenaForAllocation());
  // @@protoc_insertion_point(field_set:keyapis.audit.v1.AuditEvent.kind)
}
inline std::string* AuditEvent::mutable_kind() {
  std::string* _s = _internal_mutable_kind();
  // @@protoc_insertion_point(field_mutable:keyapis.audit.v1.AuditEvent.kind)
  return _s;
}
inline const std::string& AuditEvent::_internal_kind() const {
  return _impl_.kind_.Get();
}
inline void AuditEvent::_internal_set_kind(const std::string& value) {
  ;


  _impl_.kind_.Set(value, GetArenaForAllocation());
}
inline std::string* AuditEvent::_internal_mutable_kind() {
  ;
  return _impl_.kind_.Mutable( GetArenaForAllocation());
}
inline std::string* AuditEvent::release_kind() {
  // @@protoc_insertion_point(field_release:keyapis.audit.v1.AuditEvent.kind)
  return _impl_.kind_.Release();
}
inline void AuditEvent::set_allocated_kind(std::string* value) {
  _impl_.kind_.SetAllocated(value, GetArenaForAllocation());
  #ifdef PROTOBUF_FORCE_COPY_DEFAULT_STRING
        if (_impl_.kind_.IsDefault()) {
          _impl_.kind_.Set("", GetArenaForAllocation());
        }
  #endif  // PROTOBUF_FORCE_COPY_DEFAULT_STRING
  // @@protoc_insertion_point(field_set_allocated:keyapis.audit.v1.AuditEvent.kind)
}

// string previous_data = 3;
inline void AuditEvent::clear_previous_data() {
  _impl_.previous_data_.ClearToEmpty();
}
inline const std::string& AuditEvent::previous_data() const {
  // @@protoc_insertion_point(field_get:keyapis.audit.v1.AuditEvent.previous_data)
  return _internal_previous_data();
}
template <typename Arg_, typename... Args_>
inline PROTOBUF_ALWAYS_INLINE void AuditEvent::set_previous_data(Arg_&& arg,
                                                     Args_... args) {
  ;
  _impl_.previous_data_.Set(static_cast<Arg_&&>(arg), args..., GetArenaForAllocation());
  // @@protoc_insertion_point(field_set:keyapis.audit.v1.AuditEvent.previous_data)
}
inline std::string* AuditEvent::mutable_previous_data() {
  std::string* _s = _internal_mutable_previous_data();
  // @@protoc_insertion_point(field_mutable:keyapis.audit.v1.AuditEvent.previous_data)
  return _s;
}
inline const std::string& AuditEvent::_internal_previous_data() const {
  return _impl_.previous_data_.Get();
}
inline void AuditEvent::_internal_set_previous_data(const std::string& value) {
  ;


  _impl_.previous_data_.Set(value, GetArenaForAllocation());
}
inline std::string* AuditEvent::_internal_mutable_previous_data() {
  ;
  return _impl_.previous_data_.Mutable( GetArenaForAllocation());
}
inline std::string* AuditEvent::release_previous_data() {
  // @@protoc_insertion_point(field_release:keyapis.audit.v1.AuditEvent.previous_data)
  return _impl_.previous_data_.Release();
}
inline void AuditEvent::set_allocated_previous_data(std::string* value) {
  _impl_.previous_data_.SetAllocated(value, GetArenaForAllocation());
  #ifdef PROTOBUF_FORCE_COPY_DEFAULT_STRING
        if (_impl_.previous_data_.IsDefault()) {
          _impl_.previous_data_.Set("", GetArenaForAllocation());
        }
  #endif  // PROTOBUF_FORCE_COPY_DEFAULT_STRING
  // @@protoc_insertion_point(field_set_allocated:keyapis.audit.v1.AuditEvent.previous_data)
}

// string current_data = 4 [(.google.api.field_behavior) = REQUIRED];
inline void AuditEvent::clear_current_data() {
  _impl_.current_data_.ClearToEmpty();
}
inline const std::string& AuditEvent::current_data() const {
  // @@protoc_insertion_point(field_get:keyapis.audit.v1.AuditEvent.current_data)
  return _internal_current_data();
}
template <typename Arg_, typename... Args_>
inline PROTOBUF_ALWAYS_INLINE void AuditEvent::set_current_data(Arg_&& arg,
                                                     Args_... args) {
  ;
  _impl_.current_data_.Set(static_cast<Arg_&&>(arg), args..., GetArenaForAllocation());
  // @@protoc_insertion_point(field_set:keyapis.audit.v1.AuditEvent.current_data)
}
inline std::string* AuditEvent::mutable_current_data() {
  std::string* _s = _internal_mutable_current_data();
  // @@protoc_insertion_point(field_mutable:keyapis.audit.v1.AuditEvent.current_data)
  return _s;
}
inline const std::string& AuditEvent::_internal_current_data() const {
  return _impl_.current_data_.Get();
}
inline void AuditEvent::_internal_set_current_data(const std::string& value) {
  ;


  _impl_.current_data_.Set(value, GetArenaForAllocation());
}
inline std::string* AuditEvent::_internal_mutable_current_data() {
  ;
  return _impl_.current_data_.Mutable( GetArenaForAllocation());
}
inline std::string* AuditEvent::release_current_data() {
  // @@protoc_insertion_point(field_release:keyapis.audit.v1.AuditEvent.current_data)
  return _impl_.current_data_.Release();
}
inline void AuditEvent::set_allocated_current_data(std::string* value) {
  _impl_.current_data_.SetAllocated(value, GetArenaForAllocation());
  #ifdef PROTOBUF_FORCE_COPY_DEFAULT_STRING
        if (_impl_.current_data_.IsDefault()) {
          _impl_.current_data_.Set("", GetArenaForAllocation());
        }
  #endif  // PROTOBUF_FORCE_COPY_DEFAULT_STRING
  // @@protoc_insertion_point(field_set_allocated:keyapis.audit.v1.AuditEvent.current_data)
}

// string service_name = 5;
inline void AuditEvent::clear_service_name() {
  _impl_.service_name_.ClearToEmpty();
}
inline const std::string& AuditEvent::service_name() const {
  // @@protoc_insertion_point(field_get:keyapis.audit.v1.AuditEvent.service_name)
  return _internal_service_name();
}
template <typename Arg_, typename... Args_>
inline PROTOBUF_ALWAYS_INLINE void AuditEvent::set_service_name(Arg_&& arg,
                                                     Args_... args) {
  ;
  _impl_.service_name_.Set(static_cast<Arg_&&>(arg), args..., GetArenaForAllocation());
  // @@protoc_insertion_point(field_set:keyapis.audit.v1.AuditEvent.service_name)
}
inline std::string* AuditEvent::mutable_service_name() {
  std::string* _s = _internal_mutable_service_name();
  // @@protoc_insertion_point(field_mutable:keyapis.audit.v1.AuditEvent.service_name)
  return _s;
}
inline const std::string& AuditEvent::_internal_service_name() const {
  return _impl_.service_name_.Get();
}
inline void AuditEvent::_internal_set_service_name(const std::string& value) {
  ;


  _impl_.service_name_.Set(value, GetArenaForAllocation());
}
inline std::string* AuditEvent::_internal_mutable_service_name() {
  ;
  return _impl_.service_name_.Mutable( GetArenaForAllocation());
}
inline std::string* AuditEvent::release_service_name() {
  // @@protoc_insertion_point(field_release:keyapis.audit.v1.AuditEvent.service_name)
  return _impl_.service_name_.Release();
}
inline void AuditEvent::set_allocated_service_name(std::string* value) {
  _impl_.service_name_.SetAllocated(value, GetArenaForAllocation());
  #ifdef PROTOBUF_FORCE_COPY_DEFAULT_STRING
        if (_impl_.service_name_.IsDefault()) {
          _impl_.service_name_.Set("", GetArenaForAllocation());
        }
  #endif  // PROTOBUF_FORCE_COPY_DEFAULT_STRING
  // @@protoc_insertion_point(field_set_allocated:keyapis.audit.v1.AuditEvent.service_name)
}

// int32 user_id = 6;
inline void AuditEvent::clear_user_id() {
  _impl_.user_id_ = 0;
}
inline ::int32_t AuditEvent::user_id() const {
  // @@protoc_insertion_point(field_get:keyapis.audit.v1.AuditEvent.user_id)
  return _internal_user_id();
}
inline void AuditEvent::set_user_id(::int32_t value) {
  _internal_set_user_id(value);
  // @@protoc_insertion_point(field_set:keyapis.audit.v1.AuditEvent.user_id)
}
inline ::int32_t AuditEvent::_internal_user_id() const {
  return _impl_.user_id_;
}
inline void AuditEvent::_internal_set_user_id(::int32_t value) {
  ;
  _impl_.user_id_ = value;
}

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

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


// @@protoc_insertion_point(global_scope)

#include "google/protobuf/port_undef.inc"

#endif  // GOOGLE_PROTOBUF_INCLUDED_keyapis_2faudit_2fv1_2fkeyapis_5faudit_5fevents_5fv1_2eproto_2epb_2eh
