Statistics
| Branch: | Tag: | Revision:

root / lib / constants.py @ 2d76b580

History | View | Annotate | Download (23.1 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 4fe80ef2 Iustin Pop
import re
25 4fe80ef2 Iustin Pop
26 2ec08468 Michael Hanselmann
from ganeti import _autoconf
27 7c18ef8e Michael Hanselmann
28 a8083063 Iustin Pop
# various versions
29 72456eb2 Michael Hanselmann
PROTOCOL_VERSION = 30
30 2ec08468 Michael Hanselmann
RELEASE_VERSION = _autoconf.PACKAGE_VERSION
31 d1a7d66f Guido Trotter
OS_API_V10 = 10
32 d1a7d66f Guido Trotter
OS_API_V15 = 15
33 d1a7d66f Guido Trotter
OS_API_VERSIONS = frozenset([OS_API_V10, OS_API_V15])
34 a8083063 Iustin Pop
EXPORT_VERSION = 0
35 bac5ffc3 Oleksiy Mishchenko
RAPI_VERSION = 2
36 a8083063 Iustin Pop
37 1b45f4e5 Michael Hanselmann
38 243cdbcc Michael Hanselmann
# Format for CONFIG_VERSION:
39 243cdbcc Michael Hanselmann
#   01 03 0123 = 01030123
40 243cdbcc Michael Hanselmann
#   ^^ ^^ ^^^^
41 243cdbcc Michael Hanselmann
#   |  |  + Configuration version/revision
42 243cdbcc Michael Hanselmann
#   |  + Minor version
43 243cdbcc Michael Hanselmann
#   + Major version
44 243cdbcc Michael Hanselmann
#
45 243cdbcc Michael Hanselmann
# It stored as an integer. Make sure not to write an octal number.
46 1b45f4e5 Michael Hanselmann
47 1b45f4e5 Michael Hanselmann
# BuildVersion and SplitVersion must be in here because we can't import other
48 1b45f4e5 Michael Hanselmann
# modules. The cfgupgrade tool must be able to read and write version numbers
49 1b45f4e5 Michael Hanselmann
# and thus requires these functions. To avoid code duplication, they're kept in
50 1b45f4e5 Michael Hanselmann
# here.
51 1b45f4e5 Michael Hanselmann
52 1b45f4e5 Michael Hanselmann
def BuildVersion(major, minor, revision):
53 1b45f4e5 Michael Hanselmann
  """Calculates int version number from major, minor and revision numbers.
54 1b45f4e5 Michael Hanselmann

55 1b45f4e5 Michael Hanselmann
  Returns: int representing version number
56 1b45f4e5 Michael Hanselmann

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

69 1b45f4e5 Michael Hanselmann
  Returns: tuple; (major, minor, revision)
70 1b45f4e5 Michael Hanselmann

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