Update encoding server list when servers disappear (#1176).
[dcpomatic.git] / src / lib / encode_server_description.h
1 /*
2     Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21 #ifndef DCPOMATIC_ENCODE_SERVER_DESCRIPTION_H
22 #define DCPOMATIC_ENCODE_SERVER_DESCRIPTION_H
23
24 #include <boost/date_time/posix_time/posix_time.hpp>
25
26 /** @class EncodeServerDescription
27  *  @brief Class to describe a server to which we can send encoding work.
28  */
29 class EncodeServerDescription
30 {
31 public:
32         EncodeServerDescription ()
33                 : _host_name ("")
34                 , _threads (1)
35                 , _link_version (0)
36                 , _last_seen (boost::posix_time::second_clock::local_time())
37         {}
38
39         /** @param h Server host name or IP address in string form.
40          *  @param t Number of threads to use on the server.
41          *  @param l Server link version number of the server.
42          */
43         EncodeServerDescription (std::string h, int t, int l)
44                 : _host_name (h)
45                 , _threads (t)
46                 , _link_version (l)
47                 , _last_seen (boost::posix_time::second_clock::local_time())
48         {}
49
50         /* Default copy constructor is fine */
51
52         /** @return server's host name or IP address in string form */
53         std::string host_name () const {
54                 return _host_name;
55         }
56
57         /** @return number of threads to use on the server */
58         int threads () const {
59                 return _threads;
60         }
61
62         int link_version () const {
63                 return _link_version;
64         }
65
66         void set_host_name (std::string n) {
67                 _host_name = n;
68         }
69
70         void set_threads (int t) {
71                 _threads = t;
72         }
73
74         void set_seen () {
75                 _last_seen = boost::posix_time::second_clock::local_time();
76         }
77
78         int last_seen_seconds () const {
79                 return boost::posix_time::time_duration(boost::posix_time::second_clock::local_time() - _last_seen).total_seconds();
80         }
81
82 private:
83         /** server's host name */
84         std::string _host_name;
85         /** number of threads to use on the server */
86         int _threads;
87         /** server link (i.e. protocol) version number */
88         int _link_version;
89         boost::posix_time::ptime _last_seen;
90 };
91
92 #endif