summaryrefslogtreecommitdiffstats
path: root/src/messages/MAuthReply.h
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/messages/MAuthReply.h69
1 files changed, 69 insertions, 0 deletions
diff --git a/src/messages/MAuthReply.h b/src/messages/MAuthReply.h
new file mode 100644
index 00000000..be3368e6
--- /dev/null
+++ b/src/messages/MAuthReply.h
@@ -0,0 +1,69 @@
+// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
+// vim: ts=8 sw=2 smarttab
+/*
+ * Ceph - scalable distributed file system
+ *
+ * Copyright (C) 2004-2006 Sage Weil <sage@newdream.net>
+ *
+ * This is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License version 2.1, as published by the Free Software
+ * Foundation. See file COPYING.
+ *
+ */
+
+#ifndef CEPH_MAUTHREPLY_H
+#define CEPH_MAUTHREPLY_H
+
+#include "msg/Message.h"
+#include "common/errno.h"
+
+class MAuthReply : public MessageInstance<MAuthReply> {
+public:
+ friend factory;
+
+ __u32 protocol;
+ errorcode32_t result;
+ uint64_t global_id; // if zero, meaningless
+ string result_msg;
+ bufferlist result_bl;
+
+ MAuthReply() : MessageInstance(CEPH_MSG_AUTH_REPLY), protocol(0), result(0), global_id(0) {}
+ MAuthReply(__u32 p, bufferlist *bl = NULL, int r = 0, uint64_t gid=0, const char *msg = "") :
+ MessageInstance(CEPH_MSG_AUTH_REPLY),
+ protocol(p), result(r), global_id(gid),
+ result_msg(msg) {
+ if (bl)
+ result_bl = *bl;
+ }
+private:
+ ~MAuthReply() override {}
+
+public:
+ std::string_view get_type_name() const override { return "auth_reply"; }
+ void print(ostream& o) const override {
+ o << "auth_reply(proto " << protocol << " " << result << " " << cpp_strerror(result);
+ if (result_msg.length())
+ o << ": " << result_msg;
+ o << ")";
+ }
+
+ void decode_payload() override {
+ auto p = payload.cbegin();
+ decode(protocol, p);
+ decode(result, p);
+ decode(global_id, p);
+ decode(result_bl, p);
+ decode(result_msg, p);
+ }
+ void encode_payload(uint64_t features) override {
+ using ceph::encode;
+ encode(protocol, payload);
+ encode(result, payload);
+ encode(global_id, payload);
+ encode(result_bl, payload);
+ encode(result_msg, payload);
+ }
+};
+
+#endif