aboutsummaryrefslogtreecommitdiffstats
path: root/documentapi/src/vespa/documentapi/messagebus/replymerger.h
blob: 8398f83bb8a37bb12f4016ec1816c00b1c1a5e75 (plain) (blame)
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
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
#pragma once

#include <vespa/messagebus/reply.h>

namespace documentapi {

class ReplyMerger
{
public:
    class Result {
        friend class ReplyMerger;

        std::unique_ptr<mbus::Reply> _generatedReply;
        uint32_t _successIdx;

        Result(uint32_t successIdx, std::unique_ptr<mbus::Reply> generatedReply);
    public:
        Result(Result&& o) noexcept
            : _generatedReply(std::move(o._generatedReply)),
              _successIdx(o._successIdx)
        { }

        bool hasGeneratedReply() const;
        bool isSuccessful() const;
        std::unique_ptr<mbus::Reply> releaseGeneratedReply();
        uint32_t getSuccessfulReplyIndex() const;
    };
private:
    std::unique_ptr<mbus::Reply> _error;
    std::unique_ptr<mbus::Reply> _ignored;
    const mbus::Reply* _successReply;
    uint32_t _successIndex;

    void mergeAllReplyErrors(const mbus::Reply&);
    bool handleReplyWithOnlyIgnoredErrors(const mbus::Reply& r);
    bool shouldReturnErrorReply() const;
    std::unique_ptr<mbus::Reply> releaseGeneratedErrorReply();
    bool replyIsBetterThanCurrent(const mbus::Reply& r) const;
    void setCurrentBestReply(uint32_t idx, const mbus::Reply& r);
    void updateStateWithSuccessfulReply(uint32_t idx, const mbus::Reply& r);
    bool successfullyMergedAtLeastOneReply() const;
    static Result createEmptyReplyResult();
    static bool resourceWasFound(const mbus::Reply& r);
public:
    ReplyMerger();
    ~ReplyMerger();

    void merge(uint32_t idx, const mbus::Reply&);
    Result mergedReply();
};

} // documentapi