summaryrefslogtreecommitdiffstats
path: root/src/librbd/migration/S3Stream.h
blob: 586b217878c64ced28713cd9f93224d4f98060e0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
// vim: ts=8 sw=2 smarttab

#ifndef CEPH_LIBRBD_MIGRATION_S3_STREAM_H
#define CEPH_LIBRBD_MIGRATION_S3_STREAM_H

#include "include/int_types.h"
#include "librbd/migration/StreamInterface.h"
#include <boost/beast/http/empty_body.hpp>
#include <boost/beast/http/message.hpp>
#include <boost/beast/http/string_body.hpp>
#include <json_spirit/json_spirit.h>
#include <memory>
#include <string>

struct Context;

namespace librbd {

struct AsioEngine;
struct ImageCtx;

namespace migration {

template <typename> class HttpClient;

template <typename ImageCtxT>
class S3Stream : public StreamInterface {
public:
  static S3Stream* create(ImageCtxT* image_ctx,
                            const json_spirit::mObject& json_object) {
    return new S3Stream(image_ctx, json_object);
  }

  S3Stream(ImageCtxT* image_ctx, const json_spirit::mObject& json_object);
  ~S3Stream() override;

  S3Stream(const S3Stream&) = delete;
  S3Stream& operator=(const S3Stream&) = delete;

  void open(Context* on_finish) override;
  void close(Context* on_finish) override;

  void get_size(uint64_t* size, Context* on_finish) override;

  void read(io::Extents&& byte_extents, bufferlist* data,
            Context* on_finish) override;

private:
  using HttpRequest = boost::beast::http::request<
    boost::beast::http::empty_body>;
  using HttpResponse = boost::beast::http::response<
    boost::beast::http::string_body>;

  struct HttpProcessor;

  ImageCtxT* m_image_ctx;
  CephContext* m_cct;
  std::shared_ptr<AsioEngine> m_asio_engine;
  json_spirit::mObject m_json_object;

  std::string m_url;
  std::string m_access_key;
  std::string m_secret_key;

  std::unique_ptr<HttpProcessor> m_http_processor;
  std::unique_ptr<HttpClient<ImageCtxT>> m_http_client;

  void process_request(HttpRequest& http_request);

};

} // namespace migration
} // namespace librbd

extern template class librbd::migration::S3Stream<librbd::ImageCtx>;

#endif // CEPH_LIBRBD_MIGRATION_S3_STREAM_H