-
Notifications
You must be signed in to change notification settings - Fork 166
Expand file tree
/
Copy pathMQProducer.h
More file actions
101 lines (86 loc) · 4.39 KB
/
MQProducer.h
File metadata and controls
101 lines (86 loc) · 4.39 KB
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef ROCKETMQ_MQPRODUCER_H_
#define ROCKETMQ_MQPRODUCER_H_
#include "MQMessageQueue.h"
#include "MQSelector.h"
#include "RequestCallback.h"
#include "SendCallback.h"
#include "SendResult.h"
#include "TransactionSendResult.h"
namespace rocketmq {
/**
* MQProducer - interface for producer
*/
class ROCKETMQCLIENT_API MQProducer {
public:
virtual ~MQProducer() = default;
public: // MQProducer
virtual void start() = 0;
virtual void shutdown() = 0;
virtual std::vector<MQMessageQueue> fetchPublishMessageQueues(const std::string& topic) = 0;
// Sync
virtual SendResult send(MQMessage& msg) = 0;
virtual SendResult send(MQMessage& msg, long timeout) = 0;
virtual SendResult send(MQMessage& msg, const MQMessageQueue& mq) = 0;
virtual SendResult send(MQMessage& msg, const MQMessageQueue& mq, long timeout) = 0;
// Async
virtual void send(MQMessage& msg, SendCallback* sendCallback) noexcept = 0;
virtual void send(MQMessage& msg, SendCallback* sendCallback, long timeout) noexcept = 0;
virtual void send(MQMessage& msg, const MQMessageQueue& mq, SendCallback* sendCallback) noexcept = 0;
virtual void send(MQMessage& msg, const MQMessageQueue& mq, SendCallback* sendCallback, long timeout) noexcept = 0;
// Oneyway
virtual void sendOneway(MQMessage& msg) = 0;
virtual void sendOneway(MQMessage& msg, const MQMessageQueue& mq) = 0;
// Select
virtual SendResult send(MQMessage& msg, MessageQueueSelector* selector, void* arg) = 0;
virtual SendResult send(MQMessage& msg, MessageQueueSelector* selector, void* arg, long timeout) = 0;
virtual void send(MQMessage& msg, MessageQueueSelector* selector, void* arg, SendCallback* sendCallback) noexcept = 0;
virtual void send(MQMessage& msg,
MessageQueueSelector* selector,
void* arg,
SendCallback* sendCallback,
long timeout) noexcept = 0;
virtual void sendOneway(MQMessage& msg, MessageQueueSelector* selector, void* arg) = 0;
// Transaction
virtual TransactionSendResult sendMessageInTransaction(MQMessage& msg, void* arg) = 0;
// Batch
virtual SendResult send(std::vector<MQMessage>& msgs) = 0;
virtual SendResult send(std::vector<MQMessage>& msgs, long timeout) = 0;
virtual SendResult send(std::vector<MQMessage>& msgs, const MQMessageQueue& mq) = 0;
virtual SendResult send(std::vector<MQMessage>& msgs, const MQMessageQueue& mq, long timeout) = 0;
virtual void send(std::vector<MQMessage>& msgs, SendCallback* sendCallback) = 0;
virtual void send(std::vector<MQMessage>& msgs, SendCallback* sendCallback, long timeout) = 0;
virtual void send(std::vector<MQMessage>& msgs, const MQMessageQueue& mq, SendCallback* sendCallback) = 0;
virtual void send(std::vector<MQMessage>& msgs,
const MQMessageQueue& mq,
SendCallback* sendCallback,
long timeout) = 0;
// RPC
virtual MQMessage request(MQMessage& msg, long timeout) = 0;
virtual void request(MQMessage& msg, RequestCallback* requestCallback, long timeout) = 0;
virtual MQMessage request(MQMessage& msg, const MQMessageQueue& mq, long timeout) = 0;
virtual void request(MQMessage& msg, const MQMessageQueue& mq, RequestCallback* requestCallback, long timeout) = 0;
virtual MQMessage request(MQMessage& msg, MessageQueueSelector* selector, void* arg, long timeout) = 0;
virtual void request(MQMessage& msg,
MessageQueueSelector* selector,
void* arg,
RequestCallback* requestCallback,
long timeout) = 0;
};
} // namespace rocketmq
#endif // ROCKETMQ_MQPRODUCER_H_