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
|