Statistics
| Branch: | Tag: | Revision:

root / lib / constants.py @ 250554a9

History | View | Annotate | Download (20.5 kB)

1 2f31098c Iustin Pop
#
2 a8083063 Iustin Pop
#
3 a8083063 Iustin Pop
4 a8083063 Iustin Pop
# Copyright (C) 2006, 2007 Google Inc.
5 a8083063 Iustin Pop
#
6 a8083063 Iustin Pop
# This program is free software; you can redistribute it and/or modify
7 a8083063 Iustin Pop
# it under the terms of the GNU General Public License as published by
8 a8083063 Iustin Pop
# the Free Software Foundation; either version 2 of the License, or
9 a8083063 Iustin Pop
# (at your option) any later version.
10 a8083063 Iustin Pop
#
11 a8083063 Iustin Pop
# This program is distributed in the hope that it will be useful, but
12 a8083063 Iustin Pop
# WITHOUT ANY WARRANTY; without even the implied warranty of
13 a8083063 Iustin Pop
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 a8083063 Iustin Pop
# General Public License for more details.
15 a8083063 Iustin Pop
#
16 a8083063 Iustin Pop
# You should have received a copy of the GNU General Public License
17 a8083063 Iustin Pop
# along with this program; if not, write to the Free Software
18 a8083063 Iustin Pop
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 a8083063 Iustin Pop
# 02110-1301, USA.
20 a8083063 Iustin Pop
21 a8083063 Iustin Pop
22 a8083063 Iustin Pop
"""Module holding different constants."""
23 a8083063 Iustin Pop
24 2ec08468 Michael Hanselmann
from ganeti import _autoconf
25 7c18ef8e Michael Hanselmann
26 a8083063 Iustin Pop
# various versions
27 f3e2e4c6 Iustin Pop
PROTOCOL_VERSION = 20
28 2ec08468 Michael Hanselmann
RELEASE_VERSION = _autoconf.PACKAGE_VERSION
29 d1a7d66f Guido Trotter
OS_API_V10 = 10
30 d1a7d66f Guido Trotter
OS_API_V15 = 15
31 d1a7d66f Guido Trotter
OS_API_VERSIONS = frozenset([OS_API_V10, OS_API_V15])
32 a8083063 Iustin Pop
EXPORT_VERSION = 0
33 bac5ffc3 Oleksiy Mishchenko
RAPI_VERSION = 2
34 a8083063 Iustin Pop
35 1b45f4e5 Michael Hanselmann
36 243cdbcc Michael Hanselmann
# Format for CONFIG_VERSION:
37 243cdbcc Michael Hanselmann
#   01 03 0123 = 01030123
38 243cdbcc Michael Hanselmann
#   ^^ ^^ ^^^^
39 243cdbcc Michael Hanselmann
#   |  |  + Configuration version/revision
40 243cdbcc Michael Hanselmann
#   |  + Minor version
41 243cdbcc Michael Hanselmann
#   + Major version
42 243cdbcc Michael Hanselmann
#
43 243cdbcc Michael Hanselmann
# It stored as an integer. Make sure not to write an octal number.
44 1b45f4e5 Michael Hanselmann
45 1b45f4e5 Michael Hanselmann
# BuildVersion and SplitVersion must be in here because we can't import other
46 1b45f4e5 Michael Hanselmann
# modules. The cfgupgrade tool must be able to read and write version numbers
47 1b45f4e5 Michael Hanselmann
# and thus requires these functions. To avoid code duplication, they're kept in
48 1b45f4e5 Michael Hanselmann
# here.
49 1b45f4e5 Michael Hanselmann
50 1b45f4e5 Michael Hanselmann
def BuildVersion(major, minor, revision):
51 1b45f4e5 Michael Hanselmann
  """Calculates int version number from major, minor and revision numbers.
52 1b45f4e5 Michael Hanselmann

53 1b45f4e5 Michael Hanselmann
  Returns: int representing version number
54 1b45f4e5 Michael Hanselmann

55 1b45f4e5 Michael Hanselmann
  """
56 1b45f4e5 Michael Hanselmann
  assert isinstance(major, int)
57 1b45f4e5 Michael Hanselmann
  assert isinstance(minor, int)
58 1b45f4e5 Michael Hanselmann
  assert isinstance(revision, int)
59 1b45f4e5 Michael Hanselmann
  return (1000000 * major +
60 1b45f4e5 Michael Hanselmann
            10000 * minor +
61 1b45f4e5 Michael Hanselmann
                1 * revision)
62 1b45f4e5 Michael Hanselmann
63 1b45f4e5 Michael Hanselmann
64 1b45f4e5 Michael Hanselmann
def SplitVersion(version):
65 1b45f4e5 Michael Hanselmann
  """Splits version number stored in an int.
66 1b45f4e5 Michael Hanselmann

67 1b45f4e5 Michael Hanselmann
  Returns: tuple; (major, minor, revision)
68 1b45f4e5 Michael Hanselmann

69 1b45f4e5 Michael Hanselmann
  """
70 1b45f4e5 Michael Hanselmann
  assert isinstance(version, int)
71 1b45f4e5 Michael Hanselmann
72 1b45f4e5 Michael Hanselmann
  (major, remainder) = divmod(version, 1000000)
73 1b45f4e5 Michael Hanselmann
  (minor, revision) = divmod(remainder, 10000)
74 1b45f4e5 Michael Hanselmann
75 1b45f4e5 Michael Hanselmann
  return (major, minor, revision)
76 1b45f4e5 Michael Hanselmann
77 1b45f4e5 Michael Hanselmann
78 243cdbcc Michael Hanselmann
CONFIG_MAJOR = int(_autoconf.VERSION_MAJOR)
79 243cdbcc Michael Hanselmann
CONFIG_MINOR = int(_autoconf.VERSION_MINOR)
80 243cdbcc Michael Hanselmann
CONFIG_REVISION = 0
81 1b45f4e5 Michael Hanselmann
CONFIG_VERSION = BuildVersion(CONFIG_MAJOR, CONFIG_MINOR, CONFIG_REVISION)
82 a8083063 Iustin Pop
83 a8083063 Iustin Pop
# file paths
84 2ec08468 Michael Hanselmann
DATA_DIR = _autoconf.LOCALSTATEDIR + "/lib/ganeti"
85 1ed70996 Iustin Pop
RUN_DIR = _autoconf.LOCALSTATEDIR + "/run"
86 75afaefc Iustin Pop
RUN_GANETI_DIR = RUN_DIR + "/ganeti"
87 42ff3343 Guido Trotter
BDEV_CACHE_DIR = RUN_GANETI_DIR + "/bdev-cache"
88 75afaefc Iustin Pop
DISK_LINKS_DIR = RUN_GANETI_DIR + "/instance-disks"
89 817a030d Guido Trotter
RUN_DIRS_MODE = 0755
90 b4442fd9 Guido Trotter
SOCKET_DIR = RUN_GANETI_DIR + "/socket"
91 5ecb7e48 Guido Trotter
SOCKET_DIR_MODE = 0700
92 75afaefc Iustin Pop
# keep RUN_GANETI_DIR first here, to make sure all get created when the node
93 75afaefc Iustin Pop
# daemon is started (this takes care of RUN_DIR being tmpfs)
94 75afaefc Iustin Pop
SUB_RUN_DIRS = [ RUN_GANETI_DIR, BDEV_CACHE_DIR, DISK_LINKS_DIR ]
95 3aecd2c7 Iustin Pop
LOCK_DIR = _autoconf.LOCALSTATEDIR + "/lock"
96 0c223ea9 Michael Hanselmann
SSCONF_LOCK_FILE = LOCK_DIR + "/ganeti-ssconf.lock"
97 a8083063 Iustin Pop
CLUSTER_CONF_FILE = DATA_DIR + "/config.data"
98 a8083063 Iustin Pop
SSL_CERT_FILE = DATA_DIR + "/server.pem"
99 61a08fa3 Michael Hanselmann
RAPI_CERT_FILE = DATA_DIR + "/rapi.pem"
100 4a34c5cf Guido Trotter
HMAC_CLUSTER_KEY = DATA_DIR + "/hmac.key"
101 5a3103e9 Michael Hanselmann
WATCHER_STATEFILE = DATA_DIR + "/watcher.data"
102 05e50653 Michael Hanselmann
WATCHER_PAUSEFILE = DATA_DIR + "/watcher.pause"
103 78f44650 Iustin Pop
INSTANCE_UPFILE = RUN_GANETI_DIR + "/instance-status"
104 82122173 Iustin Pop
SSH_KNOWN_HOSTS_FILE = DATA_DIR + "/known_hosts"
105 b5b67ef9 Michael Hanselmann
RAPI_USERS_FILE = DATA_DIR + "/rapi_users"
106 f1da30e6 Michael Hanselmann
QUEUE_DIR = DATA_DIR + "/queue"
107 f154a7a3 Michael Hanselmann
DAEMON_UTIL = _autoconf.PKGLIBDIR + "/daemon-util"
108 c8a0948f Michael Hanselmann
ETC_HOSTS = "/etc/hosts"
109 1abbbbe2 Manuel Franceschini
DEFAULT_FILE_STORAGE_DIR = _autoconf.FILE_STORAGE_DIR
110 5420ffc9 Guido Trotter
SYSCONFDIR = _autoconf.SYSCONFDIR
111 bea60381 Michael Hanselmann
TOOLSDIR = _autoconf.TOOLSDIR
112 131178b9 Luca Bigliardi
CONF_DIR = SYSCONFDIR + "/ganeti"
113 9894ece7 Michael Hanselmann
114 227647ac Guido Trotter
MASTER_SOCKET = SOCKET_DIR + "/ganeti-master"
115 a8083063 Iustin Pop
116 cd50653c Guido Trotter
NODED = "ganeti-noded"
117 18679072 Guido Trotter
CONFD = "ganeti-confd"
118 8c96d01f Guido Trotter
RAPI = "ganeti-rapi"
119 dae3fdd2 Guido Trotter
MASTERD = "ganeti-masterd"
120 cd50653c Guido Trotter
121 04ccf5e9 Guido Trotter
MULTITHREADED_DAEMONS = frozenset([MASTERD])
122 04ccf5e9 Guido Trotter
123 3b1b0cb6 Guido Trotter
DAEMONS_SSL = {
124 3b1b0cb6 Guido Trotter
  # daemon-name: (default-cert-path, default-key-path)
125 3b1b0cb6 Guido Trotter
  NODED: (SSL_CERT_FILE, SSL_CERT_FILE),
126 3b1b0cb6 Guido Trotter
  RAPI: (RAPI_CERT_FILE, RAPI_CERT_FILE),
127 3b1b0cb6 Guido Trotter
}
128 3b1b0cb6 Guido Trotter
129 cd50653c Guido Trotter
DAEMONS_PORTS = {
130 cd50653c Guido Trotter
  # daemon-name: ("proto", "default-port")
131 cd50653c Guido Trotter
  NODED: ("tcp", 1811),
132 18679072 Guido Trotter
  CONFD: ("udp", 1814),
133 8c96d01f Guido Trotter
  RAPI: ("tcp", 5080),
134 cd50653c Guido Trotter
}
135 cd50653c Guido Trotter
DEFAULT_NODED_PORT = DAEMONS_PORTS[NODED][1]
136 18679072 Guido Trotter
DEFAULT_CONFD_PORT = DAEMONS_PORTS[CONFD][1]
137 8c96d01f Guido Trotter
DEFAULT_RAPI_PORT = DAEMONS_PORTS[RAPI][1]
138 cd50653c Guido Trotter
139 a8083063 Iustin Pop
FIRST_DRBD_PORT = 11000
140 a8083063 Iustin Pop
LAST_DRBD_PORT = 14999
141 880478f8 Iustin Pop
MASTER_SCRIPT = "ganeti-master"
142 a8083063 Iustin Pop
143 9936bd63 Iustin Pop
LOG_DIR = _autoconf.LOCALSTATEDIR + "/log/ganeti/"
144 dae3fdd2 Guido Trotter
DAEMONS_LOGFILES = {
145 d73ef63f Michael Hanselmann
  # "daemon-name": "logfile"
146 d73ef63f Michael Hanselmann
  NODED: LOG_DIR + "node-daemon.log",
147 d73ef63f Michael Hanselmann
  CONFD: LOG_DIR + "conf-daemon.log",
148 d73ef63f Michael Hanselmann
  RAPI: LOG_DIR + "rapi-daemon.log",
149 d73ef63f Michael Hanselmann
  MASTERD: LOG_DIR + "master-daemon.log",
150 d73ef63f Michael Hanselmann
  }
151 9936bd63 Iustin Pop
LOG_OS_DIR = LOG_DIR + "os"
152 9936bd63 Iustin Pop
LOG_WATCHER = LOG_DIR + "watcher.log"
153 9936bd63 Iustin Pop
LOG_COMMANDS = LOG_DIR + "commands.log"
154 6abe9194 Iustin Pop
LOG_BURNIN = LOG_DIR + "burnin.log"
155 a8083063 Iustin Pop
156 7c3d51d4 Guido Trotter
OS_SEARCH_PATH = _autoconf.OS_SEARCH_PATH
157 68dccc07 Guido Trotter
EXPORT_DIR = _autoconf.EXPORT_DIR
158 a8083063 Iustin Pop
159 a8083063 Iustin Pop
EXPORT_CONF_FILE = "config.ini"
160 a8083063 Iustin Pop
161 2f2dbb4b Jun Futagawa
XEN_BOOTLOADER = _autoconf.XEN_BOOTLOADER
162 f00b46bc Michael Hanselmann
XEN_KERNEL = _autoconf.XEN_KERNEL
163 f00b46bc Michael Hanselmann
XEN_INITRD = _autoconf.XEN_INITRD
164 f00b46bc Michael Hanselmann
165 7e2c5b9e Guido Trotter
KVM_PATH = _autoconf.KVM_PATH
166 14aa53cb Guido Trotter
SOCAT_PATH = _autoconf.SOCAT_PATH
167 fe5b0c42 Michael Hanselmann
SOCAT_USE_ESCAPE = _autoconf.SOCAT_USE_ESCAPE
168 86d6bc2a Guido Trotter
SOCAT_ESCAPE_CODE = "0x1d"
169 7e2c5b9e Guido Trotter
170 973d7867 Iustin Pop
VALUE_DEFAULT = "default"
171 4c566ede Guido Trotter
VALUE_AUTO = "auto"
172 4c566ede Guido Trotter
VALUE_GENERATE = "generate"
173 973d7867 Iustin Pop
VALUE_NONE = "none"
174 1817f49b Guido Trotter
VALUE_TRUE = "true"
175 1817f49b Guido Trotter
VALUE_FALSE = "false"
176 973d7867 Iustin Pop
177 a8083063 Iustin Pop
# hooks-related constants
178 131178b9 Luca Bigliardi
HOOKS_BASE_DIR = CONF_DIR + "/hooks"
179 a8083063 Iustin Pop
HOOKS_PHASE_PRE = "pre"
180 a8083063 Iustin Pop
HOOKS_PHASE_POST = "post"
181 6a4aa7c1 Iustin Pop
HOOKS_NAME_CFGUPDATE = "config-update"
182 f3e2e4c6 Iustin Pop
HOOKS_VERSION = 2
183 a8083063 Iustin Pop
184 a8083063 Iustin Pop
# hooks subject type (what object type does the LU deal with)
185 a8083063 Iustin Pop
HTYPE_CLUSTER = "CLUSTER"
186 a8083063 Iustin Pop
HTYPE_NODE = "NODE"
187 a8083063 Iustin Pop
HTYPE_INSTANCE = "INSTANCE"
188 a8083063 Iustin Pop
189 a8083063 Iustin Pop
HKR_SKIP = 0
190 a8083063 Iustin Pop
HKR_FAIL = 1
191 a8083063 Iustin Pop
HKR_SUCCESS = 2
192 a8083063 Iustin Pop
193 ac2d0fe4 Michael Hanselmann
# Storage types
194 ac2d0fe4 Michael Hanselmann
ST_FILE = "file"
195 ac2d0fe4 Michael Hanselmann
ST_LVM_PV = "lvm-pv"
196 ac2d0fe4 Michael Hanselmann
ST_LVM_VG = "lvm-vg"
197 6032697c Michael Hanselmann
198 6032697c Michael Hanselmann
# Storage fields
199 620a85fd Iustin Pop
# first two are valid in LU context only, not passed to backend
200 620a85fd Iustin Pop
SF_NODE = "node"
201 620a85fd Iustin Pop
SF_TYPE = "type"
202 620a85fd Iustin Pop
# and the rest are valid in backend
203 6032697c Michael Hanselmann
SF_NAME = "name"
204 6032697c Michael Hanselmann
SF_SIZE = "size"
205 6032697c Michael Hanselmann
SF_FREE = "free"
206 6032697c Michael Hanselmann
SF_USED = "used"
207 6032697c Michael Hanselmann
SF_ALLOCATABLE = "allocatable"
208 6032697c Michael Hanselmann
209 6c3c6db9 Michael Hanselmann
# Storage operations
210 6c3c6db9 Michael Hanselmann
SO_FIX_CONSISTENCY = "fix-consistency"
211 6c3c6db9 Michael Hanselmann
212 6032697c Michael Hanselmann
# Available fields per storage type
213 620a85fd Iustin Pop
VALID_STORAGE_FIELDS = frozenset([SF_NAME, SF_TYPE, SF_SIZE,
214 620a85fd Iustin Pop
                                  SF_USED, SF_FREE, SF_ALLOCATABLE])
215 620a85fd Iustin Pop
216 620a85fd Iustin Pop
VALID_STORAGE_TYPES = frozenset([ST_FILE, ST_LVM_PV, ST_LVM_VG])
217 a8083063 Iustin Pop
218 efb8da02 Michael Hanselmann
MODIFIABLE_STORAGE_FIELDS = {
219 efb8da02 Michael Hanselmann
  ST_LVM_PV: frozenset([SF_ALLOCATABLE]),
220 efb8da02 Michael Hanselmann
  }
221 efb8da02 Michael Hanselmann
222 4b37cac5 Michael Hanselmann
VALID_STORAGE_OPERATIONS = {
223 6c3c6db9 Michael Hanselmann
  ST_LVM_VG: frozenset([SO_FIX_CONSISTENCY]),
224 4b37cac5 Michael Hanselmann
  }
225 4b37cac5 Michael Hanselmann
226 74f37195 Michael Hanselmann
# Local disk status
227 74f37195 Michael Hanselmann
# Note: Code depends on LDS_OKAY < LDS_UNKNOWN < LDS_FAULTY
228 74f37195 Michael Hanselmann
(LDS_OKAY,
229 74f37195 Michael Hanselmann
 LDS_UNKNOWN,
230 74f37195 Michael Hanselmann
 LDS_FAULTY) = range(1, 4)
231 74f37195 Michael Hanselmann
232 a8083063 Iustin Pop
# disk template types
233 a8083063 Iustin Pop
DT_DISKLESS = "diskless"
234 a8083063 Iustin Pop
DT_PLAIN = "plain"
235 a1f445d3 Iustin Pop
DT_DRBD8 = "drbd"
236 04fa07f2 Manuel Franceschini
DT_FILE = "file"
237 a1f445d3 Iustin Pop
238 a1f445d3 Iustin Pop
# the set of network-mirrored disk templates
239 abdf0113 Iustin Pop
DTS_NET_MIRROR = frozenset([DT_DRBD8])
240 a8083063 Iustin Pop
241 d63e148a Manuel Franceschini
# the set of non-lvm-based disk templates
242 d63e148a Manuel Franceschini
DTS_NOT_LVM = frozenset([DT_DISKLESS, DT_FILE])
243 d63e148a Manuel Franceschini
244 fe96220b Iustin Pop
# logical disk types
245 fe96220b Iustin Pop
LD_LV = "lvm"
246 a1f445d3 Iustin Pop
LD_DRBD8 = "drbd8"
247 04fa07f2 Manuel Franceschini
LD_FILE = "file"
248 464736ae Guido Trotter
LDS_BLOCK = frozenset([LD_LV, LD_DRBD8])
249 04fa07f2 Manuel Franceschini
250 2899d9de Iustin Pop
# drbd constants
251 2899d9de Iustin Pop
DRBD_HMAC_ALG = "md5"
252 3c03759a Iustin Pop
DRBD_NET_PROTOCOL = "C"
253 2899d9de Iustin Pop
254 04fa07f2 Manuel Franceschini
# file backend driver
255 04fa07f2 Manuel Franceschini
FD_LOOP = "loop"
256 04fa07f2 Manuel Franceschini
FD_BLKTAP = "blktap"
257 a1f445d3 Iustin Pop
258 a1f445d3 Iustin Pop
# the set of drbd-like disk types
259 abdf0113 Iustin Pop
LDS_DRBD = frozenset([LD_DRBD8])
260 fe96220b Iustin Pop
261 08db7c5c Iustin Pop
# disk access mode
262 24991749 Iustin Pop
DISK_RDONLY = "ro"
263 24991749 Iustin Pop
DISK_RDWR = "rw"
264 08db7c5c Iustin Pop
DISK_ACCESS_SET = frozenset([DISK_RDONLY, DISK_RDWR])
265 08db7c5c Iustin Pop
266 a9e0c397 Iustin Pop
# disk replacement mode
267 cfacfd6e Iustin Pop
REPLACE_DISK_PRI = "replace_on_primary"    # replace disks on primary
268 cfacfd6e Iustin Pop
REPLACE_DISK_SEC = "replace_on_secondary"  # replace disks on secondary
269 cfacfd6e Iustin Pop
REPLACE_DISK_CHG = "replace_new_secondary" # change secondary node
270 942be002 Michael Hanselmann
REPLACE_DISK_AUTO = "replace_auto"
271 a9e0c397 Iustin Pop
272 f6d9a522 Guido Trotter
# lock recalculate mode
273 f6d9a522 Guido Trotter
LOCKS_REPLACE = 'replace'
274 9513b6ab Guido Trotter
LOCKS_APPEND = 'append'
275 f6d9a522 Guido Trotter
276 2f6eebee Guido Trotter
# instance creation modes
277 a8083063 Iustin Pop
INSTANCE_CREATE = "create"
278 a8083063 Iustin Pop
INSTANCE_IMPORT = "import"
279 a8083063 Iustin Pop
280 a8083063 Iustin Pop
DISK_TEMPLATES = frozenset([DT_DISKLESS, DT_PLAIN,
281 04fa07f2 Manuel Franceschini
                            DT_DRBD8, DT_FILE])
282 04fa07f2 Manuel Franceschini
283 04fa07f2 Manuel Franceschini
FILE_DRIVER = frozenset([FD_LOOP, FD_BLKTAP])
284 a8083063 Iustin Pop
285 a8083063 Iustin Pop
# import/export config options
286 a8083063 Iustin Pop
INISECT_EXP = "export"
287 a8083063 Iustin Pop
INISECT_INS = "instance"
288 38242904 Iustin Pop
289 24991749 Iustin Pop
# dynamic device modification
290 24991749 Iustin Pop
291 24991749 Iustin Pop
DDM_ADD = 'add'
292 24991749 Iustin Pop
DDM_REMOVE = 'remove'
293 24991749 Iustin Pop
294 38242904 Iustin Pop
# common exit codes
295 a5bc662a Iustin Pop
EXIT_SUCCESS = 0
296 438b45d4 Michael Hanselmann
EXIT_FAILURE = 1
297 46479775 Guido Trotter
EXIT_NOTCLUSTER = 5
298 38242904 Iustin Pop
EXIT_NOTMASTER = 11
299 619fdc8e Iustin Pop
EXIT_NODESETUP_ERROR = 12
300 a5bc662a Iustin Pop
EXIT_CONFIRMATION = 13 # need user confirmation
301 3f71b464 Guido Trotter
EXIT_NOTCANDIDATE = 14
302 cf62a272 Michael Hanselmann
303 5c947f38 Iustin Pop
# tags
304 5c947f38 Iustin Pop
TAG_CLUSTER = "cluster"
305 5c947f38 Iustin Pop
TAG_NODE = "node"
306 5c947f38 Iustin Pop
TAG_INSTANCE = "instance"
307 5c947f38 Iustin Pop
MAX_TAG_LEN = 128
308 5c947f38 Iustin Pop
MAX_TAGS_PER_OBJ = 4096
309 5c947f38 Iustin Pop
310 cf62a272 Michael Hanselmann
# others
311 cf62a272 Michael Hanselmann
DEFAULT_BRIDGE = "xen-br0"
312 24b0d752 Iustin Pop
SYNC_SPEED = 60 * 1024
313 aa4260ca Iustin Pop
LOCALHOST_IP_ADDRESS = "127.0.0.1"
314 16abfbc2 Alexander Schreiber
TCP_PING_TIMEOUT = 10
315 7900ed01 Iustin Pop
GANETI_RUNAS = "root"
316 d63e148a Manuel Franceschini
DEFAULT_VG = "xenvg"
317 31a853d2 Iustin Pop
BIND_ADDRESS_GLOBAL = "0.0.0.0"
318 8d1a2a64 Michael Hanselmann
MIN_VG_SIZE = 20480
319 c5e489f7 Iustin Pop
DEFAULT_MAC_PREFIX = "aa:00:00"
320 3736cb6b Iustin Pop
LVM_STRIPECOUNT = _autoconf.LVM_STRIPECOUNT
321 88cd08aa Guido Trotter
# default maximum instance wait time, in seconds.
322 88cd08aa Guido Trotter
DEFAULT_SHUTDOWN_TIMEOUT = 120
323 313b2dd4 Michael Hanselmann
NODE_MAX_CLOCK_SKEW = 150
324 7900ed01 Iustin Pop
325 12bce260 Michael Hanselmann
# RPC constants
326 12bce260 Michael Hanselmann
(RPC_ENCODING_NONE,
327 12bce260 Michael Hanselmann
 RPC_ENCODING_ZLIB_BASE64) = range(2)
328 12bce260 Michael Hanselmann
329 ded1c679 Guido Trotter
# os related constants
330 ded1c679 Guido Trotter
OS_SCRIPT_CREATE = 'create'
331 ded1c679 Guido Trotter
OS_SCRIPT_IMPORT = 'import'
332 ded1c679 Guido Trotter
OS_SCRIPT_EXPORT = 'export'
333 ded1c679 Guido Trotter
OS_SCRIPT_RENAME = 'rename'
334 16653425 Iustin Pop
OS_SCRIPTS = frozenset([OS_SCRIPT_CREATE, OS_SCRIPT_IMPORT,
335 ded1c679 Guido Trotter
                        OS_SCRIPT_EXPORT, OS_SCRIPT_RENAME])
336 37482e7b Guido Trotter
337 b6b45e0d Guido Trotter
OS_API_FILE = 'ganeti_api_version'
338 6d79896b Guido Trotter
OS_VARIANTS_FILE = 'variants.list'
339 b6b45e0d Guido Trotter
340 70d9e3d8 Iustin Pop
# ssh constants
341 70d9e3d8 Iustin Pop
SSH_CONFIG_DIR = "/etc/ssh/"
342 70d9e3d8 Iustin Pop
SSH_HOST_DSA_PRIV = SSH_CONFIG_DIR + "ssh_host_dsa_key"
343 70d9e3d8 Iustin Pop
SSH_HOST_DSA_PUB = SSH_HOST_DSA_PRIV + ".pub"
344 70d9e3d8 Iustin Pop
SSH_HOST_RSA_PRIV = SSH_CONFIG_DIR + "ssh_host_rsa_key"
345 70d9e3d8 Iustin Pop
SSH_HOST_RSA_PUB = SSH_HOST_RSA_PRIV + ".pub"
346 fff33d70 Michael Hanselmann
SSH = "ssh"
347 fff33d70 Michael Hanselmann
SCP = "scp"
348 007a2f3e Alexander Schreiber
349 007a2f3e Alexander Schreiber
# reboot types
350 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_SOFT = "soft"
351 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_HARD = "hard"
352 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_FULL = "full"
353 2584d4a4 Alexander Schreiber
354 00f91f29 Iustin Pop
REBOOT_TYPES = frozenset([INSTANCE_REBOOT_SOFT,
355 00f91f29 Iustin Pop
                          INSTANCE_REBOOT_HARD,
356 00f91f29 Iustin Pop
                          INSTANCE_REBOOT_FULL])
357 00f91f29 Iustin Pop
358 a5728081 Guido Trotter
VTYPE_STRING = 'string'
359 a5728081 Guido Trotter
VTYPE_BOOL = 'bool'
360 a5728081 Guido Trotter
VTYPE_SIZE = 'size' # size, in MiBs
361 a5728081 Guido Trotter
VTYPE_INT = 'int'
362 a5728081 Guido Trotter
ENFORCEABLE_TYPES = frozenset([
363 a5728081 Guido Trotter
                      VTYPE_STRING,
364 a5728081 Guido Trotter
                      VTYPE_BOOL,
365 a5728081 Guido Trotter
                      VTYPE_SIZE,
366 a5728081 Guido Trotter
                      VTYPE_INT,
367 a5728081 Guido Trotter
                      ])
368 a5728081 Guido Trotter
369 e64b8beb Iustin Pop
# HV parameter names (global namespace)
370 e64b8beb Iustin Pop
HV_BOOT_ORDER = "boot_order"
371 e64b8beb Iustin Pop
HV_CDROM_IMAGE_PATH = "cdrom_image_path"
372 e64b8beb Iustin Pop
HV_NIC_TYPE = "nic_type"
373 e64b8beb Iustin Pop
HV_DISK_TYPE = "disk_type"
374 e64b8beb Iustin Pop
HV_VNC_BIND_ADDRESS = "vnc_bind_address"
375 6e6bb8d5 Guido Trotter
HV_VNC_PASSWORD_FILE = "vnc_password_file"
376 8b2d1013 Guido Trotter
HV_VNC_TLS = "vnc_tls"
377 8b2d1013 Guido Trotter
HV_VNC_X509 = "vnc_x509_path"
378 8b2d1013 Guido Trotter
HV_VNC_X509_VERIFY = "vnc_x509_verify"
379 e64b8beb Iustin Pop
HV_ACPI = "acpi"
380 e64b8beb Iustin Pop
HV_PAE = "pae"
381 2f2dbb4b Jun Futagawa
HV_USE_BOOTLOADER = "use_bootloader"
382 2f2dbb4b Jun Futagawa
HV_BOOTLOADER_ARGS = "bootloader_args"
383 2f2dbb4b Jun Futagawa
HV_BOOTLOADER_PATH = "bootloader_path"
384 f9d6542d Iustin Pop
HV_KERNEL_ARGS = "kernel_args"
385 e64b8beb Iustin Pop
HV_KERNEL_PATH = "kernel_path"
386 e64b8beb Iustin Pop
HV_INITRD_PATH = "initrd_path"
387 074ca009 Guido Trotter
HV_ROOT_PATH = "root_path"
388 a2faf9ee Guido Trotter
HV_SERIAL_CONSOLE = "serial_console"
389 11344a50 Guido Trotter
HV_USB_MOUSE = "usb_mouse"
390 09ea8710 Iustin Pop
HV_DEVICE_MODEL = "device_model"
391 48297fa2 Iustin Pop
HV_INIT_SCRIPT = "init_script"
392 78411c60 Iustin Pop
HV_MIGRATION_PORT = "migration_port"
393 6b970cef Jun Futagawa
HV_USE_LOCALTIME = "use_localtime"
394 e64b8beb Iustin Pop
395 a5728081 Guido Trotter
HVS_PARAMETER_TYPES = {
396 a5728081 Guido Trotter
  HV_BOOT_ORDER: VTYPE_STRING,
397 a5728081 Guido Trotter
  HV_CDROM_IMAGE_PATH: VTYPE_STRING,
398 a5728081 Guido Trotter
  HV_NIC_TYPE: VTYPE_STRING,
399 a5728081 Guido Trotter
  HV_DISK_TYPE: VTYPE_STRING,
400 6e6bb8d5 Guido Trotter
  HV_VNC_PASSWORD_FILE: VTYPE_STRING,
401 a5728081 Guido Trotter
  HV_VNC_BIND_ADDRESS: VTYPE_STRING,
402 a5728081 Guido Trotter
  HV_VNC_TLS: VTYPE_BOOL,
403 a5728081 Guido Trotter
  HV_VNC_X509: VTYPE_STRING,
404 a5728081 Guido Trotter
  HV_VNC_X509_VERIFY: VTYPE_BOOL,
405 a5728081 Guido Trotter
  HV_ACPI: VTYPE_BOOL,
406 a5728081 Guido Trotter
  HV_PAE: VTYPE_BOOL,
407 2f2dbb4b Jun Futagawa
  HV_USE_BOOTLOADER: VTYPE_BOOL,
408 2f2dbb4b Jun Futagawa
  HV_BOOTLOADER_PATH: VTYPE_STRING,
409 2f2dbb4b Jun Futagawa
  HV_BOOTLOADER_ARGS: VTYPE_STRING,
410 a5728081 Guido Trotter
  HV_KERNEL_PATH: VTYPE_STRING,
411 f9d6542d Iustin Pop
  HV_KERNEL_ARGS: VTYPE_STRING,
412 a5728081 Guido Trotter
  HV_INITRD_PATH: VTYPE_STRING,
413 a5728081 Guido Trotter
  HV_ROOT_PATH: VTYPE_STRING,
414 a5728081 Guido Trotter
  HV_SERIAL_CONSOLE: VTYPE_BOOL,
415 a5728081 Guido Trotter
  HV_USB_MOUSE: VTYPE_STRING,
416 09ea8710 Iustin Pop
  HV_DEVICE_MODEL: VTYPE_STRING,
417 48297fa2 Iustin Pop
  HV_INIT_SCRIPT: VTYPE_STRING,
418 78411c60 Iustin Pop
  HV_MIGRATION_PORT: VTYPE_INT,
419 6b970cef Jun Futagawa
  HV_USE_LOCALTIME: VTYPE_BOOL,
420 a5728081 Guido Trotter
  }
421 a5728081 Guido Trotter
422 a5728081 Guido Trotter
HVS_PARAMETERS = frozenset(HVS_PARAMETER_TYPES.keys())
423 5018a335 Iustin Pop
424 e64b8beb Iustin Pop
# BE parameter names
425 cd3ab26e Iustin Pop
BE_MEMORY = "memory"
426 e64b8beb Iustin Pop
BE_VCPUS = "vcpus"
427 c0f2b229 Iustin Pop
BE_AUTO_BALANCE = "auto_balance"
428 e64b8beb Iustin Pop
429 a5728081 Guido Trotter
BES_PARAMETER_TYPES = {
430 a5728081 Guido Trotter
    BE_MEMORY: VTYPE_SIZE,
431 a5728081 Guido Trotter
    BE_VCPUS: VTYPE_INT,
432 a5728081 Guido Trotter
    BE_AUTO_BALANCE: VTYPE_BOOL,
433 a5728081 Guido Trotter
    }
434 a5728081 Guido Trotter
435 a5728081 Guido Trotter
BES_PARAMETERS = frozenset(BES_PARAMETER_TYPES.keys())
436 cd3ab26e Iustin Pop
437 4ef7f423 Guido Trotter
# Instance Parameters Profile
438 4ef7f423 Guido Trotter
PP_DEFAULT = "default"
439 e64b8beb Iustin Pop
440 ac061be9 Guido Trotter
NIC_MODE = "mode"
441 ac061be9 Guido Trotter
NIC_LINK = "link"
442 ac061be9 Guido Trotter
443 ac061be9 Guido Trotter
NIC_MODE_BRIDGED = "bridged"
444 ac061be9 Guido Trotter
NIC_MODE_ROUTED = "routed"
445 ac061be9 Guido Trotter
446 ac061be9 Guido Trotter
NIC_VALID_MODES = frozenset([NIC_MODE_BRIDGED, NIC_MODE_ROUTED])
447 ac061be9 Guido Trotter
448 ac061be9 Guido Trotter
NICS_PARAMETER_TYPES = {
449 ac061be9 Guido Trotter
    NIC_MODE: VTYPE_STRING,
450 ac061be9 Guido Trotter
    NIC_LINK: VTYPE_STRING,
451 ac061be9 Guido Trotter
    }
452 ac061be9 Guido Trotter
453 ac061be9 Guido Trotter
NICS_PARAMETERS = frozenset(NICS_PARAMETER_TYPES.keys())
454 e64b8beb Iustin Pop
455 2584d4a4 Alexander Schreiber
# Hypervisor constants
456 00cd937c Iustin Pop
HT_XEN_PVM = "xen-pvm"
457 2584d4a4 Alexander Schreiber
HT_FAKE = "fake"
458 00cd937c Iustin Pop
HT_XEN_HVM = "xen-hvm"
459 550e49b9 Guido Trotter
HT_KVM = "kvm"
460 48297fa2 Iustin Pop
HT_CHROOT = "chroot"
461 48297fa2 Iustin Pop
HYPER_TYPES = frozenset([HT_XEN_PVM, HT_FAKE, HT_XEN_HVM, HT_KVM, HT_CHROOT])
462 fd4daa3a Guido Trotter
HTS_REQ_PORT = frozenset([HT_XEN_HVM, HT_KVM])
463 2584d4a4 Alexander Schreiber
464 377d74c9 Guido Trotter
VNC_BASE_PORT = 5900
465 131178b9 Luca Bigliardi
VNC_PASSWORD_FILE = CONF_DIR + "/vnc-cluster-password"
466 31a853d2 Iustin Pop
VNC_DEFAULT_BIND_ADDRESS = '0.0.0.0'
467 e54c4c5e Guido Trotter
468 835528af Iustin Pop
# NIC types
469 d08f6067 Guido Trotter
HT_NIC_RTL8139 = "rtl8139"
470 d08f6067 Guido Trotter
HT_NIC_NE2K_PCI = "ne2k_pci"
471 d08f6067 Guido Trotter
HT_NIC_NE2K_ISA = "ne2k_isa"
472 43440815 Guido Trotter
HT_NIC_I82551 = "i82551"
473 43440815 Guido Trotter
HT_NIC_I85557B = "i82557b"
474 43440815 Guido Trotter
HT_NIC_I8259ER = "i82559er"
475 43440815 Guido Trotter
HT_NIC_PCNET = "pcnet"
476 43440815 Guido Trotter
HT_NIC_E1000 = "e1000"
477 d08f6067 Guido Trotter
HT_NIC_PARAVIRTUAL = HT_DISK_PARAVIRTUAL = "paravirtual"
478 43440815 Guido Trotter
479 d08f6067 Guido Trotter
HT_HVM_VALID_NIC_TYPES = frozenset([HT_NIC_RTL8139, HT_NIC_NE2K_PCI,
480 d08f6067 Guido Trotter
                                    HT_NIC_NE2K_ISA, HT_NIC_PARAVIRTUAL])
481 43440815 Guido Trotter
HT_KVM_VALID_NIC_TYPES = frozenset([HT_NIC_RTL8139, HT_NIC_NE2K_PCI,
482 43440815 Guido Trotter
                                    HT_NIC_NE2K_ISA, HT_NIC_I82551,
483 43440815 Guido Trotter
                                    HT_NIC_I85557B, HT_NIC_I8259ER,
484 43440815 Guido Trotter
                                    HT_NIC_PCNET, HT_NIC_E1000,
485 43440815 Guido Trotter
                                    HT_NIC_PARAVIRTUAL])
486 835528af Iustin Pop
# Disk types
487 835528af Iustin Pop
HT_DISK_IOEMU = "ioemu"
488 835528af Iustin Pop
HT_DISK_IDE = "ide"
489 835528af Iustin Pop
HT_DISK_SCSI = "scsi"
490 835528af Iustin Pop
HT_DISK_SD = "sd"
491 835528af Iustin Pop
HT_DISK_MTD = "mtd"
492 835528af Iustin Pop
HT_DISK_PFLASH = "pflash"
493 835528af Iustin Pop
494 835528af Iustin Pop
HT_HVM_VALID_DISK_TYPES = frozenset([HT_DISK_PARAVIRTUAL, HT_DISK_IOEMU])
495 43440815 Guido Trotter
HT_KVM_VALID_DISK_TYPES = frozenset([HT_DISK_PARAVIRTUAL, HT_DISK_IDE,
496 43440815 Guido Trotter
                                     HT_DISK_SCSI, HT_DISK_SD, HT_DISK_MTD,
497 43440815 Guido Trotter
                                     HT_DISK_PFLASH])
498 b894f5a8 Alexander Schreiber
499 835528af Iustin Pop
# Mouse types:
500 835528af Iustin Pop
HT_MOUSE_MOUSE = "mouse"
501 835528af Iustin Pop
HT_MOUSE_TABLET = "tablet"
502 835528af Iustin Pop
503 835528af Iustin Pop
HT_KVM_VALID_MOUSE_TYPES = frozenset([HT_MOUSE_MOUSE, HT_MOUSE_TABLET])
504 835528af Iustin Pop
505 835528af Iustin Pop
# Boot order
506 835528af Iustin Pop
HT_BO_CDROM = "cdrom"
507 835528af Iustin Pop
HT_BO_DISK = "disk"
508 835528af Iustin Pop
HT_BO_NETWORK = "network"
509 835528af Iustin Pop
510 835528af Iustin Pop
HT_KVM_VALID_BO_TYPES = frozenset([HT_BO_CDROM, HT_BO_DISK, HT_BO_NETWORK])
511 835528af Iustin Pop
512 e54c4c5e Guido Trotter
# Cluster Verify steps
513 e54c4c5e Guido Trotter
VERIFY_NPLUSONE_MEM = 'nplusone_mem'
514 e54c4c5e Guido Trotter
VERIFY_OPTIONAL_CHECKS = frozenset([VERIFY_NPLUSONE_MEM])
515 e54c4c5e Guido Trotter
516 25361b9a Iustin Pop
# Node verify constants
517 25361b9a Iustin Pop
NV_FILELIST = "filelist"
518 25361b9a Iustin Pop
NV_HVINFO = "hvinfo"
519 25361b9a Iustin Pop
NV_HYPERVISOR = "hypervisor"
520 25361b9a Iustin Pop
NV_INSTANCELIST = "instancelist"
521 25361b9a Iustin Pop
NV_NODELIST = "nodelist"
522 25361b9a Iustin Pop
NV_NODENETTEST = "node-net-test"
523 25361b9a Iustin Pop
NV_VERSION = "version"
524 25361b9a Iustin Pop
NV_VGLIST = "vglist"
525 d091393e Iustin Pop
NV_LVLIST = "lvlist"
526 d091393e Iustin Pop
NV_PVLIST = "pvlist"
527 6d2e83d5 Iustin Pop
NV_DRBDLIST = "drbd-list"
528 7c0aa8e9 Iustin Pop
NV_NODESETUP = "nodesetup"
529 313b2dd4 Michael Hanselmann
NV_TIME = "time"
530 25361b9a Iustin Pop
531 d61df03e Iustin Pop
# Allocator framework constants
532 77031881 Iustin Pop
IALLOCATOR_VERSION = 2
533 298fe380 Iustin Pop
IALLOCATOR_DIR_IN = "in"
534 298fe380 Iustin Pop
IALLOCATOR_DIR_OUT = "out"
535 298fe380 Iustin Pop
IALLOCATOR_MODE_ALLOC = "allocate"
536 298fe380 Iustin Pop
IALLOCATOR_MODE_RELOC = "relocate"
537 298fe380 Iustin Pop
IALLOCATOR_SEARCH_PATH = _autoconf.IALLOCATOR_SEARCH_PATH
538 5f33b613 Michael Hanselmann
539 f1da30e6 Michael Hanselmann
# Job queue
540 f1da30e6 Michael Hanselmann
JOB_QUEUE_VERSION = 1
541 f1da30e6 Michael Hanselmann
JOB_QUEUE_LOCK_FILE = QUEUE_DIR + "/lock"
542 f1da30e6 Michael Hanselmann
JOB_QUEUE_VERSION_FILE = QUEUE_DIR + "/version"
543 f1da30e6 Michael Hanselmann
JOB_QUEUE_SERIAL_FILE = QUEUE_DIR + "/serial"
544 0cb94105 Michael Hanselmann
JOB_QUEUE_ARCHIVE_DIR = QUEUE_DIR + "/archive"
545 686d7433 Iustin Pop
JOB_QUEUE_DRAIN_FILE = QUEUE_DIR + "/drain"
546 f87b405e Michael Hanselmann
JOB_QUEUE_SIZE_HARD_LIMIT = 5000
547 f87b405e Michael Hanselmann
JOB_QUEUE_SIZE_SOFT_LIMIT = JOB_QUEUE_SIZE_HARD_LIMIT * 0.8
548 f1da30e6 Michael Hanselmann
549 bac5ffc3 Oleksiy Mishchenko
JOB_ID_TEMPLATE = r"\d+"
550 bac5ffc3 Oleksiy Mishchenko
551 5c735209 Iustin Pop
# unchanged job return
552 5c735209 Iustin Pop
JOB_NOTCHANGED = "nochange"
553 5c735209 Iustin Pop
554 5f33b613 Michael Hanselmann
# Job status
555 5f33b613 Michael Hanselmann
JOB_STATUS_QUEUED = "queued"
556 e92376d7 Iustin Pop
JOB_STATUS_WAITLOCK = "waiting"
557 fbf0262f Michael Hanselmann
JOB_STATUS_CANCELING = "canceling"
558 5f33b613 Michael Hanselmann
JOB_STATUS_RUNNING = "running"
559 5f33b613 Michael Hanselmann
JOB_STATUS_CANCELED = "canceled"
560 5f33b613 Michael Hanselmann
JOB_STATUS_SUCCESS = "success"
561 5f33b613 Michael Hanselmann
JOB_STATUS_ERROR = "error"
562 5f33b613 Michael Hanselmann
563 34327f51 Iustin Pop
# OpCode status
564 34327f51 Iustin Pop
# not yet finalized
565 5f33b613 Michael Hanselmann
OP_STATUS_QUEUED = "queued"
566 e92376d7 Iustin Pop
OP_STATUS_WAITLOCK = "waiting"
567 fbf0262f Michael Hanselmann
OP_STATUS_CANCELING = "canceling"
568 5f33b613 Michael Hanselmann
OP_STATUS_RUNNING = "running"
569 34327f51 Iustin Pop
# finalized
570 4cb1d919 Michael Hanselmann
OP_STATUS_CANCELED = "canceled"
571 5f33b613 Michael Hanselmann
OP_STATUS_SUCCESS = "success"
572 5f33b613 Michael Hanselmann
OP_STATUS_ERROR = "error"
573 34327f51 Iustin Pop
OPS_FINALIZED = frozenset([OP_STATUS_CANCELED,
574 34327f51 Iustin Pop
                           OP_STATUS_SUCCESS,
575 34327f51 Iustin Pop
                           OP_STATUS_ERROR])
576 f1048938 Iustin Pop
577 f1048938 Iustin Pop
# Execution log types
578 f1048938 Iustin Pop
ELOG_MESSAGE = "message"
579 f1048938 Iustin Pop
ELOG_PROGRESS = "progress"
580 d4104181 Iustin Pop
581 c5e489f7 Iustin Pop
# max dynamic devices
582 24991749 Iustin Pop
MAX_NICS = 8
583 24991749 Iustin Pop
MAX_DISKS = 16
584 24991749 Iustin Pop
585 93384844 Iustin Pop
# SSCONF keys
586 93384844 Iustin Pop
SS_CLUSTER_NAME = "cluster_name"
587 5d60b3bd Iustin Pop
SS_CLUSTER_TAGS = "cluster_tags"
588 93384844 Iustin Pop
SS_FILE_STORAGE_DIR = "file_storage_dir"
589 f56618e0 Iustin Pop
SS_MASTER_CANDIDATES = "master_candidates"
590 8113a52e Luca Bigliardi
SS_MASTER_CANDIDATES_IPS = "master_candidates_ips"
591 93384844 Iustin Pop
SS_MASTER_IP = "master_ip"
592 93384844 Iustin Pop
SS_MASTER_NETDEV = "master_netdev"
593 93384844 Iustin Pop
SS_MASTER_NODE = "master_node"
594 93384844 Iustin Pop
SS_NODE_LIST = "node_list"
595 f9780ccd Luca Bigliardi
SS_NODE_PRIMARY_IPS = "node_primary_ips"
596 f9780ccd Luca Bigliardi
SS_NODE_SECONDARY_IPS = "node_secondary_ips"
597 a3316e4a Iustin Pop
SS_OFFLINE_NODES = "offline_nodes"
598 81a49123 Iustin Pop
SS_ONLINE_NODES = "online_nodes"
599 81a49123 Iustin Pop
SS_INSTANCE_LIST = "instance_list"
600 8a113c7a Iustin Pop
SS_RELEASE_VERSION = "release_version"
601 93384844 Iustin Pop
602 7888a614 Alexander Schreiber
# cluster wide default parameters
603 7888a614 Alexander Schreiber
DEFAULT_ENABLED_HYPERVISOR = HT_XEN_PVM
604 7888a614 Alexander Schreiber
605 7888a614 Alexander Schreiber
HVC_DEFAULTS = {
606 bd0ff7c2 Iustin Pop
  HT_XEN_PVM: {
607 2f2dbb4b Jun Futagawa
    HV_USE_BOOTLOADER: False,
608 2f2dbb4b Jun Futagawa
    HV_BOOTLOADER_PATH: XEN_BOOTLOADER,
609 2f2dbb4b Jun Futagawa
    HV_BOOTLOADER_ARGS: '',
610 bd0ff7c2 Iustin Pop
    HV_KERNEL_PATH: "/boot/vmlinuz-2.6-xenU",
611 a5728081 Guido Trotter
    HV_INITRD_PATH: '',
612 1cd8141c Guido Trotter
    HV_ROOT_PATH: '/dev/sda1',
613 f9d6542d Iustin Pop
    HV_KERNEL_ARGS: 'ro',
614 78411c60 Iustin Pop
    HV_MIGRATION_PORT: 8002,
615 bd0ff7c2 Iustin Pop
    },
616 bd0ff7c2 Iustin Pop
  HT_XEN_HVM: {
617 bd0ff7c2 Iustin Pop
    HV_BOOT_ORDER: "cd",
618 a5728081 Guido Trotter
    HV_CDROM_IMAGE_PATH: '',
619 d08f6067 Guido Trotter
    HV_NIC_TYPE: HT_NIC_RTL8139,
620 43440815 Guido Trotter
    HV_DISK_TYPE: HT_DISK_PARAVIRTUAL,
621 bd0ff7c2 Iustin Pop
    HV_VNC_BIND_ADDRESS: '0.0.0.0',
622 6e6bb8d5 Guido Trotter
    HV_VNC_PASSWORD_FILE: VNC_PASSWORD_FILE,
623 bd0ff7c2 Iustin Pop
    HV_ACPI: True,
624 bd0ff7c2 Iustin Pop
    HV_PAE: True,
625 e2ee1cea Iustin Pop
    HV_KERNEL_PATH: "/usr/lib/xen/boot/hvmloader",
626 09ea8710 Iustin Pop
    HV_DEVICE_MODEL: "/usr/lib/xen/bin/qemu-dm",
627 78411c60 Iustin Pop
    HV_MIGRATION_PORT: 8002,
628 6b970cef Jun Futagawa
    HV_USE_LOCALTIME: False,
629 bd0ff7c2 Iustin Pop
    },
630 bd0ff7c2 Iustin Pop
  HT_KVM: {
631 bd0ff7c2 Iustin Pop
    HV_KERNEL_PATH: "/boot/vmlinuz-2.6-kvmU",
632 a5728081 Guido Trotter
    HV_INITRD_PATH: '',
633 f9d6542d Iustin Pop
    HV_KERNEL_ARGS: 'ro',
634 1cd8141c Guido Trotter
    HV_ROOT_PATH: '/dev/vda1',
635 bd0ff7c2 Iustin Pop
    HV_ACPI: True,
636 bd0ff7c2 Iustin Pop
    HV_SERIAL_CONSOLE: True,
637 a5728081 Guido Trotter
    HV_VNC_BIND_ADDRESS: '',
638 8b2d1013 Guido Trotter
    HV_VNC_TLS: False,
639 8b2d1013 Guido Trotter
    HV_VNC_X509: '',
640 8b2d1013 Guido Trotter
    HV_VNC_X509_VERIFY: False,
641 6e6bb8d5 Guido Trotter
    HV_VNC_PASSWORD_FILE: '',
642 a5728081 Guido Trotter
    HV_CDROM_IMAGE_PATH: '',
643 835528af Iustin Pop
    HV_BOOT_ORDER: HT_BO_DISK,
644 43440815 Guido Trotter
    HV_NIC_TYPE: HT_NIC_PARAVIRTUAL,
645 43440815 Guido Trotter
    HV_DISK_TYPE: HT_DISK_PARAVIRTUAL,
646 a5728081 Guido Trotter
    HV_USB_MOUSE: '',
647 3c075436 Iustin Pop
    HV_MIGRATION_PORT: 8102,
648 6b970cef Jun Futagawa
    HV_USE_LOCALTIME: False,
649 bd0ff7c2 Iustin Pop
    },
650 bd0ff7c2 Iustin Pop
  HT_FAKE: {
651 bd0ff7c2 Iustin Pop
    },
652 48297fa2 Iustin Pop
  HT_CHROOT: {
653 48297fa2 Iustin Pop
    HV_INIT_SCRIPT: "/ganeti-chroot",
654 48297fa2 Iustin Pop
    },
655 bd0ff7c2 Iustin Pop
  }
656 7888a614 Alexander Schreiber
657 7736a5f2 Iustin Pop
HVC_GLOBALS = frozenset([
658 7736a5f2 Iustin Pop
  HV_MIGRATION_PORT,
659 7736a5f2 Iustin Pop
  ])
660 7736a5f2 Iustin Pop
661 7888a614 Alexander Schreiber
BEC_DEFAULTS = {
662 bd0ff7c2 Iustin Pop
  BE_MEMORY: 128,
663 bd0ff7c2 Iustin Pop
  BE_VCPUS: 1,
664 bd0ff7c2 Iustin Pop
  BE_AUTO_BALANCE: True,
665 bd0ff7c2 Iustin Pop
  }
666 c3e618cc Guido Trotter
667 ac061be9 Guido Trotter
NICC_DEFAULTS = {
668 ac061be9 Guido Trotter
  NIC_MODE: NIC_MODE_BRIDGED,
669 ac061be9 Guido Trotter
  NIC_LINK: DEFAULT_BRIDGE,
670 ac061be9 Guido Trotter
  }
671 ac061be9 Guido Trotter
672 c3e618cc Guido Trotter
MASTER_POOL_SIZE_DEFAULT = 10
673 ea1518af Guido Trotter
674 ea1518af Guido Trotter
CONFD_PROTOCOL_VERSION = 1
675 ea1518af Guido Trotter
676 09444532 Guido Trotter
CONFD_REQ_PING = 0
677 ea1518af Guido Trotter
CONFD_REQ_NODE_ROLE_BYNAME = 1
678 ea1518af Guido Trotter
CONFD_REQ_NODE_PIP_BY_INSTANCE_IP = 2
679 48166551 Guido Trotter
CONFD_REQ_CLUSTER_MASTER = 3
680 efbb4fd2 Luca Bigliardi
CONFD_REQ_NODE_PIP_LIST = 4
681 efbb4fd2 Luca Bigliardi
CONFD_REQ_MC_PIP_LIST = 5
682 d01ae714 Luca Bigliardi
CONFD_REQ_INSTANCES_IPS_LIST = 6
683 ea1518af Guido Trotter
684 19351457 Guido Trotter
# Confd request query fields. These are used to narrow down queries.
685 19351457 Guido Trotter
# These must be strings rather than integers, because json-encoding
686 19351457 Guido Trotter
# converts them to strings anyway, as they're used as dict-keys.
687 19351457 Guido Trotter
CONFD_REQQ_LINK = "0"
688 19351457 Guido Trotter
CONFD_REQQ_IP = "1"
689 19351457 Guido Trotter
CONFD_REQQ_IPLIST = "2"
690 250554a9 Guido Trotter
CONFD_REQQ_FIELDS = "3"
691 250554a9 Guido Trotter
692 250554a9 Guido Trotter
CONFD_REQFIELD_NAME = "0"
693 250554a9 Guido Trotter
CONFD_REQFIELD_IP = "1"
694 19351457 Guido Trotter
695 ea1518af Guido Trotter
CONFD_REQS = frozenset([
696 09444532 Guido Trotter
  CONFD_REQ_PING,
697 ea1518af Guido Trotter
  CONFD_REQ_NODE_ROLE_BYNAME,
698 ea1518af Guido Trotter
  CONFD_REQ_NODE_PIP_BY_INSTANCE_IP,
699 48166551 Guido Trotter
  CONFD_REQ_CLUSTER_MASTER,
700 efbb4fd2 Luca Bigliardi
  CONFD_REQ_NODE_PIP_LIST,
701 efbb4fd2 Luca Bigliardi
  CONFD_REQ_MC_PIP_LIST,
702 d01ae714 Luca Bigliardi
  CONFD_REQ_INSTANCES_IPS_LIST,
703 ea1518af Guido Trotter
  ])
704 ea1518af Guido Trotter
705 31c2a99e Guido Trotter
CONFD_REPL_STATUS_OK = 0
706 31c2a99e Guido Trotter
CONFD_REPL_STATUS_ERROR = 1
707 31c2a99e Guido Trotter
CONFD_REPL_STATUS_NOTIMPLEMENTED = 2
708 31c2a99e Guido Trotter
709 31c2a99e Guido Trotter
CONFD_REPL_STATUSES = frozenset([
710 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_OK,
711 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_ERROR,
712 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_NOTIMPLEMENTED,
713 31c2a99e Guido Trotter
  ])
714 31c2a99e Guido Trotter
715 89c52785 Guido Trotter
(CONFD_NODE_ROLE_MASTER,
716 89c52785 Guido Trotter
 CONFD_NODE_ROLE_CANDIDATE,
717 89c52785 Guido Trotter
 CONFD_NODE_ROLE_OFFLINE,
718 197b0f5d Guido Trotter
 CONFD_NODE_ROLE_DRAINED,
719 197b0f5d Guido Trotter
 CONFD_NODE_ROLE_REGULAR,
720 197b0f5d Guido Trotter
 ) = range(5)
721 89c52785 Guido Trotter
722 ca2a5b13 Guido Trotter
# A few common errors for confd
723 ca2a5b13 Guido Trotter
CONFD_ERROR_UNKNOWN_ENTRY = 1
724 7189e790 Guido Trotter
CONFD_ERROR_INTERNAL = 2
725 19351457 Guido Trotter
CONFD_ERROR_ARGUMENT = 3
726 ca2a5b13 Guido Trotter
727 71f27d19 Guido Trotter
# Each request is "salted" by the current timestamp.
728 71f27d19 Guido Trotter
# This constants decides how many seconds of skew to accept.
729 71f27d19 Guido Trotter
# TODO: make this a default and allow the value to be more configurable
730 313b2dd4 Michael Hanselmann
CONFD_MAX_CLOCK_SKEW = 2 * NODE_MAX_CLOCK_SKEW
731 84c3ab28 Guido Trotter
732 84c3ab28 Guido Trotter
# When we haven't reloaded the config for more than this amount of seconds, we
733 84c3ab28 Guido Trotter
# force a test to see if inotify is betraying us.
734 84c3ab28 Guido Trotter
CONFD_CONFIG_RELOAD_TIMEOUT = 60
735 84c3ab28 Guido Trotter
736 84c3ab28 Guido Trotter
# If we receive more than one update in this amount of seconds, we move to
737 84c3ab28 Guido Trotter
# polling every RATELIMIT seconds, rather than relying on inotify, to be able
738 84c3ab28 Guido Trotter
# to serve more requests.
739 84c3ab28 Guido Trotter
CONFD_CONFIG_RELOAD_RATELIMIT = 2
740 c8eded0b Guido Trotter
741 a3758ab2 Guido Trotter
# Magic number prepended to all confd queries.
742 a3758ab2 Guido Trotter
# This allows us to distinguish different types of confd protocols and handle
743 a3758ab2 Guido Trotter
# them. For example by changing this we can move the whole payload to be
744 a3758ab2 Guido Trotter
# compressed, or move away from json.
745 a3758ab2 Guido Trotter
CONFD_MAGIC_FOURCC = 'plj0'
746 a3758ab2 Guido Trotter
747 e4ccf6cd Guido Trotter
# By default a confd request is sent to the minimum between this number and all
748 e4ccf6cd Guido Trotter
# MCs. 6 was chosen because even in the case of a disastrous 50% response rate,
749 e4ccf6cd Guido Trotter
# we should have enough answers to be able to compare more than one.
750 e4ccf6cd Guido Trotter
CONFD_DEFAULT_REQ_COVERAGE = 6
751 e4ccf6cd Guido Trotter
752 e4ccf6cd Guido Trotter
# Timeout in seconds to expire pending query request in the confd client
753 e4ccf6cd Guido Trotter
# library. We don't actually expect any answer more than 10 seconds after we
754 e4ccf6cd Guido Trotter
# sent a request.
755 e4ccf6cd Guido Trotter
CONFD_CLIENT_EXPIRE_TIMEOUT = 10
756 e4ccf6cd Guido Trotter
757 c8eded0b Guido Trotter
# Maximum UDP datagram size.
758 c8eded0b Guido Trotter
# On IPv4: 64K - 20 (ip header size) - 8 (udp header size) = 65507
759 c8eded0b Guido Trotter
# On IPv6: 64K - 40 (ip6 header size) - 8 (udp header size) = 65487
760 c8eded0b Guido Trotter
#   (assuming we can't use jumbo frames)
761 c8eded0b Guido Trotter
# We just set this to 60K, which should be enough
762 c8eded0b Guido Trotter
MAX_UDP_DATA_SIZE = 61440