1 // -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
2 // vim: ts=8 sw=2 smarttab
4 #include "librbd/mirror/GetStatusRequest.h"
5 #include "common/dout.h"
6 #include "common/errno.h"
7 #include "cls/rbd/cls_rbd_client.h"
8 #include "librbd/ImageCtx.h"
9 #include "librbd/ImageState.h"
10 #include "librbd/Journal.h"
11 #include "librbd/Utils.h"
12 #include "librbd/mirror/GetInfoRequest.h"
14 #define dout_subsys ceph_subsys_rbd
16 #define dout_prefix *_dout << "librbd::mirror::GetStatusRequest: " << this \
17 << " " << __func__ << ": "
22 using librbd::util::create_context_callback
;
23 using librbd::util::create_rados_callback
;
26 void GetStatusRequest
<I
>::send() {
27 *m_mirror_image_status
= cls::rbd::MirrorImageStatus(
28 {{cls::rbd::MirrorImageSiteStatus::LOCAL_MIRROR_UUID
,
29 cls::rbd::MIRROR_IMAGE_STATUS_STATE_UNKNOWN
, "status not found"}});
35 void GetStatusRequest
<I
>::get_info() {
36 CephContext
*cct
= m_image_ctx
.cct
;
37 ldout(cct
, 20) << dendl
;
39 auto ctx
= create_context_callback
<
40 GetStatusRequest
<I
>, &GetStatusRequest
<I
>::handle_get_info
>(this);
41 auto req
= GetInfoRequest
<I
>::create(m_image_ctx
, m_mirror_image
,
43 &m_primary_mirror_uuid
, ctx
);
48 void GetStatusRequest
<I
>::handle_get_info(int r
) {
49 CephContext
*cct
= m_image_ctx
.cct
;
50 ldout(cct
, 20) << "r=" << r
<< dendl
;
53 lderr(cct
) << "failed to retrieve mirroring state: " << cpp_strerror(r
)
57 } else if (m_mirror_image
->state
!= cls::rbd::MIRROR_IMAGE_STATE_ENABLED
) {
66 void GetStatusRequest
<I
>::get_status() {
67 CephContext
*cct
= m_image_ctx
.cct
;
68 ldout(cct
, 20) << dendl
;
70 librados::ObjectReadOperation op
;
71 cls_client::mirror_image_status_get_start(
72 &op
, m_mirror_image
->global_image_id
);
74 librados::AioCompletion
*comp
= create_rados_callback
<
75 GetStatusRequest
<I
>, &GetStatusRequest
<I
>::handle_get_status
>(this);
76 int r
= m_image_ctx
.md_ctx
.aio_operate(RBD_MIRRORING
, comp
, &op
, &m_out_bl
);
82 void GetStatusRequest
<I
>::handle_get_status(int r
) {
83 CephContext
*cct
= m_image_ctx
.cct
;
84 ldout(cct
, 20) << "r=" << r
<< dendl
;
87 auto iter
= m_out_bl
.cbegin();
88 r
= cls_client::mirror_image_status_get_finish(&iter
,
89 m_mirror_image_status
);
92 if (r
< 0 && r
!= -ENOENT
) {
93 lderr(cct
) << "failed to retrieve mirror image status: " << cpp_strerror(r
)
102 template <typename I
>
103 void GetStatusRequest
<I
>::finish(int r
) {
104 CephContext
*cct
= m_image_ctx
.cct
;
105 ldout(cct
, 20) << "r=" << r
<< dendl
;
107 m_on_finish
->complete(r
);
111 } // namespace mirror
112 } // namespace librbd
114 template class librbd::mirror::GetStatusRequest
<librbd::ImageCtx
>;