summaryrefslogtreecommitdiff
path: root/cpp/src/IceGrid/NodeSessionI.h
blob: 5958bd0a84efa9dc713963af6d547a027c71fd2c (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
//
// Copyright (c) ZeroC, Inc. All rights reserved.
//

#ifndef ICEGRID_NODE_SESSION_H
#define ICEGRID_NODE_SESSION_H

#include <IceGrid/Internal.h>
#include <set>

namespace IceGrid
{

class Database;
class TraceLevels;

class NodeSessionI : public NodeSession
{
public:

    static std::shared_ptr<NodeSessionI> create(const std::shared_ptr<Database>&, const std::shared_ptr<NodePrx>&,
                                                const std::shared_ptr<InternalNodeInfo>&,
                                                std::chrono::seconds, const LoadInfo&);

    void keepAlive(LoadInfo, const Ice::Current&) override;
    void setReplicaObserver(std::shared_ptr<ReplicaObserverPrx>, const Ice::Current&) override;
    int getTimeout(const Ice::Current&) const override;
    std::shared_ptr<NodeObserverPrx> getObserver(const Ice::Current&) const override;
    void loadServersAsync(std::function<void()>, std::function<void(std::exception_ptr)>,
                          const Ice::Current&) const override;
    Ice::StringSeq getServers(const Ice::Current&) const override;
    void waitForApplicationUpdateAsync(std::string, int, std::function<void()>, std::function<void(std::exception_ptr)>,
                                       const Ice::Current&) const override;
    void destroy(const Ice::Current&) override;

    std::chrono::steady_clock::time_point timestamp() const;
    void shutdown();

    const std::shared_ptr<NodePrx>& getNode() const;
    const std::shared_ptr<InternalNodeInfo>& getInfo() const;
    const LoadInfo& getLoadInfo() const;
    std::shared_ptr<NodeSessionPrx> getProxy() const;

    bool isDestroyed() const;

private:

    NodeSessionI(const std::shared_ptr<Database>&, const std::shared_ptr<NodePrx>&,
                 const std::shared_ptr<InternalNodeInfo>&, std::chrono::seconds, const LoadInfo&);

    void destroyImpl(bool);

    const std::shared_ptr<Database> _database;
    const std::shared_ptr<TraceLevels> _traceLevels;
    const std::string _name;
    const std::shared_ptr<NodePrx> _node;
    const std::shared_ptr<InternalNodeInfo> _info;
    const std::chrono::seconds _timeout;
    std::shared_ptr<NodeSessionPrx> _proxy;
    std::shared_ptr<ReplicaObserverPrx> _replicaObserver;
    std::chrono::steady_clock::time_point _timestamp;
    LoadInfo _load;
    bool _destroy;

    mutable std::mutex _mutex;
};

};

#endif