Statistics
| Branch: | Tag: | Revision:

root / lib / constants.py @ a52978c7

History | View | Annotate | Download (40.7 kB)

1 2f31098c Iustin Pop
#
2 a8083063 Iustin Pop
#
3 a8083063 Iustin Pop
4 dcb9946c Iustin Pop
# Copyright (C) 2006, 2007, 2008, 2009, 2010, 2011 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 13aeae6a Iustin Pop
from ganeti import _vcsversion
28 7c18ef8e Michael Hanselmann
29 a8083063 Iustin Pop
# various versions
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 b41b3516 Iustin Pop
OS_API_V20 = 20
34 b41b3516 Iustin Pop
OS_API_VERSIONS = frozenset([OS_API_V10, OS_API_V15, OS_API_V20])
35 13aeae6a Iustin Pop
VCS_VERSION = _vcsversion.VCS_VERSION
36 a8083063 Iustin Pop
EXPORT_VERSION = 0
37 bac5ffc3 Oleksiy Mishchenko
RAPI_VERSION = 2
38 a8083063 Iustin Pop
39 1b45f4e5 Michael Hanselmann
40 243cdbcc Michael Hanselmann
# Format for CONFIG_VERSION:
41 243cdbcc Michael Hanselmann
#   01 03 0123 = 01030123
42 243cdbcc Michael Hanselmann
#   ^^ ^^ ^^^^
43 243cdbcc Michael Hanselmann
#   |  |  + Configuration version/revision
44 243cdbcc Michael Hanselmann
#   |  + Minor version
45 243cdbcc Michael Hanselmann
#   + Major version
46 243cdbcc Michael Hanselmann
#
47 243cdbcc Michael Hanselmann
# It stored as an integer. Make sure not to write an octal number.
48 1b45f4e5 Michael Hanselmann
49 1b45f4e5 Michael Hanselmann
# BuildVersion and SplitVersion must be in here because we can't import other
50 1b45f4e5 Michael Hanselmann
# modules. The cfgupgrade tool must be able to read and write version numbers
51 1b45f4e5 Michael Hanselmann
# and thus requires these functions. To avoid code duplication, they're kept in
52 1b45f4e5 Michael Hanselmann
# here.
53 1b45f4e5 Michael Hanselmann
54 1b45f4e5 Michael Hanselmann
def BuildVersion(major, minor, revision):
55 1b45f4e5 Michael Hanselmann
  """Calculates int version number from major, minor and revision numbers.
56 1b45f4e5 Michael Hanselmann

57 1b45f4e5 Michael Hanselmann
  Returns: int representing version number
58 1b45f4e5 Michael Hanselmann

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

71 1b45f4e5 Michael Hanselmann
  Returns: tuple; (major, minor, revision)
72 1b45f4e5 Michael Hanselmann

73 1b45f4e5 Michael Hanselmann
  """
74 1b45f4e5 Michael Hanselmann
  assert isinstance(version, int)
75 1b45f4e5 Michael Hanselmann
76 1b45f4e5 Michael Hanselmann
  (major, remainder) = divmod(version, 1000000)
77 1b45f4e5 Michael Hanselmann
  (minor, revision) = divmod(remainder, 10000)
78 1b45f4e5 Michael Hanselmann
79 1b45f4e5 Michael Hanselmann
  return (major, minor, revision)
80 1b45f4e5 Michael Hanselmann
81 1b45f4e5 Michael Hanselmann
82 243cdbcc Michael Hanselmann
CONFIG_MAJOR = int(_autoconf.VERSION_MAJOR)
83 243cdbcc Michael Hanselmann
CONFIG_MINOR = int(_autoconf.VERSION_MINOR)
84 243cdbcc Michael Hanselmann
CONFIG_REVISION = 0
85 1b45f4e5 Michael Hanselmann
CONFIG_VERSION = BuildVersion(CONFIG_MAJOR, CONFIG_MINOR, CONFIG_REVISION)
86 a8083063 Iustin Pop
87 cc7d6f1a Michael Hanselmann
#: RPC protocol version
88 cc7d6f1a Michael Hanselmann
PROTOCOL_VERSION = BuildVersion(CONFIG_MAJOR, CONFIG_MINOR, 0)
89 cc7d6f1a Michael Hanselmann
90 8b72b05c René Nussbaumer
# user separation
91 8b72b05c René Nussbaumer
DAEMONS_GROUP = _autoconf.DAEMONS_GROUP
92 f12e1736 René Nussbaumer
ADMIN_GROUP = _autoconf.ADMIN_GROUP
93 8b72b05c René Nussbaumer
MASTERD_USER = _autoconf.MASTERD_USER
94 f12e1736 René Nussbaumer
MASTERD_GROUP = _autoconf.MASTERD_GROUP
95 8b72b05c René Nussbaumer
RAPI_USER = _autoconf.RAPI_USER
96 f12e1736 René Nussbaumer
RAPI_GROUP = _autoconf.RAPI_GROUP
97 f12e1736 René Nussbaumer
CONFD_USER = _autoconf.CONFD_USER
98 f12e1736 René Nussbaumer
CONFD_GROUP = _autoconf.CONFD_GROUP
99 f12e1736 René Nussbaumer
NODED_USER = _autoconf.NODED_USER
100 03881cb0 René Nussbaumer
NODED_GROUP = _autoconf.NODED_GROUP
101 8b72b05c René Nussbaumer
102 7e7629c6 Tsachy Shacham
# cpu pinning separators and constants
103 7e7629c6 Tsachy Shacham
CPU_PINNING_SEP = ":"
104 7e7629c6 Tsachy Shacham
CPU_PINNING_ALL = "all"
105 7e7629c6 Tsachy Shacham
# internal representation of "all"
106 7e7629c6 Tsachy Shacham
CPU_PINNING_ALL_VAL = -1
107 bf5681c0 Tsachy Shacham
# one "all" entry in a CPU list means CPU pinning is off
108 bf5681c0 Tsachy Shacham
CPU_PINNING_OFF = [CPU_PINNING_ALL_VAL]
109 7e7629c6 Tsachy Shacham
110 7e7629c6 Tsachy Shacham
# A Xen-specific implementation detail - there is no way to actually say
111 7e7629c6 Tsachy Shacham
# "use any cpu for pinning" in a Xen configuration file, as opposed to the
112 7e7629c6 Tsachy Shacham
# command line, where you can say "xm vcpu-pin <domain> <vcpu> all".
113 7e7629c6 Tsachy Shacham
# The workaround used in Xen is "0-63" (see source code function
114 7e7629c6 Tsachy Shacham
# xm_vcpu_pin in <xen-source>/tools/python/xen/xm/main.py).
115 7e7629c6 Tsachy Shacham
# To support future changes, the following constant is treated as a
116 7e7629c6 Tsachy Shacham
# blackbox string that simply means use-any-cpu-for-pinning-under-xen.
117 7e7629c6 Tsachy Shacham
CPU_PINNING_ALL_XEN = "0-63"
118 a03fcb26 René Nussbaumer
119 bf5681c0 Tsachy Shacham
# A KVM-specific implementation detail - the following value is used
120 bf5681c0 Tsachy Shacham
# to set CPU affinity to all processors (#0 through #31), per taskset
121 bf5681c0 Tsachy Shacham
# man page.
122 bf5681c0 Tsachy Shacham
CPU_PINNING_ALL_KVM = 0xFFFFFFFF
123 bf5681c0 Tsachy Shacham
124 6e991d0e René Nussbaumer
# Wipe
125 da63bb4e René Nussbaumer
DD_CMD = "dd"
126 e687ec01 Michael Hanselmann
WIPE_BLOCK_SIZE = 1024 ** 2
127 a03fcb26 René Nussbaumer
MAX_WIPE_CHUNK = 1024 # 1GB
128 a03fcb26 René Nussbaumer
MIN_WIPE_CHUNK_PERCENT = 10
129 a03fcb26 René Nussbaumer
130 6e991d0e René Nussbaumer
131 a8083063 Iustin Pop
# file paths
132 2ec08468 Michael Hanselmann
DATA_DIR = _autoconf.LOCALSTATEDIR + "/lib/ganeti"
133 1ed70996 Iustin Pop
RUN_DIR = _autoconf.LOCALSTATEDIR + "/run"
134 75afaefc Iustin Pop
RUN_GANETI_DIR = RUN_DIR + "/ganeti"
135 42ff3343 Guido Trotter
BDEV_CACHE_DIR = RUN_GANETI_DIR + "/bdev-cache"
136 75afaefc Iustin Pop
DISK_LINKS_DIR = RUN_GANETI_DIR + "/instance-disks"
137 8b72b05c René Nussbaumer
RUN_DIRS_MODE = 0775
138 b4442fd9 Guido Trotter
SOCKET_DIR = RUN_GANETI_DIR + "/socket"
139 5bae14d9 Guido Trotter
SECURE_DIR_MODE = 0700
140 637c8ab8 Balazs Lecz
SECURE_FILE_MODE = 0600
141 8b72b05c René Nussbaumer
SOCKET_DIR_MODE = 0750
142 f942a838 Michael Hanselmann
CRYPTO_KEYS_DIR = RUN_GANETI_DIR + "/crypto"
143 01144827 Guido Trotter
CRYPTO_KEYS_DIR_MODE = SECURE_DIR_MODE
144 1651d116 Michael Hanselmann
IMPORT_EXPORT_DIR = RUN_GANETI_DIR + "/import-export"
145 1651d116 Michael Hanselmann
IMPORT_EXPORT_DIR_MODE = 0755
146 b6135bbc Apollon Oikonomopoulos
ADOPTABLE_BLOCKDEV_ROOT = "/dev/disk/"
147 75afaefc Iustin Pop
# keep RUN_GANETI_DIR first here, to make sure all get created when the node
148 75afaefc Iustin Pop
# daemon is started (this takes care of RUN_DIR being tmpfs)
149 e687ec01 Michael Hanselmann
SUB_RUN_DIRS = [
150 e687ec01 Michael Hanselmann
  RUN_GANETI_DIR,
151 e687ec01 Michael Hanselmann
  BDEV_CACHE_DIR,
152 e687ec01 Michael Hanselmann
  DISK_LINKS_DIR,
153 e687ec01 Michael Hanselmann
  ]
154 3aecd2c7 Iustin Pop
LOCK_DIR = _autoconf.LOCALSTATEDIR + "/lock"
155 0c223ea9 Michael Hanselmann
SSCONF_LOCK_FILE = LOCK_DIR + "/ganeti-ssconf.lock"
156 649bcdd8 Balazs Lecz
# User-id pool lock directory
157 649bcdd8 Balazs Lecz
# The user-ids that are in use have a corresponding lock file in this directory
158 649bcdd8 Balazs Lecz
UIDPOOL_LOCKDIR = RUN_GANETI_DIR + "/uid-pool"
159 a8083063 Iustin Pop
CLUSTER_CONF_FILE = DATA_DIR + "/config.data"
160 168c1de2 Michael Hanselmann
NODED_CERT_FILE = DATA_DIR + "/server.pem"
161 61a08fa3 Michael Hanselmann
RAPI_CERT_FILE = DATA_DIR + "/rapi.pem"
162 6b7d5878 Michael Hanselmann
CONFD_HMAC_KEY = DATA_DIR + "/hmac.key"
163 3db3eb2a Michael Hanselmann
CLUSTER_DOMAIN_SECRET_FILE = DATA_DIR + "/cluster-domain-secret"
164 bcf0450d Michael Hanselmann
INSTANCE_STATUS_FILE = RUN_GANETI_DIR + "/instance-status"
165 82122173 Iustin Pop
SSH_KNOWN_HOSTS_FILE = DATA_DIR + "/known_hosts"
166 fdd9ac5b Michael Hanselmann
RAPI_USERS_FILE = DATA_DIR + "/rapi/users"
167 f1da30e6 Michael Hanselmann
QUEUE_DIR = DATA_DIR + "/queue"
168 f154a7a3 Michael Hanselmann
DAEMON_UTIL = _autoconf.PKGLIBDIR + "/daemon-util"
169 2e6469a1 René Nussbaumer
SETUP_SSH = _autoconf.TOOLSDIR + "/setup-ssh"
170 26916aad Apollon Oikonomopoulos
KVM_IFUP = _autoconf.PKGLIBDIR + "/kvm-ifup"
171 2f4c951e Stephen Shirley
KVM_CONSOLE_WRAPPER = _autoconf.PKGLIBDIR + "/tools/kvm-console-wrapper"
172 61631293 Stephen Shirley
XM_CONSOLE_WRAPPER = _autoconf.PKGLIBDIR + "/tools/xm-console-wrapper"
173 c8a0948f Michael Hanselmann
ETC_HOSTS = "/etc/hosts"
174 1abbbbe2 Manuel Franceschini
DEFAULT_FILE_STORAGE_DIR = _autoconf.FILE_STORAGE_DIR
175 4b97f902 Apollon Oikonomopoulos
DEFAULT_SHARED_FILE_STORAGE_DIR = _autoconf.SHARED_FILE_STORAGE_DIR
176 cb7c0198 Iustin Pop
ENABLE_FILE_STORAGE = _autoconf.ENABLE_FILE_STORAGE
177 4b97f902 Apollon Oikonomopoulos
ENABLE_SHARED_FILE_STORAGE = _autoconf.ENABLE_SHARED_FILE_STORAGE
178 5420ffc9 Guido Trotter
SYSCONFDIR = _autoconf.SYSCONFDIR
179 bea60381 Michael Hanselmann
TOOLSDIR = _autoconf.TOOLSDIR
180 131178b9 Luca Bigliardi
CONF_DIR = SYSCONFDIR + "/ganeti"
181 9894ece7 Michael Hanselmann
182 9d7b1e53 Michael Hanselmann
#: Lock file for watcher, locked in shared mode by watcher; lock in exclusive
183 9d7b1e53 Michael Hanselmann
# mode to block watcher (see L{cli._RunWhileClusterStoppedHelper.Call}
184 9d7b1e53 Michael Hanselmann
WATCHER_LOCK_FILE = LOCK_DIR + "/ganeti-watcher.lock"
185 9d7b1e53 Michael Hanselmann
186 9d7b1e53 Michael Hanselmann
#: Status file for per-group watcher, locked in exclusive mode by watcher
187 9d7b1e53 Michael Hanselmann
WATCHER_GROUP_STATE_FILE = DATA_DIR + "/watcher.%s.data"
188 9d7b1e53 Michael Hanselmann
189 9bb69bb5 Michael Hanselmann
#: File for per-group instance status, merged into L{INSTANCE_STATUS_FILE} by
190 9bb69bb5 Michael Hanselmann
#: per-group processes
191 9bb69bb5 Michael Hanselmann
WATCHER_GROUP_INSTANCE_STATUS_FILE = DATA_DIR + "/watcher.%s.instance-status"
192 9bb69bb5 Michael Hanselmann
193 9d7b1e53 Michael Hanselmann
#: File containing Unix timestamp until which watcher should be paused
194 9d7b1e53 Michael Hanselmann
WATCHER_PAUSEFILE = DATA_DIR + "/watcher.pause"
195 9d7b1e53 Michael Hanselmann
196 168c1de2 Michael Hanselmann
ALL_CERT_FILES = frozenset([NODED_CERT_FILE, RAPI_CERT_FILE])
197 d3100055 Michael Hanselmann
198 227647ac Guido Trotter
MASTER_SOCKET = SOCKET_DIR + "/ganeti-master"
199 a8083063 Iustin Pop
200 cd50653c Guido Trotter
NODED = "ganeti-noded"
201 18679072 Guido Trotter
CONFD = "ganeti-confd"
202 8c96d01f Guido Trotter
RAPI = "ganeti-rapi"
203 dae3fdd2 Guido Trotter
MASTERD = "ganeti-masterd"
204 4d32feba Guido Trotter
# used in the ganeti-nbma project
205 4d32feba Guido Trotter
NLD = "ganeti-nld"
206 cd50653c Guido Trotter
207 cd50653c Guido Trotter
DAEMONS_PORTS = {
208 cd50653c Guido Trotter
  # daemon-name: ("proto", "default-port")
209 cd50653c Guido Trotter
  NODED: ("tcp", 1811),
210 18679072 Guido Trotter
  CONFD: ("udp", 1814),
211 8c96d01f Guido Trotter
  RAPI: ("tcp", 5080),
212 2089573e René Nussbaumer
  "ssh": ("tcp", 22),
213 4d32feba Guido Trotter
  # used in the ganeti-nbma project
214 4d32feba Guido Trotter
  NLD: ("udp", 1816),
215 cd50653c Guido Trotter
}
216 cd50653c Guido Trotter
DEFAULT_NODED_PORT = DAEMONS_PORTS[NODED][1]
217 18679072 Guido Trotter
DEFAULT_CONFD_PORT = DAEMONS_PORTS[CONFD][1]
218 8c96d01f Guido Trotter
DEFAULT_RAPI_PORT = DAEMONS_PORTS[RAPI][1]
219 4d32feba Guido Trotter
# used in the ganeti-nbma project
220 4d32feba Guido Trotter
DEFAULT_NLD_PORT = DAEMONS_PORTS[NLD][1]
221 cd50653c Guido Trotter
222 a8083063 Iustin Pop
FIRST_DRBD_PORT = 11000
223 a8083063 Iustin Pop
LAST_DRBD_PORT = 14999
224 880478f8 Iustin Pop
MASTER_SCRIPT = "ganeti-master"
225 a8083063 Iustin Pop
226 9936bd63 Iustin Pop
LOG_DIR = _autoconf.LOCALSTATEDIR + "/log/ganeti/"
227 dae3fdd2 Guido Trotter
DAEMONS_LOGFILES = {
228 d73ef63f Michael Hanselmann
  # "daemon-name": "logfile"
229 d73ef63f Michael Hanselmann
  NODED: LOG_DIR + "node-daemon.log",
230 d73ef63f Michael Hanselmann
  CONFD: LOG_DIR + "conf-daemon.log",
231 d73ef63f Michael Hanselmann
  RAPI: LOG_DIR + "rapi-daemon.log",
232 d73ef63f Michael Hanselmann
  MASTERD: LOG_DIR + "master-daemon.log",
233 4d32feba Guido Trotter
  # used in the ganeti-nbma project
234 4d32feba Guido Trotter
  NLD: LOG_DIR + "nl-daemon.log",
235 d73ef63f Michael Hanselmann
  }
236 57fd6d0b Michael Hanselmann
237 9936bd63 Iustin Pop
LOG_OS_DIR = LOG_DIR + "os"
238 9936bd63 Iustin Pop
LOG_WATCHER = LOG_DIR + "watcher.log"
239 9936bd63 Iustin Pop
LOG_COMMANDS = LOG_DIR + "commands.log"
240 6abe9194 Iustin Pop
LOG_BURNIN = LOG_DIR + "burnin.log"
241 2089573e René Nussbaumer
LOG_SETUP_SSH = LOG_DIR + "setup-ssh.log"
242 a8083063 Iustin Pop
243 481d47e8 Luca Bigliardi
DEV_CONSOLE = "/dev/console"
244 481d47e8 Luca Bigliardi
245 1b045f5d Balazs Lecz
PROC_MOUNTS = "/proc/mounts"
246 1b045f5d Balazs Lecz
247 3d5ebbf0 Stephen Shirley
# Local UniX Interface related constants
248 25942a6c Guido Trotter
LUXI_EOM = "\3"
249 e986f20c Michael Hanselmann
LUXI_VERSION = CONFIG_VERSION
250 25942a6c Guido Trotter
251 d0c8c01d Iustin Pop
# one of "no", "yes", "only"
252 551b6283 Iustin Pop
SYSLOG_USAGE = _autoconf.SYSLOG_USAGE
253 551b6283 Iustin Pop
SYSLOG_NO = "no"
254 551b6283 Iustin Pop
SYSLOG_YES = "yes"
255 551b6283 Iustin Pop
SYSLOG_ONLY = "only"
256 551b6283 Iustin Pop
SYSLOG_SOCKET = "/dev/log"
257 551b6283 Iustin Pop
258 7c3d51d4 Guido Trotter
OS_SEARCH_PATH = _autoconf.OS_SEARCH_PATH
259 68dccc07 Guido Trotter
EXPORT_DIR = _autoconf.EXPORT_DIR
260 a8083063 Iustin Pop
261 a8083063 Iustin Pop
EXPORT_CONF_FILE = "config.ini"
262 a8083063 Iustin Pop
263 2f2dbb4b Jun Futagawa
XEN_BOOTLOADER = _autoconf.XEN_BOOTLOADER
264 f00b46bc Michael Hanselmann
XEN_KERNEL = _autoconf.XEN_KERNEL
265 f00b46bc Michael Hanselmann
XEN_INITRD = _autoconf.XEN_INITRD
266 f00b46bc Michael Hanselmann
267 7e2c5b9e Guido Trotter
KVM_PATH = _autoconf.KVM_PATH
268 14aa53cb Guido Trotter
SOCAT_PATH = _autoconf.SOCAT_PATH
269 fe5b0c42 Michael Hanselmann
SOCAT_USE_ESCAPE = _autoconf.SOCAT_USE_ESCAPE
270 e90739d6 Michael Hanselmann
SOCAT_USE_COMPRESS = _autoconf.SOCAT_USE_COMPRESS
271 86d6bc2a Guido Trotter
SOCAT_ESCAPE_CODE = "0x1d"
272 7e2c5b9e Guido Trotter
273 25ce3ec4 Michael Hanselmann
#: Console as SSH command
274 25ce3ec4 Michael Hanselmann
CONS_SSH = "ssh"
275 25ce3ec4 Michael Hanselmann
276 25ce3ec4 Michael Hanselmann
#: Console as VNC server
277 25ce3ec4 Michael Hanselmann
CONS_VNC = "vnc"
278 25ce3ec4 Michael Hanselmann
279 4d2cdb5a Andrea Spadaccini
#: Console as SPICE server
280 4d2cdb5a Andrea Spadaccini
CONS_SPICE = "spice"
281 4d2cdb5a Andrea Spadaccini
282 25ce3ec4 Michael Hanselmann
#: Display a message for console access
283 25ce3ec4 Michael Hanselmann
CONS_MESSAGE = "msg"
284 25ce3ec4 Michael Hanselmann
285 25ce3ec4 Michael Hanselmann
#: All console types
286 4d2cdb5a Andrea Spadaccini
CONS_ALL = frozenset([CONS_SSH, CONS_VNC, CONS_SPICE, CONS_MESSAGE])
287 25ce3ec4 Michael Hanselmann
288 bdd5e420 Michael Hanselmann
# For RSA keys more bits are better, but they also make operations more
289 bdd5e420 Michael Hanselmann
# expensive. NIST SP 800-131 recommends a minimum of 2048 bits from the year
290 bdd5e420 Michael Hanselmann
# 2010 on.
291 bdd5e420 Michael Hanselmann
RSA_KEY_BITS = 2048
292 bdd5e420 Michael Hanselmann
293 971bbd84 Michael Hanselmann
# Ciphers allowed for SSL connections. For the format, see ciphers(1). A better
294 971bbd84 Michael Hanselmann
# way to disable ciphers would be to use the exclamation mark (!), but socat
295 971bbd84 Michael Hanselmann
# versions below 1.5 can't parse exclamation marks in options properly. When
296 7407c2d5 Adeodato Simo
# modifying the ciphers, ensure not to accidentially add something after it's
297 971bbd84 Michael Hanselmann
# been removed. Use the "openssl" utility to check the allowed ciphers, e.g.
298 971bbd84 Michael Hanselmann
# "openssl ciphers -v HIGH:-DES".
299 971bbd84 Michael Hanselmann
OPENSSL_CIPHERS = "HIGH:-DES:-3DES:-EXPORT:-ADH"
300 971bbd84 Michael Hanselmann
301 bdd5e420 Michael Hanselmann
# Digest used to sign certificates ("openssl x509" uses SHA1 by default)
302 bdd5e420 Michael Hanselmann
X509_CERT_SIGN_DIGEST = "SHA1"
303 bdd5e420 Michael Hanselmann
304 600535f0 Manuel Franceschini
# Default validity of certificates in days
305 600535f0 Manuel Franceschini
X509_CERT_DEFAULT_VALIDITY = 365 * 5
306 600535f0 Manuel Franceschini
307 600535f0 Manuel Franceschini
# commonName (CN) used in certificates
308 600535f0 Manuel Franceschini
X509_CERT_CN = "ganeti.example.com"
309 600535f0 Manuel Franceschini
310 68857643 Michael Hanselmann
X509_CERT_SIGNATURE_HEADER = "X-Ganeti-Signature"
311 68857643 Michael Hanselmann
312 2d76b580 Michael Hanselmann
IMPORT_EXPORT_DAEMON = _autoconf.PKGLIBDIR + "/import-export"
313 2d76b580 Michael Hanselmann
314 2d76b580 Michael Hanselmann
# Import/export daemon mode
315 2d76b580 Michael Hanselmann
IEM_IMPORT = "import"
316 2d76b580 Michael Hanselmann
IEM_EXPORT = "export"
317 2d76b580 Michael Hanselmann
318 7e3c1da6 Michael Hanselmann
# Import/export transport compression
319 7e3c1da6 Michael Hanselmann
IEC_NONE = "none"
320 7e3c1da6 Michael Hanselmann
IEC_GZIP = "gzip"
321 7e3c1da6 Michael Hanselmann
IEC_ALL = frozenset([
322 7e3c1da6 Michael Hanselmann
  IEC_NONE,
323 7e3c1da6 Michael Hanselmann
  IEC_GZIP,
324 7e3c1da6 Michael Hanselmann
  ])
325 7e3c1da6 Michael Hanselmann
326 f9323011 Michael Hanselmann
IE_CUSTOM_SIZE = "fd"
327 f9323011 Michael Hanselmann
328 1d3dfa29 Michael Hanselmann
IE_MAGIC_RE = re.compile(r"^[-_.a-zA-Z0-9]{5,100}$")
329 1d3dfa29 Michael Hanselmann
330 1651d116 Michael Hanselmann
# Import/export I/O
331 1651d116 Michael Hanselmann
# Direct file I/O, equivalent to a shell's I/O redirection using '<' or '>'
332 1651d116 Michael Hanselmann
IEIO_FILE = "file"
333 1651d116 Michael Hanselmann
# Raw block device I/O using "dd"
334 1651d116 Michael Hanselmann
IEIO_RAW_DISK = "raw"
335 1651d116 Michael Hanselmann
# OS definition import/export script
336 1651d116 Michael Hanselmann
IEIO_SCRIPT = "script"
337 1651d116 Michael Hanselmann
338 973d7867 Iustin Pop
VALUE_DEFAULT = "default"
339 4c566ede Guido Trotter
VALUE_AUTO = "auto"
340 4c566ede Guido Trotter
VALUE_GENERATE = "generate"
341 973d7867 Iustin Pop
VALUE_NONE = "none"
342 1817f49b Guido Trotter
VALUE_TRUE = "true"
343 1817f49b Guido Trotter
VALUE_FALSE = "false"
344 973d7867 Iustin Pop
345 4fe80ef2 Iustin Pop
# External script validation mask
346 4fe80ef2 Iustin Pop
EXT_PLUGIN_MASK = re.compile("^[a-zA-Z0-9_-]+$")
347 4fe80ef2 Iustin Pop
348 a8083063 Iustin Pop
# hooks-related constants
349 131178b9 Luca Bigliardi
HOOKS_BASE_DIR = CONF_DIR + "/hooks"
350 a8083063 Iustin Pop
HOOKS_PHASE_PRE = "pre"
351 a8083063 Iustin Pop
HOOKS_PHASE_POST = "post"
352 6a4aa7c1 Iustin Pop
HOOKS_NAME_CFGUPDATE = "config-update"
353 9e289e36 Guido Trotter
HOOKS_NAME_WATCHER = "watcher"
354 f3e2e4c6 Iustin Pop
HOOKS_VERSION = 2
355 a8083063 Iustin Pop
356 a8083063 Iustin Pop
# hooks subject type (what object type does the LU deal with)
357 a8083063 Iustin Pop
HTYPE_CLUSTER = "CLUSTER"
358 a8083063 Iustin Pop
HTYPE_NODE = "NODE"
359 b1ee5610 Adeodato Simo
HTYPE_GROUP = "GROUP"
360 a8083063 Iustin Pop
HTYPE_INSTANCE = "INSTANCE"
361 a8083063 Iustin Pop
362 a8083063 Iustin Pop
HKR_SKIP = 0
363 a8083063 Iustin Pop
HKR_FAIL = 1
364 a8083063 Iustin Pop
HKR_SUCCESS = 2
365 a8083063 Iustin Pop
366 ac2d0fe4 Michael Hanselmann
# Storage types
367 ac2d0fe4 Michael Hanselmann
ST_FILE = "file"
368 ac2d0fe4 Michael Hanselmann
ST_LVM_PV = "lvm-pv"
369 ac2d0fe4 Michael Hanselmann
ST_LVM_VG = "lvm-vg"
370 6032697c Michael Hanselmann
371 6032697c Michael Hanselmann
# Storage fields
372 620a85fd Iustin Pop
# first two are valid in LU context only, not passed to backend
373 620a85fd Iustin Pop
SF_NODE = "node"
374 620a85fd Iustin Pop
SF_TYPE = "type"
375 620a85fd Iustin Pop
# and the rest are valid in backend
376 6032697c Michael Hanselmann
SF_NAME = "name"
377 6032697c Michael Hanselmann
SF_SIZE = "size"
378 6032697c Michael Hanselmann
SF_FREE = "free"
379 6032697c Michael Hanselmann
SF_USED = "used"
380 6032697c Michael Hanselmann
SF_ALLOCATABLE = "allocatable"
381 6032697c Michael Hanselmann
382 6c3c6db9 Michael Hanselmann
# Storage operations
383 6c3c6db9 Michael Hanselmann
SO_FIX_CONSISTENCY = "fix-consistency"
384 6c3c6db9 Michael Hanselmann
385 6032697c Michael Hanselmann
# Available fields per storage type
386 21daa4a8 Stephen Shirley
VALID_STORAGE_FIELDS = frozenset([
387 21daa4a8 Stephen Shirley
  SF_NAME,
388 21daa4a8 Stephen Shirley
  SF_TYPE,
389 21daa4a8 Stephen Shirley
  SF_SIZE,
390 21daa4a8 Stephen Shirley
  SF_USED,
391 21daa4a8 Stephen Shirley
  SF_FREE,
392 21daa4a8 Stephen Shirley
  SF_ALLOCATABLE
393 21daa4a8 Stephen Shirley
  ])
394 620a85fd Iustin Pop
395 620a85fd Iustin Pop
VALID_STORAGE_TYPES = frozenset([ST_FILE, ST_LVM_PV, ST_LVM_VG])
396 a8083063 Iustin Pop
397 efb8da02 Michael Hanselmann
MODIFIABLE_STORAGE_FIELDS = {
398 efb8da02 Michael Hanselmann
  ST_LVM_PV: frozenset([SF_ALLOCATABLE]),
399 efb8da02 Michael Hanselmann
  }
400 efb8da02 Michael Hanselmann
401 4b37cac5 Michael Hanselmann
VALID_STORAGE_OPERATIONS = {
402 6c3c6db9 Michael Hanselmann
  ST_LVM_VG: frozenset([SO_FIX_CONSISTENCY]),
403 4b37cac5 Michael Hanselmann
  }
404 4b37cac5 Michael Hanselmann
405 74f37195 Michael Hanselmann
# Local disk status
406 74f37195 Michael Hanselmann
# Note: Code depends on LDS_OKAY < LDS_UNKNOWN < LDS_FAULTY
407 74f37195 Michael Hanselmann
(LDS_OKAY,
408 74f37195 Michael Hanselmann
 LDS_UNKNOWN,
409 74f37195 Michael Hanselmann
 LDS_FAULTY) = range(1, 4)
410 74f37195 Michael Hanselmann
411 a8083063 Iustin Pop
# disk template types
412 a8083063 Iustin Pop
DT_DISKLESS = "diskless"
413 a8083063 Iustin Pop
DT_PLAIN = "plain"
414 a1f445d3 Iustin Pop
DT_DRBD8 = "drbd"
415 04fa07f2 Manuel Franceschini
DT_FILE = "file"
416 4b97f902 Apollon Oikonomopoulos
DT_SHARED_FILE = "sharedfile"
417 b6135bbc Apollon Oikonomopoulos
DT_BLOCK = "blockdev"
418 a1f445d3 Iustin Pop
419 a1f445d3 Iustin Pop
# the set of network-mirrored disk templates
420 3429a076 Apollon Oikonomopoulos
DTS_INT_MIRROR = frozenset([DT_DRBD8])
421 a8083063 Iustin Pop
422 b6135bbc Apollon Oikonomopoulos
# the set of externally-mirrored disk templates (e.g. SAN, NAS)
423 b6135bbc Apollon Oikonomopoulos
DTS_EXT_MIRROR = frozenset([DT_SHARED_FILE, DT_BLOCK])
424 4b97f902 Apollon Oikonomopoulos
425 d63e148a Manuel Franceschini
# the set of non-lvm-based disk templates
426 b6135bbc Apollon Oikonomopoulos
DTS_NOT_LVM = frozenset([DT_DISKLESS, DT_FILE, DT_SHARED_FILE, DT_BLOCK])
427 d63e148a Manuel Franceschini
428 728489a3 Guido Trotter
# the set of disk templates which can be grown
429 4b97f902 Apollon Oikonomopoulos
DTS_GROWABLE = frozenset([DT_PLAIN, DT_DRBD8, DT_FILE, DT_SHARED_FILE])
430 728489a3 Guido Trotter
431 3b08cd1c Apollon Oikonomopoulos
# the set of disk templates that allow adoption
432 b6135bbc Apollon Oikonomopoulos
DTS_MAY_ADOPT = frozenset([DT_PLAIN, DT_BLOCK])
433 b6135bbc Apollon Oikonomopoulos
434 b6135bbc Apollon Oikonomopoulos
# the set of disk templates that *must* use adoption
435 b6135bbc Apollon Oikonomopoulos
DTS_MUST_ADOPT = frozenset([DT_BLOCK])
436 3b08cd1c Apollon Oikonomopoulos
437 85a0ff7e Apollon Oikonomopoulos
# the set of disk templates that allow migrations
438 3429a076 Apollon Oikonomopoulos
DTS_MIRRORED = frozenset.union(DTS_INT_MIRROR, DTS_EXT_MIRROR)
439 85a0ff7e Apollon Oikonomopoulos
440 c16915bd Guido Trotter
# the set of file based disk templates
441 c16915bd Guido Trotter
DTS_FILEBASED = frozenset([DT_FILE, DT_SHARED_FILE])
442 85a0ff7e Apollon Oikonomopoulos
443 fe96220b Iustin Pop
# logical disk types
444 fe96220b Iustin Pop
LD_LV = "lvm"
445 a1f445d3 Iustin Pop
LD_DRBD8 = "drbd8"
446 04fa07f2 Manuel Franceschini
LD_FILE = "file"
447 b6135bbc Apollon Oikonomopoulos
LD_BLOCKDEV = "blockdev"
448 b6135bbc Apollon Oikonomopoulos
LDS_BLOCK = frozenset([LD_LV, LD_DRBD8, LD_BLOCKDEV])
449 04fa07f2 Manuel Franceschini
450 2899d9de Iustin Pop
# drbd constants
451 2899d9de Iustin Pop
DRBD_HMAC_ALG = "md5"
452 3c03759a Iustin Pop
DRBD_NET_PROTOCOL = "C"
453 89b70f39 Iustin Pop
DRBD_BARRIERS = _autoconf.DRBD_BARRIERS
454 2899d9de Iustin Pop
455 04fa07f2 Manuel Franceschini
# file backend driver
456 04fa07f2 Manuel Franceschini
FD_LOOP = "loop"
457 04fa07f2 Manuel Franceschini
FD_BLKTAP = "blktap"
458 a1f445d3 Iustin Pop
459 a1f445d3 Iustin Pop
# the set of drbd-like disk types
460 abdf0113 Iustin Pop
LDS_DRBD = frozenset([LD_DRBD8])
461 fe96220b Iustin Pop
462 08db7c5c Iustin Pop
# disk access mode
463 24991749 Iustin Pop
DISK_RDONLY = "ro"
464 24991749 Iustin Pop
DISK_RDWR = "rw"
465 08db7c5c Iustin Pop
DISK_ACCESS_SET = frozenset([DISK_RDONLY, DISK_RDWR])
466 08db7c5c Iustin Pop
467 a9e0c397 Iustin Pop
# disk replacement mode
468 cfacfd6e Iustin Pop
REPLACE_DISK_PRI = "replace_on_primary"    # replace disks on primary
469 cfacfd6e Iustin Pop
REPLACE_DISK_SEC = "replace_on_secondary"  # replace disks on secondary
470 cfacfd6e Iustin Pop
REPLACE_DISK_CHG = "replace_new_secondary" # change secondary node
471 942be002 Michael Hanselmann
REPLACE_DISK_AUTO = "replace_auto"
472 3636400f Iustin Pop
REPLACE_MODES = frozenset([
473 3636400f Iustin Pop
  REPLACE_DISK_PRI,
474 3636400f Iustin Pop
  REPLACE_DISK_SEC,
475 3636400f Iustin Pop
  REPLACE_DISK_CHG,
476 3636400f Iustin Pop
  REPLACE_DISK_AUTO,
477 3636400f Iustin Pop
  ])
478 a9e0c397 Iustin Pop
479 4a96f1d1 Michael Hanselmann
# Instance export mode
480 4a96f1d1 Michael Hanselmann
EXPORT_MODE_LOCAL = "local"
481 4a96f1d1 Michael Hanselmann
EXPORT_MODE_REMOTE = "remote"
482 4a96f1d1 Michael Hanselmann
EXPORT_MODES = frozenset([
483 4a96f1d1 Michael Hanselmann
  EXPORT_MODE_LOCAL,
484 4a96f1d1 Michael Hanselmann
  EXPORT_MODE_REMOTE,
485 4a96f1d1 Michael Hanselmann
  ])
486 4a96f1d1 Michael Hanselmann
487 d385a174 Iustin Pop
# Lock recalculate mode
488 d0c8c01d Iustin Pop
LOCKS_REPLACE = "replace"
489 d0c8c01d Iustin Pop
LOCKS_APPEND = "append"
490 f6d9a522 Guido Trotter
491 d385a174 Iustin Pop
# Lock timeout (sum) before we should go into blocking acquire (still
492 d385a174 Iustin Pop
# can be reset by priority change); computed as max time (10 hours)
493 d385a174 Iustin Pop
# before we should actually go into blocking acquire given that we
494 d385a174 Iustin Pop
# start from default priority level; in seconds
495 d385a174 Iustin Pop
LOCK_ATTEMPTS_TIMEOUT = 10 * 3600 / 20.0
496 d385a174 Iustin Pop
LOCK_ATTEMPTS_MAXWAIT = 15.0
497 d385a174 Iustin Pop
LOCK_ATTEMPTS_MINWAIT = 1.0
498 d385a174 Iustin Pop
499 2f6eebee Guido Trotter
# instance creation modes
500 a8083063 Iustin Pop
INSTANCE_CREATE = "create"
501 a8083063 Iustin Pop
INSTANCE_IMPORT = "import"
502 9bf56d77 Michael Hanselmann
INSTANCE_REMOTE_IMPORT = "remote-import"
503 9bf56d77 Michael Hanselmann
INSTANCE_CREATE_MODES = frozenset([
504 9bf56d77 Michael Hanselmann
  INSTANCE_CREATE,
505 9bf56d77 Michael Hanselmann
  INSTANCE_IMPORT,
506 9bf56d77 Michael Hanselmann
  INSTANCE_REMOTE_IMPORT,
507 9bf56d77 Michael Hanselmann
  ])
508 a8083063 Iustin Pop
509 1410fa8d Michael Hanselmann
# Remote import/export handshake message and version
510 1410fa8d Michael Hanselmann
RIE_VERSION = 0
511 1410fa8d Michael Hanselmann
RIE_HANDSHAKE = "Hi, I'm Ganeti"
512 1410fa8d Michael Hanselmann
513 1410fa8d Michael Hanselmann
# Remote import/export certificate validity in seconds
514 1410fa8d Michael Hanselmann
RIE_CERT_VALIDITY = 24 * 60 * 60
515 1410fa8d Michael Hanselmann
516 4478301b Michael Hanselmann
# Overall timeout for establishing connection
517 8fd2e34c Michael Hanselmann
RIE_CONNECT_TIMEOUT = 180
518 4a96f1d1 Michael Hanselmann
519 4478301b Michael Hanselmann
# Export only: how long to wait per connection attempt (seconds)
520 4478301b Michael Hanselmann
RIE_CONNECT_ATTEMPT_TIMEOUT = 20
521 4478301b Michael Hanselmann
522 4478301b Michael Hanselmann
# Export only: number of attempts to connect
523 4478301b Michael Hanselmann
RIE_CONNECT_RETRIES = 10
524 4478301b Michael Hanselmann
525 c74cda62 René Nussbaumer
#: Give child process up to 5 seconds to exit after sending a signal
526 c74cda62 René Nussbaumer
CHILD_LINGER_TIMEOUT = 5.0
527 4a96f1d1 Michael Hanselmann
528 21daa4a8 Stephen Shirley
DISK_TEMPLATES = frozenset([
529 21daa4a8 Stephen Shirley
  DT_DISKLESS,
530 21daa4a8 Stephen Shirley
  DT_PLAIN,
531 21daa4a8 Stephen Shirley
  DT_DRBD8,
532 21daa4a8 Stephen Shirley
  DT_FILE,
533 21daa4a8 Stephen Shirley
  DT_SHARED_FILE,
534 21daa4a8 Stephen Shirley
  DT_BLOCK
535 21daa4a8 Stephen Shirley
  ])
536 04fa07f2 Manuel Franceschini
537 04fa07f2 Manuel Franceschini
FILE_DRIVER = frozenset([FD_LOOP, FD_BLKTAP])
538 a8083063 Iustin Pop
539 a8083063 Iustin Pop
# import/export config options
540 a8083063 Iustin Pop
INISECT_EXP = "export"
541 a8083063 Iustin Pop
INISECT_INS = "instance"
542 3c8954ad Iustin Pop
INISECT_HYP = "hypervisor"
543 3c8954ad Iustin Pop
INISECT_BEP = "backend"
544 535b49cb Iustin Pop
INISECT_OSP = "os"
545 38242904 Iustin Pop
546 24991749 Iustin Pop
# dynamic device modification
547 61a14bb3 Iustin Pop
DDM_ADD = "add"
548 61a14bb3 Iustin Pop
DDM_REMOVE = "remove"
549 61a14bb3 Iustin Pop
DDMS_VALUES = frozenset([DDM_ADD, DDM_REMOVE])
550 24991749 Iustin Pop
551 38242904 Iustin Pop
# common exit codes
552 a5bc662a Iustin Pop
EXIT_SUCCESS = 0
553 438b45d4 Michael Hanselmann
EXIT_FAILURE = 1
554 46479775 Guido Trotter
EXIT_NOTCLUSTER = 5
555 38242904 Iustin Pop
EXIT_NOTMASTER = 11
556 619fdc8e Iustin Pop
EXIT_NODESETUP_ERROR = 12
557 a5bc662a Iustin Pop
EXIT_CONFIRMATION = 13 # need user confirmation
558 cf62a272 Michael Hanselmann
559 ee3aedff Michael Hanselmann
#: Exit code for query operations with unknown fields
560 ee3aedff Michael Hanselmann
EXIT_UNKNOWN_FIELD = 14
561 ee3aedff Michael Hanselmann
562 5c947f38 Iustin Pop
# tags
563 5c947f38 Iustin Pop
TAG_CLUSTER = "cluster"
564 1ffd2673 Michael Hanselmann
TAG_NODEGROUP = "nodegroup"
565 5c947f38 Iustin Pop
TAG_NODE = "node"
566 5c947f38 Iustin Pop
TAG_INSTANCE = "instance"
567 3636400f Iustin Pop
VALID_TAG_TYPES = frozenset([
568 3636400f Iustin Pop
  TAG_CLUSTER,
569 1ffd2673 Michael Hanselmann
  TAG_NODEGROUP,
570 3636400f Iustin Pop
  TAG_NODE,
571 3636400f Iustin Pop
  TAG_INSTANCE,
572 3636400f Iustin Pop
  ])
573 5c947f38 Iustin Pop
MAX_TAG_LEN = 128
574 5c947f38 Iustin Pop
MAX_TAGS_PER_OBJ = 4096
575 5c947f38 Iustin Pop
576 cf62a272 Michael Hanselmann
# others
577 cf62a272 Michael Hanselmann
DEFAULT_BRIDGE = "xen-br0"
578 24b0d752 Iustin Pop
SYNC_SPEED = 60 * 1024
579 9769bb78 Manuel Franceschini
IP4_ADDRESS_LOCALHOST = "127.0.0.1"
580 9769bb78 Manuel Franceschini
IP4_ADDRESS_ANY = "0.0.0.0"
581 0d2cd893 Manuel Franceschini
IP6_ADDRESS_LOCALHOST = "::1"
582 0d2cd893 Manuel Franceschini
IP6_ADDRESS_ANY = "::"
583 2f20d07b Manuel Franceschini
IP4_VERSION = 4
584 2f20d07b Manuel Franceschini
IP6_VERSION = 6
585 b1cb62bd Andrea Spadaccini
VALID_IP_VERSIONS = frozenset([IP4_VERSION, IP6_VERSION])
586 16abfbc2 Alexander Schreiber
TCP_PING_TIMEOUT = 10
587 7900ed01 Iustin Pop
GANETI_RUNAS = "root"
588 d63e148a Manuel Franceschini
DEFAULT_VG = "xenvg"
589 ee2f0ed4 Luca Bigliardi
DEFAULT_DRBD_HELPER = "/bin/true"
590 8d1a2a64 Michael Hanselmann
MIN_VG_SIZE = 20480
591 c5e489f7 Iustin Pop
DEFAULT_MAC_PREFIX = "aa:00:00"
592 3736cb6b Iustin Pop
LVM_STRIPECOUNT = _autoconf.LVM_STRIPECOUNT
593 88cd08aa Guido Trotter
# default maximum instance wait time, in seconds.
594 88cd08aa Guido Trotter
DEFAULT_SHUTDOWN_TIMEOUT = 120
595 313b2dd4 Michael Hanselmann
NODE_MAX_CLOCK_SKEW = 150
596 033a1d00 Michael Hanselmann
# Time for an intra-cluster disk transfer to wait for a connection
597 81635b5a Iustin Pop
DISK_TRANSFER_CONNECT_TIMEOUT = 60
598 3536c792 Iustin Pop
# Disk index separator
599 3536c792 Iustin Pop
DISK_SEPARATOR = _autoconf.DISK_SEPARATOR
600 c4dfb0b6 Andrea Spadaccini
IP_COMMAND_PATH = _autoconf.IP_PATH
601 7900ed01 Iustin Pop
602 6a373640 Michael Hanselmann
#: Key for job IDs in opcode result
603 6a373640 Michael Hanselmann
JOB_IDS_KEY = "jobs"
604 6a373640 Michael Hanselmann
605 6bb65e3a Guido Trotter
# runparts results
606 6bb65e3a Guido Trotter
(RUNPARTS_SKIP,
607 6bb65e3a Guido Trotter
 RUNPARTS_RUN,
608 6bb65e3a Guido Trotter
 RUNPARTS_ERR) = range(3)
609 6bb65e3a Guido Trotter
610 6bb65e3a Guido Trotter
RUNPARTS_STATUS = frozenset([RUNPARTS_SKIP, RUNPARTS_RUN, RUNPARTS_ERR])
611 6bb65e3a Guido Trotter
612 12bce260 Michael Hanselmann
# RPC constants
613 12bce260 Michael Hanselmann
(RPC_ENCODING_NONE,
614 12bce260 Michael Hanselmann
 RPC_ENCODING_ZLIB_BASE64) = range(2)
615 12bce260 Michael Hanselmann
616 ded1c679 Guido Trotter
# os related constants
617 d0c8c01d Iustin Pop
OS_SCRIPT_CREATE = "create"
618 d0c8c01d Iustin Pop
OS_SCRIPT_IMPORT = "import"
619 d0c8c01d Iustin Pop
OS_SCRIPT_EXPORT = "export"
620 d0c8c01d Iustin Pop
OS_SCRIPT_RENAME = "rename"
621 d0c8c01d Iustin Pop
OS_SCRIPT_VERIFY = "verify"
622 21daa4a8 Stephen Shirley
OS_SCRIPTS = frozenset([
623 21daa4a8 Stephen Shirley
  OS_SCRIPT_CREATE,
624 21daa4a8 Stephen Shirley
  OS_SCRIPT_IMPORT,
625 21daa4a8 Stephen Shirley
  OS_SCRIPT_EXPORT,
626 21daa4a8 Stephen Shirley
  OS_SCRIPT_RENAME,
627 21daa4a8 Stephen Shirley
  OS_SCRIPT_VERIFY
628 21daa4a8 Stephen Shirley
  ])
629 37482e7b Guido Trotter
630 d0c8c01d Iustin Pop
OS_API_FILE = "ganeti_api_version"
631 d0c8c01d Iustin Pop
OS_VARIANTS_FILE = "variants.list"
632 d0c8c01d Iustin Pop
OS_PARAMETERS_FILE = "parameters.list"
633 b41b3516 Iustin Pop
634 d0c8c01d Iustin Pop
OS_VALIDATE_PARAMETERS = "parameters"
635 acd9ff9e Iustin Pop
OS_VALIDATE_CALLS = frozenset([OS_VALIDATE_PARAMETERS])
636 b6b45e0d Guido Trotter
637 70d9e3d8 Iustin Pop
# ssh constants
638 553bd93f Vitaly Kuznetsov
SSH_CONFIG_DIR = _autoconf.SSH_CONFIG_DIR
639 553bd93f Vitaly Kuznetsov
SSH_HOST_DSA_PRIV = SSH_CONFIG_DIR + "/ssh_host_dsa_key"
640 70d9e3d8 Iustin Pop
SSH_HOST_DSA_PUB = SSH_HOST_DSA_PRIV + ".pub"
641 553bd93f Vitaly Kuznetsov
SSH_HOST_RSA_PRIV = SSH_CONFIG_DIR + "/ssh_host_rsa_key"
642 70d9e3d8 Iustin Pop
SSH_HOST_RSA_PUB = SSH_HOST_RSA_PRIV + ".pub"
643 fff33d70 Michael Hanselmann
SSH = "ssh"
644 fff33d70 Michael Hanselmann
SCP = "scp"
645 007a2f3e Alexander Schreiber
646 007a2f3e Alexander Schreiber
# reboot types
647 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_SOFT = "soft"
648 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_HARD = "hard"
649 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_FULL = "full"
650 2584d4a4 Alexander Schreiber
651 990ade2d Stephen Shirley
REBOOT_TYPES = frozenset([
652 990ade2d Stephen Shirley
  INSTANCE_REBOOT_SOFT,
653 990ade2d Stephen Shirley
  INSTANCE_REBOOT_HARD,
654 990ade2d Stephen Shirley
  INSTANCE_REBOOT_FULL
655 990ade2d Stephen Shirley
  ])
656 990ade2d Stephen Shirley
657 990ade2d Stephen Shirley
# instance reboot behaviors
658 990ade2d Stephen Shirley
INSTANCE_REBOOT_ALLOWED = "reboot"
659 990ade2d Stephen Shirley
INSTANCE_REBOOT_EXIT = "exit"
660 990ade2d Stephen Shirley
661 990ade2d Stephen Shirley
REBOOT_BEHAVIORS = frozenset([
662 990ade2d Stephen Shirley
  INSTANCE_REBOOT_ALLOWED,
663 990ade2d Stephen Shirley
  INSTANCE_REBOOT_EXIT
664 990ade2d Stephen Shirley
  ])
665 00f91f29 Iustin Pop
666 d0c8c01d Iustin Pop
VTYPE_STRING = "string"
667 59525e1f Michael Hanselmann
VTYPE_MAYBE_STRING = "maybe-string"
668 d0c8c01d Iustin Pop
VTYPE_BOOL = "bool"
669 d0c8c01d Iustin Pop
VTYPE_SIZE = "size" # size, in MiBs
670 d0c8c01d Iustin Pop
VTYPE_INT = "int"
671 a5728081 Guido Trotter
ENFORCEABLE_TYPES = frozenset([
672 21daa4a8 Stephen Shirley
  VTYPE_STRING,
673 21daa4a8 Stephen Shirley
  VTYPE_MAYBE_STRING,
674 21daa4a8 Stephen Shirley
  VTYPE_BOOL,
675 21daa4a8 Stephen Shirley
  VTYPE_SIZE,
676 21daa4a8 Stephen Shirley
  VTYPE_INT,
677 21daa4a8 Stephen Shirley
  ])
678 a5728081 Guido Trotter
679 b1cb62bd Andrea Spadaccini
# Constant representing that the user does not specify any IP version
680 b1cb62bd Andrea Spadaccini
IFACE_NO_IP_VERSION_SPECIFIED = 0
681 b1cb62bd Andrea Spadaccini
682 e64b8beb Iustin Pop
# HV parameter names (global namespace)
683 e64b8beb Iustin Pop
HV_BOOT_ORDER = "boot_order"
684 e64b8beb Iustin Pop
HV_CDROM_IMAGE_PATH = "cdrom_image_path"
685 cc130cc7 Marco Casavecchia
HV_KVM_CDROM2_IMAGE_PATH = "cdrom2_image_path"
686 cc130cc7 Marco Casavecchia
HV_KVM_FLOPPY_IMAGE_PATH = "floppy_image_path"
687 e64b8beb Iustin Pop
HV_NIC_TYPE = "nic_type"
688 e64b8beb Iustin Pop
HV_DISK_TYPE = "disk_type"
689 cc130cc7 Marco Casavecchia
HV_KVM_CDROM_DISK_TYPE = "cdrom_disk_type"
690 e64b8beb Iustin Pop
HV_VNC_BIND_ADDRESS = "vnc_bind_address"
691 6e6bb8d5 Guido Trotter
HV_VNC_PASSWORD_FILE = "vnc_password_file"
692 8b2d1013 Guido Trotter
HV_VNC_TLS = "vnc_tls"
693 8b2d1013 Guido Trotter
HV_VNC_X509 = "vnc_x509_path"
694 8b2d1013 Guido Trotter
HV_VNC_X509_VERIFY = "vnc_x509_verify"
695 b1cb62bd Andrea Spadaccini
HV_KVM_SPICE_BIND = "spice_bind"
696 b1cb62bd Andrea Spadaccini
HV_KVM_SPICE_IP_VERSION = "spice_ip_version"
697 b451c4c7 Andrea Spadaccini
HV_KVM_SPICE_PASSWORD_FILE = "spice_password_file"
698 ea064d24 Andrea Spadaccini
HV_KVM_SPICE_LOSSLESS_IMG_COMPR = "spice_image_compression"
699 ea064d24 Andrea Spadaccini
HV_KVM_SPICE_JPEG_IMG_COMPR = "spice_jpeg_wan_compression"
700 ea064d24 Andrea Spadaccini
HV_KVM_SPICE_ZLIB_GLZ_IMG_COMPR = "spice_zlib_glz_wan_compression"
701 ea064d24 Andrea Spadaccini
HV_KVM_SPICE_STREAMING_VIDEO_DETECTION = "spice_streaming_video"
702 ea064d24 Andrea Spadaccini
HV_KVM_SPICE_AUDIO_COMPR = "spice_playback_compression"
703 e64b8beb Iustin Pop
HV_ACPI = "acpi"
704 e64b8beb Iustin Pop
HV_PAE = "pae"
705 2f2dbb4b Jun Futagawa
HV_USE_BOOTLOADER = "use_bootloader"
706 2f2dbb4b Jun Futagawa
HV_BOOTLOADER_ARGS = "bootloader_args"
707 2f2dbb4b Jun Futagawa
HV_BOOTLOADER_PATH = "bootloader_path"
708 f9d6542d Iustin Pop
HV_KERNEL_ARGS = "kernel_args"
709 e64b8beb Iustin Pop
HV_KERNEL_PATH = "kernel_path"
710 e64b8beb Iustin Pop
HV_INITRD_PATH = "initrd_path"
711 074ca009 Guido Trotter
HV_ROOT_PATH = "root_path"
712 a2faf9ee Guido Trotter
HV_SERIAL_CONSOLE = "serial_console"
713 11344a50 Guido Trotter
HV_USB_MOUSE = "usb_mouse"
714 4f580fef Sébastien Bocahu
HV_KEYMAP = "keymap"
715 09ea8710 Iustin Pop
HV_DEVICE_MODEL = "device_model"
716 48297fa2 Iustin Pop
HV_INIT_SCRIPT = "init_script"
717 78411c60 Iustin Pop
HV_MIGRATION_PORT = "migration_port"
718 e43d4f9f Apollon Oikonomopoulos
HV_MIGRATION_BANDWIDTH = "migration_bandwidth"
719 e43d4f9f Apollon Oikonomopoulos
HV_MIGRATION_DOWNTIME = "migration_downtime"
720 783a6c0b Iustin Pop
HV_MIGRATION_MODE = "migration_mode"
721 6b970cef Jun Futagawa
HV_USE_LOCALTIME = "use_localtime"
722 ea0f3d7a Iustin Pop
HV_DISK_CACHE = "disk_cache"
723 3424767f Guido Trotter
HV_SECURITY_MODEL = "security_model"
724 3424767f Guido Trotter
HV_SECURITY_DOMAIN = "security_domain"
725 7ba594c0 Guido Trotter
HV_KVM_FLAG = "kvm_flag"
726 fbe27e2b Guido Trotter
HV_VHOST_NET = "vhost_net"
727 84c08e4e Balazs Lecz
HV_KVM_USE_CHROOT = "use_chroot"
728 e3ed5316 Balazs Lecz
HV_CPU_MASK = "cpu_mask"
729 4f958b0b Miguel Di Ciurcio Filho
HV_MEM_PATH = "mem_path"
730 525011bc Maciej Bliziński
HV_BLOCKDEV_PREFIX = "blockdev_prefix"
731 990ade2d Stephen Shirley
HV_REBOOT_BEHAVIOR = "reboot_behavior"
732 e64b8beb Iustin Pop
733 a5728081 Guido Trotter
HVS_PARAMETER_TYPES = {
734 a5728081 Guido Trotter
  HV_BOOT_ORDER: VTYPE_STRING,
735 cc130cc7 Marco Casavecchia
  HV_KVM_FLOPPY_IMAGE_PATH: VTYPE_STRING,
736 a5728081 Guido Trotter
  HV_CDROM_IMAGE_PATH: VTYPE_STRING,
737 cc130cc7 Marco Casavecchia
  HV_KVM_CDROM2_IMAGE_PATH: VTYPE_STRING,
738 a5728081 Guido Trotter
  HV_NIC_TYPE: VTYPE_STRING,
739 a5728081 Guido Trotter
  HV_DISK_TYPE: VTYPE_STRING,
740 cc130cc7 Marco Casavecchia
  HV_KVM_CDROM_DISK_TYPE: VTYPE_STRING,
741 6e6bb8d5 Guido Trotter
  HV_VNC_PASSWORD_FILE: VTYPE_STRING,
742 a5728081 Guido Trotter
  HV_VNC_BIND_ADDRESS: VTYPE_STRING,
743 a5728081 Guido Trotter
  HV_VNC_TLS: VTYPE_BOOL,
744 a5728081 Guido Trotter
  HV_VNC_X509: VTYPE_STRING,
745 a5728081 Guido Trotter
  HV_VNC_X509_VERIFY: VTYPE_BOOL,
746 b1cb62bd Andrea Spadaccini
  HV_KVM_SPICE_BIND: VTYPE_STRING,
747 b1cb62bd Andrea Spadaccini
  HV_KVM_SPICE_IP_VERSION: VTYPE_INT,
748 b451c4c7 Andrea Spadaccini
  HV_KVM_SPICE_PASSWORD_FILE: VTYPE_STRING,
749 ea064d24 Andrea Spadaccini
  HV_KVM_SPICE_LOSSLESS_IMG_COMPR: VTYPE_STRING,
750 ea064d24 Andrea Spadaccini
  HV_KVM_SPICE_JPEG_IMG_COMPR: VTYPE_STRING,
751 ea064d24 Andrea Spadaccini
  HV_KVM_SPICE_ZLIB_GLZ_IMG_COMPR: VTYPE_STRING,
752 ea064d24 Andrea Spadaccini
  HV_KVM_SPICE_STREAMING_VIDEO_DETECTION: VTYPE_STRING,
753 ea064d24 Andrea Spadaccini
  HV_KVM_SPICE_AUDIO_COMPR: VTYPE_BOOL,
754 a5728081 Guido Trotter
  HV_ACPI: VTYPE_BOOL,
755 a5728081 Guido Trotter
  HV_PAE: VTYPE_BOOL,
756 2f2dbb4b Jun Futagawa
  HV_USE_BOOTLOADER: VTYPE_BOOL,
757 2f2dbb4b Jun Futagawa
  HV_BOOTLOADER_PATH: VTYPE_STRING,
758 2f2dbb4b Jun Futagawa
  HV_BOOTLOADER_ARGS: VTYPE_STRING,
759 a5728081 Guido Trotter
  HV_KERNEL_PATH: VTYPE_STRING,
760 f9d6542d Iustin Pop
  HV_KERNEL_ARGS: VTYPE_STRING,
761 a5728081 Guido Trotter
  HV_INITRD_PATH: VTYPE_STRING,
762 7adf7814 René Nussbaumer
  HV_ROOT_PATH: VTYPE_MAYBE_STRING,
763 a5728081 Guido Trotter
  HV_SERIAL_CONSOLE: VTYPE_BOOL,
764 a5728081 Guido Trotter
  HV_USB_MOUSE: VTYPE_STRING,
765 4f580fef Sébastien Bocahu
  HV_KEYMAP: VTYPE_STRING,
766 09ea8710 Iustin Pop
  HV_DEVICE_MODEL: VTYPE_STRING,
767 48297fa2 Iustin Pop
  HV_INIT_SCRIPT: VTYPE_STRING,
768 78411c60 Iustin Pop
  HV_MIGRATION_PORT: VTYPE_INT,
769 e43d4f9f Apollon Oikonomopoulos
  HV_MIGRATION_BANDWIDTH: VTYPE_INT,
770 e43d4f9f Apollon Oikonomopoulos
  HV_MIGRATION_DOWNTIME: VTYPE_INT,
771 783a6c0b Iustin Pop
  HV_MIGRATION_MODE: VTYPE_STRING,
772 6b970cef Jun Futagawa
  HV_USE_LOCALTIME: VTYPE_BOOL,
773 ea0f3d7a Iustin Pop
  HV_DISK_CACHE: VTYPE_STRING,
774 3424767f Guido Trotter
  HV_SECURITY_MODEL: VTYPE_STRING,
775 3424767f Guido Trotter
  HV_SECURITY_DOMAIN: VTYPE_STRING,
776 7ba594c0 Guido Trotter
  HV_KVM_FLAG: VTYPE_STRING,
777 fbe27e2b Guido Trotter
  HV_VHOST_NET: VTYPE_BOOL,
778 84c08e4e Balazs Lecz
  HV_KVM_USE_CHROOT: VTYPE_BOOL,
779 e3ed5316 Balazs Lecz
  HV_CPU_MASK: VTYPE_STRING,
780 4f958b0b Miguel Di Ciurcio Filho
  HV_MEM_PATH: VTYPE_STRING,
781 525011bc Maciej Bliziński
  HV_BLOCKDEV_PREFIX: VTYPE_STRING,
782 990ade2d Stephen Shirley
  HV_REBOOT_BEHAVIOR: VTYPE_STRING,
783 a5728081 Guido Trotter
  }
784 a5728081 Guido Trotter
785 a5728081 Guido Trotter
HVS_PARAMETERS = frozenset(HVS_PARAMETER_TYPES.keys())
786 5018a335 Iustin Pop
787 3d5ebbf0 Stephen Shirley
# Backend parameter names
788 cd3ab26e Iustin Pop
BE_MEMORY = "memory"
789 e64b8beb Iustin Pop
BE_VCPUS = "vcpus"
790 c0f2b229 Iustin Pop
BE_AUTO_BALANCE = "auto_balance"
791 e64b8beb Iustin Pop
792 a5728081 Guido Trotter
BES_PARAMETER_TYPES = {
793 a5728081 Guido Trotter
    BE_MEMORY: VTYPE_SIZE,
794 a5728081 Guido Trotter
    BE_VCPUS: VTYPE_INT,
795 a5728081 Guido Trotter
    BE_AUTO_BALANCE: VTYPE_BOOL,
796 a5728081 Guido Trotter
    }
797 a5728081 Guido Trotter
798 a5728081 Guido Trotter
BES_PARAMETERS = frozenset(BES_PARAMETER_TYPES.keys())
799 cd3ab26e Iustin Pop
800 095e71aa René Nussbaumer
# Node parameter names
801 095e71aa René Nussbaumer
ND_OOB_PROGRAM = "oob_program"
802 095e71aa René Nussbaumer
803 095e71aa René Nussbaumer
NDS_PARAMETER_TYPES = {
804 095e71aa René Nussbaumer
    ND_OOB_PROGRAM: VTYPE_MAYBE_STRING,
805 095e71aa René Nussbaumer
    }
806 095e71aa René Nussbaumer
807 095e71aa René Nussbaumer
NDS_PARAMETERS = frozenset(NDS_PARAMETER_TYPES.keys())
808 095e71aa René Nussbaumer
809 b2f29800 René Nussbaumer
# OOB supported commands
810 b2f29800 René Nussbaumer
OOB_POWER_ON = "power-on"
811 b2f29800 René Nussbaumer
OOB_POWER_OFF = "power-off"
812 b2f29800 René Nussbaumer
OOB_POWER_CYCLE = "power-cycle"
813 b2f29800 René Nussbaumer
OOB_POWER_STATUS = "power-status"
814 b2f29800 René Nussbaumer
OOB_HEALTH = "health"
815 b2f29800 René Nussbaumer
816 21daa4a8 Stephen Shirley
OOB_COMMANDS = frozenset([
817 21daa4a8 Stephen Shirley
  OOB_POWER_ON,
818 21daa4a8 Stephen Shirley
  OOB_POWER_OFF,
819 21daa4a8 Stephen Shirley
  OOB_POWER_CYCLE,
820 21daa4a8 Stephen Shirley
  OOB_POWER_STATUS,
821 21daa4a8 Stephen Shirley
  OOB_HEALTH
822 21daa4a8 Stephen Shirley
  ])
823 b2f29800 René Nussbaumer
824 b528a12d René Nussbaumer
OOB_POWER_STATUS_POWERED = "powered"
825 b528a12d René Nussbaumer
826 445f735d René Nussbaumer
OOB_TIMEOUT = 60 # 60 seconds
827 beff3779 René Nussbaumer
OOB_POWER_DELAY = 2.0 # 2 seconds
828 445f735d René Nussbaumer
829 445f735d René Nussbaumer
OOB_STATUS_OK = "OK"
830 445f735d René Nussbaumer
OOB_STATUS_WARNING = "WARNING"
831 445f735d René Nussbaumer
OOB_STATUS_CRITICAL = "CRITICAL"
832 445f735d René Nussbaumer
OOB_STATUS_UNKNOWN = "UNKNOWN"
833 445f735d René Nussbaumer
834 445f735d René Nussbaumer
OOB_STATUSES = frozenset([
835 445f735d René Nussbaumer
  OOB_STATUS_OK,
836 445f735d René Nussbaumer
  OOB_STATUS_WARNING,
837 445f735d René Nussbaumer
  OOB_STATUS_CRITICAL,
838 445f735d René Nussbaumer
  OOB_STATUS_UNKNOWN,
839 445f735d René Nussbaumer
  ])
840 445f735d René Nussbaumer
841 4ef7f423 Guido Trotter
# Instance Parameters Profile
842 4ef7f423 Guido Trotter
PP_DEFAULT = "default"
843 e64b8beb Iustin Pop
844 246f4067 Guido Trotter
# NIC_* constants are used inside the ganeti config
845 ac061be9 Guido Trotter
NIC_MODE = "mode"
846 ac061be9 Guido Trotter
NIC_LINK = "link"
847 ac061be9 Guido Trotter
848 ac061be9 Guido Trotter
NIC_MODE_BRIDGED = "bridged"
849 ac061be9 Guido Trotter
NIC_MODE_ROUTED = "routed"
850 ac061be9 Guido Trotter
851 ac061be9 Guido Trotter
NIC_VALID_MODES = frozenset([NIC_MODE_BRIDGED, NIC_MODE_ROUTED])
852 ac061be9 Guido Trotter
853 ac061be9 Guido Trotter
NICS_PARAMETER_TYPES = {
854 ac061be9 Guido Trotter
    NIC_MODE: VTYPE_STRING,
855 ac061be9 Guido Trotter
    NIC_LINK: VTYPE_STRING,
856 ac061be9 Guido Trotter
    }
857 ac061be9 Guido Trotter
858 ac061be9 Guido Trotter
NICS_PARAMETERS = frozenset(NICS_PARAMETER_TYPES.keys())
859 e64b8beb Iustin Pop
860 246f4067 Guido Trotter
# IDISK_* constants are used in opcodes, to create/change disks
861 bd061c35 Guido Trotter
IDISK_SIZE = "size"
862 bd061c35 Guido Trotter
IDISK_MODE = "mode"
863 8494604f Apollon Oikonomopoulos
IDISK_ADOPT = "adopt"
864 7af3534e Dmitry Chernyak
IDISK_VG = "vg"
865 87001920 Iustin Pop
IDISK_METAVG = "metavg"
866 8494604f Apollon Oikonomopoulos
IDISK_PARAMS_TYPES = {
867 8494604f Apollon Oikonomopoulos
  IDISK_SIZE: VTYPE_SIZE,
868 8494604f Apollon Oikonomopoulos
  IDISK_MODE: VTYPE_STRING,
869 8494604f Apollon Oikonomopoulos
  IDISK_ADOPT: VTYPE_STRING,
870 7af3534e Dmitry Chernyak
  IDISK_VG: VTYPE_STRING,
871 87001920 Iustin Pop
  IDISK_METAVG: VTYPE_STRING,
872 8494604f Apollon Oikonomopoulos
  }
873 cc87d736 Michael Hanselmann
IDISK_PARAMS = frozenset(IDISK_PARAMS_TYPES.keys())
874 cc87d736 Michael Hanselmann
875 246f4067 Guido Trotter
# INIC_* constants are used in opcodes, to create/change nics
876 bd061c35 Guido Trotter
INIC_MAC = "mac"
877 bd061c35 Guido Trotter
INIC_IP = "ip"
878 bd061c35 Guido Trotter
INIC_MODE = "mode"
879 bd061c35 Guido Trotter
INIC_LINK = "link"
880 cc87d736 Michael Hanselmann
INIC_PARAMS_TYPES = {
881 cc87d736 Michael Hanselmann
  INIC_IP: VTYPE_MAYBE_STRING,
882 cc87d736 Michael Hanselmann
  INIC_LINK: VTYPE_STRING,
883 cc87d736 Michael Hanselmann
  INIC_MAC: VTYPE_STRING,
884 cc87d736 Michael Hanselmann
  INIC_MODE: VTYPE_STRING,
885 cc87d736 Michael Hanselmann
  }
886 cc87d736 Michael Hanselmann
INIC_PARAMS = frozenset(INIC_PARAMS_TYPES.keys())
887 bd061c35 Guido Trotter
888 2584d4a4 Alexander Schreiber
# Hypervisor constants
889 00cd937c Iustin Pop
HT_XEN_PVM = "xen-pvm"
890 2584d4a4 Alexander Schreiber
HT_FAKE = "fake"
891 00cd937c Iustin Pop
HT_XEN_HVM = "xen-hvm"
892 550e49b9 Guido Trotter
HT_KVM = "kvm"
893 48297fa2 Iustin Pop
HT_CHROOT = "chroot"
894 4b5e40a5 Iustin Pop
HT_LXC = "lxc"
895 4b5e40a5 Iustin Pop
HYPER_TYPES = frozenset([
896 4b5e40a5 Iustin Pop
  HT_XEN_PVM,
897 4b5e40a5 Iustin Pop
  HT_FAKE,
898 4b5e40a5 Iustin Pop
  HT_XEN_HVM,
899 4b5e40a5 Iustin Pop
  HT_KVM,
900 4b5e40a5 Iustin Pop
  HT_CHROOT,
901 4b5e40a5 Iustin Pop
  HT_LXC,
902 4b5e40a5 Iustin Pop
  ])
903 fd4daa3a Guido Trotter
HTS_REQ_PORT = frozenset([HT_XEN_HVM, HT_KVM])
904 2584d4a4 Alexander Schreiber
905 377d74c9 Guido Trotter
VNC_BASE_PORT = 5900
906 131178b9 Luca Bigliardi
VNC_PASSWORD_FILE = CONF_DIR + "/vnc-cluster-password"
907 0d2cd893 Manuel Franceschini
VNC_DEFAULT_BIND_ADDRESS = IP4_ADDRESS_ANY
908 e54c4c5e Guido Trotter
909 835528af Iustin Pop
# NIC types
910 d08f6067 Guido Trotter
HT_NIC_RTL8139 = "rtl8139"
911 d08f6067 Guido Trotter
HT_NIC_NE2K_PCI = "ne2k_pci"
912 d08f6067 Guido Trotter
HT_NIC_NE2K_ISA = "ne2k_isa"
913 43440815 Guido Trotter
HT_NIC_I82551 = "i82551"
914 43440815 Guido Trotter
HT_NIC_I85557B = "i82557b"
915 43440815 Guido Trotter
HT_NIC_I8259ER = "i82559er"
916 43440815 Guido Trotter
HT_NIC_PCNET = "pcnet"
917 43440815 Guido Trotter
HT_NIC_E1000 = "e1000"
918 d08f6067 Guido Trotter
HT_NIC_PARAVIRTUAL = HT_DISK_PARAVIRTUAL = "paravirtual"
919 43440815 Guido Trotter
920 21daa4a8 Stephen Shirley
HT_HVM_VALID_NIC_TYPES = frozenset([
921 21daa4a8 Stephen Shirley
  HT_NIC_RTL8139,
922 21daa4a8 Stephen Shirley
  HT_NIC_NE2K_PCI,
923 21daa4a8 Stephen Shirley
  HT_NIC_E1000,
924 21daa4a8 Stephen Shirley
  HT_NIC_NE2K_ISA,
925 21daa4a8 Stephen Shirley
  HT_NIC_PARAVIRTUAL
926 21daa4a8 Stephen Shirley
  ])
927 21daa4a8 Stephen Shirley
HT_KVM_VALID_NIC_TYPES = frozenset([
928 21daa4a8 Stephen Shirley
  HT_NIC_RTL8139,
929 21daa4a8 Stephen Shirley
  HT_NIC_NE2K_PCI,
930 21daa4a8 Stephen Shirley
  HT_NIC_NE2K_ISA,
931 21daa4a8 Stephen Shirley
  HT_NIC_I82551,
932 21daa4a8 Stephen Shirley
  HT_NIC_I85557B,
933 21daa4a8 Stephen Shirley
  HT_NIC_I8259ER,
934 21daa4a8 Stephen Shirley
  HT_NIC_PCNET,
935 21daa4a8 Stephen Shirley
  HT_NIC_E1000,
936 21daa4a8 Stephen Shirley
  HT_NIC_PARAVIRTUAL
937 21daa4a8 Stephen Shirley
  ])
938 21daa4a8 Stephen Shirley
939 835528af Iustin Pop
# Disk types
940 835528af Iustin Pop
HT_DISK_IOEMU = "ioemu"
941 835528af Iustin Pop
HT_DISK_IDE = "ide"
942 835528af Iustin Pop
HT_DISK_SCSI = "scsi"
943 835528af Iustin Pop
HT_DISK_SD = "sd"
944 835528af Iustin Pop
HT_DISK_MTD = "mtd"
945 835528af Iustin Pop
HT_DISK_PFLASH = "pflash"
946 835528af Iustin Pop
947 ea0f3d7a Iustin Pop
HT_CACHE_DEFAULT = "default"
948 ea0f3d7a Iustin Pop
HT_CACHE_NONE = "none"
949 ea0f3d7a Iustin Pop
HT_CACHE_WTHROUGH = "writethrough"
950 ea0f3d7a Iustin Pop
HT_CACHE_WBACK = "writeback"
951 21daa4a8 Stephen Shirley
HT_VALID_CACHE_TYPES = frozenset([
952 21daa4a8 Stephen Shirley
  HT_CACHE_DEFAULT,
953 21daa4a8 Stephen Shirley
  HT_CACHE_NONE,
954 21daa4a8 Stephen Shirley
  HT_CACHE_WTHROUGH,
955 21daa4a8 Stephen Shirley
  HT_CACHE_WBACK
956 21daa4a8 Stephen Shirley
  ])
957 ea0f3d7a Iustin Pop
958 835528af Iustin Pop
HT_HVM_VALID_DISK_TYPES = frozenset([HT_DISK_PARAVIRTUAL, HT_DISK_IOEMU])
959 21daa4a8 Stephen Shirley
HT_KVM_VALID_DISK_TYPES = frozenset([
960 21daa4a8 Stephen Shirley
  HT_DISK_PARAVIRTUAL,
961 21daa4a8 Stephen Shirley
  HT_DISK_IDE,
962 21daa4a8 Stephen Shirley
  HT_DISK_SCSI,
963 21daa4a8 Stephen Shirley
  HT_DISK_SD,
964 21daa4a8 Stephen Shirley
  HT_DISK_MTD,
965 21daa4a8 Stephen Shirley
  HT_DISK_PFLASH
966 21daa4a8 Stephen Shirley
  ])
967 b894f5a8 Alexander Schreiber
968 835528af Iustin Pop
# Mouse types:
969 835528af Iustin Pop
HT_MOUSE_MOUSE = "mouse"
970 835528af Iustin Pop
HT_MOUSE_TABLET = "tablet"
971 835528af Iustin Pop
972 835528af Iustin Pop
HT_KVM_VALID_MOUSE_TYPES = frozenset([HT_MOUSE_MOUSE, HT_MOUSE_TABLET])
973 835528af Iustin Pop
974 835528af Iustin Pop
# Boot order
975 cc130cc7 Marco Casavecchia
HT_BO_FLOPPY = "floppy"
976 835528af Iustin Pop
HT_BO_CDROM = "cdrom"
977 835528af Iustin Pop
HT_BO_DISK = "disk"
978 835528af Iustin Pop
HT_BO_NETWORK = "network"
979 835528af Iustin Pop
980 21daa4a8 Stephen Shirley
HT_KVM_VALID_BO_TYPES = frozenset([
981 21daa4a8 Stephen Shirley
  HT_BO_FLOPPY,
982 21daa4a8 Stephen Shirley
  HT_BO_CDROM,
983 21daa4a8 Stephen Shirley
  HT_BO_DISK,
984 21daa4a8 Stephen Shirley
  HT_BO_NETWORK
985 21daa4a8 Stephen Shirley
  ])
986 835528af Iustin Pop
987 ea064d24 Andrea Spadaccini
# SPICE lossless image compression options
988 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSLESS_IMG_COMPR_AUTO_GLZ = "auto_glz"
989 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSLESS_IMG_COMPR_AUTO_LZ = "auto_lz"
990 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSLESS_IMG_COMPR_QUIC = "quic"
991 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSLESS_IMG_COMPR_GLZ = "glz"
992 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSLESS_IMG_COMPR_LZ = "lz"
993 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSLESS_IMG_COMPR_OFF = "off"
994 ea064d24 Andrea Spadaccini
995 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_VALID_LOSSLESS_IMG_COMPR_OPTIONS = frozenset([
996 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSLESS_IMG_COMPR_AUTO_GLZ,
997 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSLESS_IMG_COMPR_AUTO_LZ,
998 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSLESS_IMG_COMPR_QUIC,
999 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSLESS_IMG_COMPR_GLZ,
1000 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSLESS_IMG_COMPR_LZ,
1001 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSLESS_IMG_COMPR_OFF,
1002 ea064d24 Andrea Spadaccini
  ])
1003 ea064d24 Andrea Spadaccini
1004 ea064d24 Andrea Spadaccini
# SPICE lossy image compression options (valid for both jpeg and zlib-glz)
1005 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSY_IMG_COMPR_AUTO = "auto"
1006 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSY_IMG_COMPR_NEVER = "never"
1007 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_LOSSY_IMG_COMPR_ALWAYS = "always"
1008 ea064d24 Andrea Spadaccini
1009 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_VALID_LOSSY_IMG_COMPR_OPTIONS = frozenset([
1010 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSY_IMG_COMPR_AUTO,
1011 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSY_IMG_COMPR_NEVER,
1012 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_LOSSY_IMG_COMPR_ALWAYS,
1013 ea064d24 Andrea Spadaccini
  ])
1014 ea064d24 Andrea Spadaccini
1015 ea064d24 Andrea Spadaccini
# SPICE video stream detection
1016 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_VIDEO_STREAM_DETECTION_OFF = "off"
1017 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_VIDEO_STREAM_DETECTION_ALL = "all"
1018 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_VIDEO_STREAM_DETECTION_FILTER = "filter"
1019 ea064d24 Andrea Spadaccini
1020 ea064d24 Andrea Spadaccini
HT_KVM_SPICE_VALID_VIDEO_STREAM_DETECTION_OPTIONS = frozenset([
1021 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_VIDEO_STREAM_DETECTION_OFF,
1022 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_VIDEO_STREAM_DETECTION_ALL,
1023 ea064d24 Andrea Spadaccini
  HT_KVM_SPICE_VIDEO_STREAM_DETECTION_FILTER,
1024 ea064d24 Andrea Spadaccini
  ])
1025 ea064d24 Andrea Spadaccini
1026 3424767f Guido Trotter
# Security models
1027 3424767f Guido Trotter
HT_SM_NONE = "none"
1028 3424767f Guido Trotter
HT_SM_USER = "user"
1029 3424767f Guido Trotter
HT_SM_POOL = "pool"
1030 3424767f Guido Trotter
1031 3424767f Guido Trotter
HT_KVM_VALID_SM_TYPES = frozenset([HT_SM_NONE, HT_SM_USER, HT_SM_POOL])
1032 3424767f Guido Trotter
1033 7ba594c0 Guido Trotter
# Kvm flag values
1034 7ba594c0 Guido Trotter
HT_KVM_ENABLED = "enabled"
1035 7ba594c0 Guido Trotter
HT_KVM_DISABLED = "disabled"
1036 7ba594c0 Guido Trotter
1037 7ba594c0 Guido Trotter
HT_KVM_FLAG_VALUES = frozenset([HT_KVM_ENABLED, HT_KVM_DISABLED])
1038 7ba594c0 Guido Trotter
1039 e71b9ef4 Iustin Pop
# Migration type
1040 e71b9ef4 Iustin Pop
HT_MIGRATION_LIVE = "live"
1041 e71b9ef4 Iustin Pop
HT_MIGRATION_NONLIVE = "non-live"
1042 783a6c0b Iustin Pop
HT_MIGRATION_MODES = frozenset([HT_MIGRATION_LIVE, HT_MIGRATION_NONLIVE])
1043 e71b9ef4 Iustin Pop
1044 e54c4c5e Guido Trotter
# Cluster Verify steps
1045 d0c8c01d Iustin Pop
VERIFY_NPLUSONE_MEM = "nplusone_mem"
1046 e54c4c5e Guido Trotter
VERIFY_OPTIONAL_CHECKS = frozenset([VERIFY_NPLUSONE_MEM])
1047 e54c4c5e Guido Trotter
1048 25361b9a Iustin Pop
# Node verify constants
1049 7ef40fbe Luca Bigliardi
NV_DRBDHELPER = "drbd-helper"
1050 b0d85178 Iustin Pop
NV_DRBDLIST = "drbd-list"
1051 25361b9a Iustin Pop
NV_FILELIST = "filelist"
1052 25361b9a Iustin Pop
NV_HVINFO = "hvinfo"
1053 25361b9a Iustin Pop
NV_HYPERVISOR = "hypervisor"
1054 58a59652 Iustin Pop
NV_HVPARAMS = "hvparms"
1055 25361b9a Iustin Pop
NV_INSTANCELIST = "instancelist"
1056 b0d85178 Iustin Pop
NV_LVLIST = "lvlist"
1057 b0d85178 Iustin Pop
NV_MASTERIP = "master-ip"
1058 25361b9a Iustin Pop
NV_NODELIST = "nodelist"
1059 25361b9a Iustin Pop
NV_NODENETTEST = "node-net-test"
1060 7c0aa8e9 Iustin Pop
NV_NODESETUP = "nodesetup"
1061 b0d85178 Iustin Pop
NV_OSLIST = "oslist"
1062 b0d85178 Iustin Pop
NV_PVLIST = "pvlist"
1063 313b2dd4 Michael Hanselmann
NV_TIME = "time"
1064 b0d85178 Iustin Pop
NV_VERSION = "version"
1065 b0d85178 Iustin Pop
NV_VGLIST = "vglist"
1066 8964ee14 Iustin Pop
NV_VMNODES = "vmnodes"
1067 16f41f24 René Nussbaumer
NV_OOB_PATHS = "oob-paths"
1068 20d317d4 Iustin Pop
NV_BRIDGES = "bridges"
1069 25361b9a Iustin Pop
1070 61a980a9 Michael Hanselmann
# Instance status
1071 61a980a9 Michael Hanselmann
INSTST_RUNNING = "running"
1072 61a980a9 Michael Hanselmann
INSTST_ADMINDOWN = "ADMIN_down"
1073 61a980a9 Michael Hanselmann
INSTST_NODEOFFLINE = "ERROR_nodeoffline"
1074 61a980a9 Michael Hanselmann
INSTST_NODEDOWN = "ERROR_nodedown"
1075 61a980a9 Michael Hanselmann
INSTST_WRONGNODE = "ERROR_wrongnode"
1076 61a980a9 Michael Hanselmann
INSTST_ERRORUP = "ERROR_up"
1077 61a980a9 Michael Hanselmann
INSTST_ERRORDOWN = "ERROR_down"
1078 61a980a9 Michael Hanselmann
INSTST_ALL = frozenset([
1079 61a980a9 Michael Hanselmann
  INSTST_RUNNING,
1080 61a980a9 Michael Hanselmann
  INSTST_ADMINDOWN,
1081 61a980a9 Michael Hanselmann
  INSTST_NODEOFFLINE,
1082 61a980a9 Michael Hanselmann
  INSTST_NODEDOWN,
1083 61a980a9 Michael Hanselmann
  INSTST_WRONGNODE,
1084 61a980a9 Michael Hanselmann
  INSTST_ERRORUP,
1085 61a980a9 Michael Hanselmann
  INSTST_ERRORDOWN,
1086 61a980a9 Michael Hanselmann
  ])
1087 61a980a9 Michael Hanselmann
1088 1e28e3b8 Michael Hanselmann
# Node roles
1089 1e28e3b8 Michael Hanselmann
NR_REGULAR = "R"
1090 1e28e3b8 Michael Hanselmann
NR_MASTER = "M"
1091 1e28e3b8 Michael Hanselmann
NR_MCANDIDATE = "C"
1092 1e28e3b8 Michael Hanselmann
NR_DRAINED = "D"
1093 1e28e3b8 Michael Hanselmann
NR_OFFLINE = "O"
1094 1e28e3b8 Michael Hanselmann
NR_ALL = frozenset([
1095 1e28e3b8 Michael Hanselmann
  NR_REGULAR,
1096 1e28e3b8 Michael Hanselmann
  NR_MASTER,
1097 1e28e3b8 Michael Hanselmann
  NR_MCANDIDATE,
1098 1e28e3b8 Michael Hanselmann
  NR_DRAINED,
1099 1e28e3b8 Michael Hanselmann
  NR_OFFLINE,
1100 1e28e3b8 Michael Hanselmann
  ])
1101 1e28e3b8 Michael Hanselmann
1102 b98bf262 Michael Hanselmann
# SSL certificate check constants (in days)
1103 b98bf262 Michael Hanselmann
SSL_CERT_EXPIRATION_WARN = 30
1104 b98bf262 Michael Hanselmann
SSL_CERT_EXPIRATION_ERROR = 7
1105 b98bf262 Michael Hanselmann
1106 d61df03e Iustin Pop
# Allocator framework constants
1107 77031881 Iustin Pop
IALLOCATOR_VERSION = 2
1108 298fe380 Iustin Pop
IALLOCATOR_DIR_IN = "in"
1109 298fe380 Iustin Pop
IALLOCATOR_DIR_OUT = "out"
1110 3636400f Iustin Pop
VALID_IALLOCATOR_DIRECTIONS = frozenset([
1111 3636400f Iustin Pop
  IALLOCATOR_DIR_IN,
1112 3636400f Iustin Pop
  IALLOCATOR_DIR_OUT,
1113 3636400f Iustin Pop
  ])
1114 298fe380 Iustin Pop
IALLOCATOR_MODE_ALLOC = "allocate"
1115 298fe380 Iustin Pop
IALLOCATOR_MODE_RELOC = "relocate"
1116 60152bbe Michael Hanselmann
IALLOCATOR_MODE_CHG_GROUP = "change-group"
1117 60152bbe Michael Hanselmann
IALLOCATOR_MODE_NODE_EVAC = "node-evacuate"
1118 3636400f Iustin Pop
VALID_IALLOCATOR_MODES = frozenset([
1119 3636400f Iustin Pop
  IALLOCATOR_MODE_ALLOC,
1120 3636400f Iustin Pop
  IALLOCATOR_MODE_RELOC,
1121 60152bbe Michael Hanselmann
  IALLOCATOR_MODE_CHG_GROUP,
1122 60152bbe Michael Hanselmann
  IALLOCATOR_MODE_NODE_EVAC,
1123 3636400f Iustin Pop
  ])
1124 298fe380 Iustin Pop
IALLOCATOR_SEARCH_PATH = _autoconf.IALLOCATOR_SEARCH_PATH
1125 5f33b613 Michael Hanselmann
1126 60152bbe Michael Hanselmann
IALLOCATOR_NEVAC_PRI = "primary-only"
1127 60152bbe Michael Hanselmann
IALLOCATOR_NEVAC_SEC = "secondary-only"
1128 60152bbe Michael Hanselmann
IALLOCATOR_NEVAC_ALL = "all"
1129 60152bbe Michael Hanselmann
IALLOCATOR_NEVAC_MODES = frozenset([
1130 60152bbe Michael Hanselmann
  IALLOCATOR_NEVAC_PRI,
1131 60152bbe Michael Hanselmann
  IALLOCATOR_NEVAC_SEC,
1132 60152bbe Michael Hanselmann
  IALLOCATOR_NEVAC_ALL,
1133 60152bbe Michael Hanselmann
  ])
1134 60152bbe Michael Hanselmann
1135 f1da30e6 Michael Hanselmann
# Job queue
1136 f1da30e6 Michael Hanselmann
JOB_QUEUE_VERSION = 1
1137 f1da30e6 Michael Hanselmann
JOB_QUEUE_LOCK_FILE = QUEUE_DIR + "/lock"
1138 f1da30e6 Michael Hanselmann
JOB_QUEUE_VERSION_FILE = QUEUE_DIR + "/version"
1139 f1da30e6 Michael Hanselmann
JOB_QUEUE_SERIAL_FILE = QUEUE_DIR + "/serial"
1140 0cb94105 Michael Hanselmann
JOB_QUEUE_ARCHIVE_DIR = QUEUE_DIR + "/archive"
1141 686d7433 Iustin Pop
JOB_QUEUE_DRAIN_FILE = QUEUE_DIR + "/drain"
1142 f87b405e Michael Hanselmann
JOB_QUEUE_SIZE_HARD_LIMIT = 5000
1143 c33549ef Guido Trotter
JOB_QUEUE_DIRS = [QUEUE_DIR, JOB_QUEUE_ARCHIVE_DIR]
1144 5bae14d9 Guido Trotter
JOB_QUEUE_DIRS_MODE = SECURE_DIR_MODE
1145 f1da30e6 Michael Hanselmann
1146 bac5ffc3 Oleksiy Mishchenko
JOB_ID_TEMPLATE = r"\d+"
1147 cb66225d Michael Hanselmann
JOB_FILE_RE = re.compile(r"^job-(%s)$" % JOB_ID_TEMPLATE)
1148 bac5ffc3 Oleksiy Mishchenko
1149 5c735209 Iustin Pop
# unchanged job return
1150 5c735209 Iustin Pop
JOB_NOTCHANGED = "nochange"
1151 5c735209 Iustin Pop
1152 5f33b613 Michael Hanselmann
# Job status
1153 5f33b613 Michael Hanselmann
JOB_STATUS_QUEUED = "queued"
1154 47099cd1 Michael Hanselmann
JOB_STATUS_WAITING = "waiting"
1155 fbf0262f Michael Hanselmann
JOB_STATUS_CANCELING = "canceling"
1156 5f33b613 Michael Hanselmann
JOB_STATUS_RUNNING = "running"
1157 5f33b613 Michael Hanselmann
JOB_STATUS_CANCELED = "canceled"
1158 5f33b613 Michael Hanselmann
JOB_STATUS_SUCCESS = "success"
1159 5f33b613 Michael Hanselmann
JOB_STATUS_ERROR = "error"
1160 989a8bee Michael Hanselmann
JOBS_FINALIZED = frozenset([
1161 989a8bee Michael Hanselmann
  JOB_STATUS_CANCELED,
1162 989a8bee Michael Hanselmann
  JOB_STATUS_SUCCESS,
1163 989a8bee Michael Hanselmann
  JOB_STATUS_ERROR,
1164 989a8bee Michael Hanselmann
  ])
1165 db5bce34 Michael Hanselmann
JOB_STATUS_ALL = frozenset([
1166 db5bce34 Michael Hanselmann
  JOB_STATUS_QUEUED,
1167 47099cd1 Michael Hanselmann
  JOB_STATUS_WAITING,
1168 db5bce34 Michael Hanselmann
  JOB_STATUS_CANCELING,
1169 db5bce34 Michael Hanselmann
  JOB_STATUS_RUNNING,
1170 db5bce34 Michael Hanselmann
  ]) | JOBS_FINALIZED
1171 5f33b613 Michael Hanselmann
1172 34327f51 Iustin Pop
# OpCode status
1173 34327f51 Iustin Pop
# not yet finalized
1174 5f33b613 Michael Hanselmann
OP_STATUS_QUEUED = "queued"
1175 47099cd1 Michael Hanselmann
OP_STATUS_WAITING = "waiting"
1176 fbf0262f Michael Hanselmann
OP_STATUS_CANCELING = "canceling"
1177 5f33b613 Michael Hanselmann
OP_STATUS_RUNNING = "running"
1178 34327f51 Iustin Pop
# finalized
1179 4cb1d919 Michael Hanselmann
OP_STATUS_CANCELED = "canceled"
1180 5f33b613 Michael Hanselmann
OP_STATUS_SUCCESS = "success"
1181 5f33b613 Michael Hanselmann
OP_STATUS_ERROR = "error"
1182 21daa4a8 Stephen Shirley
OPS_FINALIZED = frozenset([
1183 21daa4a8 Stephen Shirley
  OP_STATUS_CANCELED,
1184 21daa4a8 Stephen Shirley
  OP_STATUS_SUCCESS,
1185 21daa4a8 Stephen Shirley
  OP_STATUS_ERROR
1186 21daa4a8 Stephen Shirley
  ])
1187 f1048938 Iustin Pop
1188 e5d8774b Michael Hanselmann
# OpCode priority
1189 e5d8774b Michael Hanselmann
OP_PRIO_LOWEST = +19
1190 e5d8774b Michael Hanselmann
OP_PRIO_HIGHEST = -20
1191 e5d8774b Michael Hanselmann
1192 e5d8774b Michael Hanselmann
OP_PRIO_LOW = +10
1193 e5d8774b Michael Hanselmann
OP_PRIO_NORMAL = 0
1194 e5d8774b Michael Hanselmann
OP_PRIO_HIGH = -10
1195 e5d8774b Michael Hanselmann
1196 e71c8147 Michael Hanselmann
OP_PRIO_SUBMIT_VALID = frozenset([
1197 e71c8147 Michael Hanselmann
  OP_PRIO_LOW,
1198 e71c8147 Michael Hanselmann
  OP_PRIO_NORMAL,
1199 e71c8147 Michael Hanselmann
  OP_PRIO_HIGH,
1200 e71c8147 Michael Hanselmann
  ])
1201 e71c8147 Michael Hanselmann
1202 e5d8774b Michael Hanselmann
OP_PRIO_DEFAULT = OP_PRIO_NORMAL
1203 e5d8774b Michael Hanselmann
1204 f1048938 Iustin Pop
# Execution log types
1205 f1048938 Iustin Pop
ELOG_MESSAGE = "message"
1206 f1048938 Iustin Pop
ELOG_PROGRESS = "progress"
1207 9bf56d77 Michael Hanselmann
ELOG_REMOTE_IMPORT = "remote-import"
1208 e58f87a9 Michael Hanselmann
ELOG_JQUEUE_TEST = "jqueue-test"
1209 e58f87a9 Michael Hanselmann
1210 19ddc57a René Nussbaumer
# /etc/hosts modification
1211 19ddc57a René Nussbaumer
ETC_HOSTS_ADD = "add"
1212 19ddc57a René Nussbaumer
ETC_HOSTS_REMOVE = "remove"
1213 19ddc57a René Nussbaumer
1214 e58f87a9 Michael Hanselmann
# Job queue test
1215 e58f87a9 Michael Hanselmann
JQT_MSGPREFIX = "TESTMSG="
1216 e58f87a9 Michael Hanselmann
JQT_EXPANDNAMES = "expandnames"
1217 e58f87a9 Michael Hanselmann
JQT_EXEC = "exec"
1218 e58f87a9 Michael Hanselmann
JQT_LOGMSG = "logmsg"
1219 f99010b2 Michael Hanselmann
JQT_STARTMSG = "startmsg"
1220 e58f87a9 Michael Hanselmann
JQT_ALL = frozenset([
1221 e58f87a9 Michael Hanselmann
  JQT_EXPANDNAMES,
1222 e58f87a9 Michael Hanselmann
  JQT_EXEC,
1223 e58f87a9 Michael Hanselmann
  JQT_LOGMSG,
1224 f99010b2 Michael Hanselmann
  JQT_STARTMSG,
1225 e58f87a9 Michael Hanselmann
  ])
1226 d4104181 Iustin Pop
1227 4a917de6 Michael Hanselmann
# Query resources
1228 4a917de6 Michael Hanselmann
QR_INSTANCE = "instance"
1229 4a917de6 Michael Hanselmann
QR_NODE = "node"
1230 24d16f76 Michael Hanselmann
QR_LOCK = "lock"
1231 e070c663 Adeodato Simo
QR_GROUP = "group"
1232 be3a4b14 Michael Hanselmann
QR_OS = "os"
1233 4a917de6 Michael Hanselmann
1234 4a917de6 Michael Hanselmann
#: List of resources which can be queried using L{opcodes.OpQuery}
1235 abd66bf8 Michael Hanselmann
QR_VIA_OP = frozenset([QR_INSTANCE, QR_NODE, QR_GROUP, QR_OS])
1236 4a917de6 Michael Hanselmann
1237 3d5ebbf0 Stephen Shirley
#: List of resources which can be queried using Local UniX Interface
1238 abd66bf8 Michael Hanselmann
QR_VIA_LUXI = QR_VIA_OP.union([
1239 24d16f76 Michael Hanselmann
  QR_LOCK,
1240 28b71a76 Michael Hanselmann
  ])
1241 28b71a76 Michael Hanselmann
1242 abd66bf8 Michael Hanselmann
#: List of resources which can be queried using RAPI
1243 abd66bf8 Michael Hanselmann
QR_VIA_RAPI = QR_VIA_LUXI
1244 abd66bf8 Michael Hanselmann
1245 4a917de6 Michael Hanselmann
# Query field types
1246 4a917de6 Michael Hanselmann
QFT_UNKNOWN = "unknown"
1247 4a917de6 Michael Hanselmann
QFT_TEXT = "text"
1248 4a917de6 Michael Hanselmann
QFT_BOOL = "bool"
1249 4a917de6 Michael Hanselmann
QFT_NUMBER = "number"
1250 4a917de6 Michael Hanselmann
QFT_UNIT = "unit"
1251 4a917de6 Michael Hanselmann
QFT_TIMESTAMP = "timestamp"
1252 4a917de6 Michael Hanselmann
QFT_OTHER = "other"
1253 4a917de6 Michael Hanselmann
1254 4a917de6 Michael Hanselmann
#: All query field types
1255 4a917de6 Michael Hanselmann
QFT_ALL = frozenset([
1256 4a917de6 Michael Hanselmann
  QFT_UNKNOWN,
1257 4a917de6 Michael Hanselmann
  QFT_TEXT,
1258 4a917de6 Michael Hanselmann
  QFT_BOOL,
1259 4a917de6 Michael Hanselmann
  QFT_NUMBER,
1260 4a917de6 Michael Hanselmann
  QFT_UNIT,
1261 4a917de6 Michael Hanselmann
  QFT_TIMESTAMP,
1262 4a917de6 Michael Hanselmann
  QFT_OTHER,
1263 4a917de6 Michael Hanselmann
  ])
1264 4a917de6 Michael Hanselmann
1265 a6070ef7 Michael Hanselmann
# Query result field status (don't change or reuse values as they're used by
1266 a6070ef7 Michael Hanselmann
# clients)
1267 4a917de6 Michael Hanselmann
#: Normal field status
1268 cfb084ae René Nussbaumer
RS_NORMAL = 0
1269 4a917de6 Michael Hanselmann
#: Unknown field
1270 cfb084ae René Nussbaumer
RS_UNKNOWN = 1
1271 cfb084ae René Nussbaumer
#: No data (e.g. RPC error), can be used instead of L{RS_OFFLINE}
1272 cfb084ae René Nussbaumer
RS_NODATA = 2
1273 dcb9946c Iustin Pop
#: Value unavailable/unsupported for item; if this field is supported
1274 e18c6c47 Iustin Pop
#: but we cannot get the data for the moment, RS_NODATA or
1275 e18c6c47 Iustin Pop
#: RS_OFFLINE should be used
1276 cfb084ae René Nussbaumer
RS_UNAVAIL = 3
1277 a6070ef7 Michael Hanselmann
#: Resource marked offline
1278 cfb084ae René Nussbaumer
RS_OFFLINE = 4
1279 cfb084ae René Nussbaumer
1280 cfb084ae René Nussbaumer
RS_ALL = frozenset([
1281 cfb084ae René Nussbaumer
  RS_NORMAL,
1282 cfb084ae René Nussbaumer
  RS_UNKNOWN,
1283 cfb084ae René Nussbaumer
  RS_NODATA,
1284 cfb084ae René Nussbaumer
  RS_UNAVAIL,
1285 cfb084ae René Nussbaumer
  RS_OFFLINE,
1286 ee3aedff Michael Hanselmann
  ])
1287 ee3aedff Michael Hanselmann
1288 f0b1bafe Iustin Pop
#: Dictionary with special field cases and their verbose/terse formatting
1289 f0b1bafe Iustin Pop
RSS_DESCRIPTION = {
1290 f0b1bafe Iustin Pop
  RS_UNKNOWN: ("(unknown)", "??"),
1291 e687ec01 Michael Hanselmann
  RS_NODATA: ("(nodata)", "?"),
1292 f0b1bafe Iustin Pop
  RS_OFFLINE: ("(offline)", "*"),
1293 f0b1bafe Iustin Pop
  RS_UNAVAIL: ("(unavail)", "-"),
1294 f0b1bafe Iustin Pop
  }
1295 f0b1bafe Iustin Pop
1296 c5e489f7 Iustin Pop
# max dynamic devices
1297 24991749 Iustin Pop
MAX_NICS = 8
1298 24991749 Iustin Pop
MAX_DISKS = 16
1299 24991749 Iustin Pop
1300 93384844 Iustin Pop
# SSCONF keys
1301 93384844 Iustin Pop
SS_CLUSTER_NAME = "cluster_name"
1302 5d60b3bd Iustin Pop
SS_CLUSTER_TAGS = "cluster_tags"
1303 93384844 Iustin Pop
SS_FILE_STORAGE_DIR = "file_storage_dir"
1304 4b97f902 Apollon Oikonomopoulos
SS_SHARED_FILE_STORAGE_DIR = "shared_file_storage_dir"
1305 f56618e0 Iustin Pop
SS_MASTER_CANDIDATES = "master_candidates"
1306 8113a52e Luca Bigliardi
SS_MASTER_CANDIDATES_IPS = "master_candidates_ips"
1307 93384844 Iustin Pop
SS_MASTER_IP = "master_ip"
1308 93384844 Iustin Pop
SS_MASTER_NETDEV = "master_netdev"
1309 93384844 Iustin Pop
SS_MASTER_NODE = "master_node"
1310 93384844 Iustin Pop
SS_NODE_LIST = "node_list"
1311 f9780ccd Luca Bigliardi
SS_NODE_PRIMARY_IPS = "node_primary_ips"
1312 f9780ccd Luca Bigliardi
SS_NODE_SECONDARY_IPS = "node_secondary_ips"
1313 a3316e4a Iustin Pop
SS_OFFLINE_NODES = "offline_nodes"
1314 81a49123 Iustin Pop
SS_ONLINE_NODES = "online_nodes"
1315 868a98ca Manuel Franceschini
SS_PRIMARY_IP_FAMILY = "primary_ip_family"
1316 81a49123 Iustin Pop
SS_INSTANCE_LIST = "instance_list"
1317 8a113c7a Iustin Pop
SS_RELEASE_VERSION = "release_version"
1318 4f7a6a10 Iustin Pop
SS_HYPERVISOR_LIST = "hypervisor_list"
1319 5c465a95 Iustin Pop
SS_MAINTAIN_NODE_HEALTH = "maintain_node_health"
1320 0fbae49a Balazs Lecz
SS_UID_POOL = "uid_pool"
1321 6f076453 Guido Trotter
SS_NODEGROUPS = "nodegroups"
1322 93384844 Iustin Pop
1323 cd57bab6 Michael Hanselmann
SS_FILE_PERMS = 0444
1324 cd57bab6 Michael Hanselmann
1325 7888a614 Alexander Schreiber
# cluster wide default parameters
1326 7888a614 Alexander Schreiber
DEFAULT_ENABLED_HYPERVISOR = HT_XEN_PVM
1327 7888a614 Alexander Schreiber
1328 7888a614 Alexander Schreiber
HVC_DEFAULTS = {
1329 bd0ff7c2 Iustin Pop
  HT_XEN_PVM: {
1330 2f2dbb4b Jun Futagawa
    HV_USE_BOOTLOADER: False,
1331 2f2dbb4b Jun Futagawa
    HV_BOOTLOADER_PATH: XEN_BOOTLOADER,
1332 d0c8c01d Iustin Pop
    HV_BOOTLOADER_ARGS: "",
1333 bd0ff7c2 Iustin Pop
    HV_KERNEL_PATH: "/boot/vmlinuz-2.6-xenU",
1334 d0c8c01d Iustin Pop
    HV_INITRD_PATH: "",
1335 d0c8c01d Iustin Pop
    HV_ROOT_PATH: "/dev/sda1",
1336 d0c8c01d Iustin Pop
    HV_KERNEL_ARGS: "ro",
1337 78411c60 Iustin Pop
    HV_MIGRATION_PORT: 8002,
1338 783a6c0b Iustin Pop
    HV_MIGRATION_MODE: HT_MIGRATION_LIVE,
1339 525011bc Maciej Bliziński
    HV_BLOCKDEV_PREFIX: "sd",
1340 990ade2d Stephen Shirley
    HV_REBOOT_BEHAVIOR: INSTANCE_REBOOT_ALLOWED,
1341 7e7629c6 Tsachy Shacham
    HV_CPU_MASK: CPU_PINNING_ALL,
1342 bd0ff7c2 Iustin Pop
    },
1343 bd0ff7c2 Iustin Pop
  HT_XEN_HVM: {
1344 bd0ff7c2 Iustin Pop
    HV_BOOT_ORDER: "cd",
1345 d0c8c01d Iustin Pop
    HV_CDROM_IMAGE_PATH: "",
1346 d08f6067 Guido Trotter
    HV_NIC_TYPE: HT_NIC_RTL8139,
1347 43440815 Guido Trotter
    HV_DISK_TYPE: HT_DISK_PARAVIRTUAL,
1348 9769bb78 Manuel Franceschini
    HV_VNC_BIND_ADDRESS: IP4_ADDRESS_ANY,
1349 6e6bb8d5 Guido Trotter
    HV_VNC_PASSWORD_FILE: VNC_PASSWORD_FILE,
1350 bd0ff7c2 Iustin Pop
    HV_ACPI: True,
1351 bd0ff7c2 Iustin Pop
    HV_PAE: True,
1352 e2ee1cea Iustin Pop
    HV_KERNEL_PATH: "/usr/lib/xen/boot/hvmloader",
1353 09ea8710 Iustin Pop
    HV_DEVICE_MODEL: "/usr/lib/xen/bin/qemu-dm",
1354 78411c60 Iustin Pop
    HV_MIGRATION_PORT: 8002,
1355 783a6c0b Iustin Pop
    HV_MIGRATION_MODE: HT_MIGRATION_NONLIVE,
1356 6b970cef Jun Futagawa
    HV_USE_LOCALTIME: False,
1357 525011bc Maciej Bliziński
    HV_BLOCKDEV_PREFIX: "hd",
1358 990ade2d Stephen Shirley
    HV_REBOOT_BEHAVIOR: INSTANCE_REBOOT_ALLOWED,
1359 7e7629c6 Tsachy Shacham
    HV_CPU_MASK: CPU_PINNING_ALL,
1360 bd0ff7c2 Iustin Pop
    },
1361 bd0ff7c2 Iustin Pop
  HT_KVM: {
1362 bd0ff7c2 Iustin Pop
    HV_KERNEL_PATH: "/boot/vmlinuz-2.6-kvmU",
1363 d0c8c01d Iustin Pop
    HV_INITRD_PATH: "",
1364 d0c8c01d Iustin Pop
    HV_KERNEL_ARGS: "ro",
1365 d0c8c01d Iustin Pop
    HV_ROOT_PATH: "/dev/vda1",
1366 bd0ff7c2 Iustin Pop
    HV_ACPI: True,
1367 bd0ff7c2 Iustin Pop
    HV_SERIAL_CONSOLE: True,
1368 d0c8c01d Iustin Pop
    HV_VNC_BIND_ADDRESS: "",
1369 8b2d1013 Guido Trotter
    HV_VNC_TLS: False,
1370 d0c8c01d Iustin Pop
    HV_VNC_X509: "",
1371 8b2d1013 Guido Trotter
    HV_VNC_X509_VERIFY: False,
1372 d0c8c01d Iustin Pop
    HV_VNC_PASSWORD_FILE: "",
1373 b1cb62bd Andrea Spadaccini
    HV_KVM_SPICE_BIND: "",
1374 b1cb62bd Andrea Spadaccini
    HV_KVM_SPICE_IP_VERSION: IFACE_NO_IP_VERSION_SPECIFIED,
1375 b451c4c7 Andrea Spadaccini
    HV_KVM_SPICE_PASSWORD_FILE: "",
1376 ea064d24 Andrea Spadaccini
    HV_KVM_SPICE_LOSSLESS_IMG_COMPR: "",
1377 ea064d24 Andrea Spadaccini
    HV_KVM_SPICE_JPEG_IMG_COMPR: "",
1378 ea064d24 Andrea Spadaccini
    HV_KVM_SPICE_ZLIB_GLZ_IMG_COMPR: "",
1379 ea064d24 Andrea Spadaccini
    HV_KVM_SPICE_STREAMING_VIDEO_DETECTION: "",
1380 ea064d24 Andrea Spadaccini
    HV_KVM_SPICE_AUDIO_COMPR: True,
1381 d0c8c01d Iustin Pop
    HV_KVM_FLOPPY_IMAGE_PATH: "",
1382 d0c8c01d Iustin Pop
    HV_CDROM_IMAGE_PATH: "",
1383 d0c8c01d Iustin Pop
    HV_KVM_CDROM2_IMAGE_PATH: "",
1384 835528af Iustin Pop
    HV_BOOT_ORDER: HT_BO_DISK,
1385 43440815 Guido Trotter
    HV_NIC_TYPE: HT_NIC_PARAVIRTUAL,
1386 43440815 Guido Trotter
    HV_DISK_TYPE: HT_DISK_PARAVIRTUAL,
1387 d0c8c01d Iustin Pop
    HV_KVM_CDROM_DISK_TYPE: "",
1388 d0c8c01d Iustin Pop
    HV_USB_MOUSE: "",
1389 4f580fef Sébastien Bocahu
    HV_KEYMAP: "",
1390 3c075436 Iustin Pop
    HV_MIGRATION_PORT: 8102,
1391 e43d4f9f Apollon Oikonomopoulos
    HV_MIGRATION_BANDWIDTH: 32, # MiB/s
1392 e43d4f9f Apollon Oikonomopoulos
    HV_MIGRATION_DOWNTIME: 30,  # ms
1393 783a6c0b Iustin Pop
    HV_MIGRATION_MODE: HT_MIGRATION_LIVE,
1394 6b970cef Jun Futagawa
    HV_USE_LOCALTIME: False,
1395 ea0f3d7a Iustin Pop
    HV_DISK_CACHE: HT_CACHE_DEFAULT,
1396 d19d94db Guido Trotter
    HV_SECURITY_MODEL: HT_SM_NONE,
1397 d0c8c01d Iustin Pop
    HV_SECURITY_DOMAIN: "",
1398 7ba594c0 Guido Trotter
    HV_KVM_FLAG: "",
1399 fbe27e2b Guido Trotter
    HV_VHOST_NET: False,
1400 84c08e4e Balazs Lecz
    HV_KVM_USE_CHROOT: False,
1401 4f958b0b Miguel Di Ciurcio Filho
    HV_MEM_PATH: "",
1402 990ade2d Stephen Shirley
    HV_REBOOT_BEHAVIOR: INSTANCE_REBOOT_ALLOWED,
1403 7e7629c6 Tsachy Shacham
    HV_CPU_MASK: CPU_PINNING_ALL,
1404 bd0ff7c2 Iustin Pop
    },
1405 bd0ff7c2 Iustin Pop
  HT_FAKE: {
1406 bd0ff7c2 Iustin Pop
    },
1407 48297fa2 Iustin Pop
  HT_CHROOT: {
1408 48297fa2 Iustin Pop
    HV_INIT_SCRIPT: "/ganeti-chroot",
1409 48297fa2 Iustin Pop
    },
1410 4b5e40a5 Iustin Pop
  HT_LXC: {
1411 e3ed5316 Balazs Lecz
    HV_CPU_MASK: "",
1412 4b5e40a5 Iustin Pop
    },
1413 bd0ff7c2 Iustin Pop
  }
1414 7888a614 Alexander Schreiber
1415 7736a5f2 Iustin Pop
HVC_GLOBALS = frozenset([
1416 7736a5f2 Iustin Pop
  HV_MIGRATION_PORT,
1417 e43d4f9f Apollon Oikonomopoulos
  HV_MIGRATION_BANDWIDTH,
1418 783a6c0b Iustin Pop
  HV_MIGRATION_MODE,
1419 7736a5f2 Iustin Pop
  ])
1420 7736a5f2 Iustin Pop
1421 7888a614 Alexander Schreiber
BEC_DEFAULTS = {
1422 bd0ff7c2 Iustin Pop
  BE_MEMORY: 128,
1423 bd0ff7c2 Iustin Pop
  BE_VCPUS: 1,
1424 bd0ff7c2 Iustin Pop
  BE_AUTO_BALANCE: True,
1425 bd0ff7c2 Iustin Pop
  }
1426 c3e618cc Guido Trotter
1427 095e71aa René Nussbaumer
NDC_DEFAULTS = {
1428 095e71aa René Nussbaumer
  ND_OOB_PROGRAM: None,
1429 095e71aa René Nussbaumer
  }
1430 095e71aa René Nussbaumer
1431 ac061be9 Guido Trotter
NICC_DEFAULTS = {
1432 ac061be9 Guido Trotter
  NIC_MODE: NIC_MODE_BRIDGED,
1433 ac061be9 Guido Trotter
  NIC_LINK: DEFAULT_BRIDGE,
1434 ac061be9 Guido Trotter
  }
1435 ac061be9 Guido Trotter
1436 c3e618cc Guido Trotter
MASTER_POOL_SIZE_DEFAULT = 10
1437 ea1518af Guido Trotter
1438 ea1518af Guido Trotter
CONFD_PROTOCOL_VERSION = 1
1439 ea1518af Guido Trotter
1440 09444532 Guido Trotter
CONFD_REQ_PING = 0
1441 ea1518af Guido Trotter
CONFD_REQ_NODE_ROLE_BYNAME = 1
1442 ea1518af Guido Trotter
CONFD_REQ_NODE_PIP_BY_INSTANCE_IP = 2
1443 48166551 Guido Trotter
CONFD_REQ_CLUSTER_MASTER = 3
1444 efbb4fd2 Luca Bigliardi
CONFD_REQ_NODE_PIP_LIST = 4
1445 efbb4fd2 Luca Bigliardi
CONFD_REQ_MC_PIP_LIST = 5
1446 d01ae714 Luca Bigliardi
CONFD_REQ_INSTANCES_IPS_LIST = 6
1447 ea1518af Guido Trotter
1448 19351457 Guido Trotter
# Confd request query fields. These are used to narrow down queries.
1449 19351457 Guido Trotter
# These must be strings rather than integers, because json-encoding
1450 19351457 Guido Trotter
# converts them to strings anyway, as they're used as dict-keys.
1451 19351457 Guido Trotter
CONFD_REQQ_LINK = "0"
1452 19351457 Guido Trotter
CONFD_REQQ_IP = "1"
1453 19351457 Guido Trotter
CONFD_REQQ_IPLIST = "2"
1454 250554a9 Guido Trotter
CONFD_REQQ_FIELDS = "3"
1455 250554a9 Guido Trotter
1456 250554a9 Guido Trotter
CONFD_REQFIELD_NAME = "0"
1457 250554a9 Guido Trotter
CONFD_REQFIELD_IP = "1"
1458 43dc8496 Guido Trotter
CONFD_REQFIELD_MNODE_PIP = "2"
1459 19351457 Guido Trotter
1460 ea1518af Guido Trotter
CONFD_REQS = frozenset([
1461 09444532 Guido Trotter
  CONFD_REQ_PING,
1462 ea1518af Guido Trotter
  CONFD_REQ_NODE_ROLE_BYNAME,
1463 ea1518af Guido Trotter
  CONFD_REQ_NODE_PIP_BY_INSTANCE_IP,
1464 48166551 Guido Trotter
  CONFD_REQ_CLUSTER_MASTER,
1465 efbb4fd2 Luca Bigliardi
  CONFD_REQ_NODE_PIP_LIST,
1466 efbb4fd2 Luca Bigliardi
  CONFD_REQ_MC_PIP_LIST,
1467 d01ae714 Luca Bigliardi
  CONFD_REQ_INSTANCES_IPS_LIST,
1468 ea1518af Guido Trotter
  ])
1469 ea1518af Guido Trotter
1470 31c2a99e Guido Trotter
CONFD_REPL_STATUS_OK = 0
1471 31c2a99e Guido Trotter
CONFD_REPL_STATUS_ERROR = 1
1472 31c2a99e Guido Trotter
CONFD_REPL_STATUS_NOTIMPLEMENTED = 2
1473 31c2a99e Guido Trotter
1474 31c2a99e Guido Trotter
CONFD_REPL_STATUSES = frozenset([
1475 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_OK,
1476 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_ERROR,
1477 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_NOTIMPLEMENTED,
1478 31c2a99e Guido Trotter
  ])
1479 31c2a99e Guido Trotter
1480 89c52785 Guido Trotter
(CONFD_NODE_ROLE_MASTER,
1481 89c52785 Guido Trotter
 CONFD_NODE_ROLE_CANDIDATE,
1482 89c52785 Guido Trotter
 CONFD_NODE_ROLE_OFFLINE,
1483 197b0f5d Guido Trotter
 CONFD_NODE_ROLE_DRAINED,
1484 197b0f5d Guido Trotter
 CONFD_NODE_ROLE_REGULAR,
1485 197b0f5d Guido Trotter
 ) = range(5)
1486 89c52785 Guido Trotter
1487 ca2a5b13 Guido Trotter
# A few common errors for confd
1488 ca2a5b13 Guido Trotter
CONFD_ERROR_UNKNOWN_ENTRY = 1
1489 7189e790 Guido Trotter
CONFD_ERROR_INTERNAL = 2
1490 19351457 Guido Trotter
CONFD_ERROR_ARGUMENT = 3
1491 ca2a5b13 Guido Trotter
1492 71f27d19 Guido Trotter
# Each request is "salted" by the current timestamp.
1493 71f27d19 Guido Trotter
# This constants decides how many seconds of skew to accept.
1494 71f27d19 Guido Trotter
# TODO: make this a default and allow the value to be more configurable
1495 313b2dd4 Michael Hanselmann
CONFD_MAX_CLOCK_SKEW = 2 * NODE_MAX_CLOCK_SKEW
1496 84c3ab28 Guido Trotter
1497 84c3ab28 Guido Trotter
# When we haven't reloaded the config for more than this amount of seconds, we
1498 84c3ab28 Guido Trotter
# force a test to see if inotify is betraying us.
1499 84c3ab28 Guido Trotter
CONFD_CONFIG_RELOAD_TIMEOUT = 60
1500 84c3ab28 Guido Trotter
1501 84c3ab28 Guido Trotter
# If we receive more than one update in this amount of seconds, we move to
1502 84c3ab28 Guido Trotter
# polling every RATELIMIT seconds, rather than relying on inotify, to be able
1503 84c3ab28 Guido Trotter
# to serve more requests.
1504 84c3ab28 Guido Trotter
CONFD_CONFIG_RELOAD_RATELIMIT = 2
1505 c8eded0b Guido Trotter
1506 a3758ab2 Guido Trotter
# Magic number prepended to all confd queries.
1507 a3758ab2 Guido Trotter
# This allows us to distinguish different types of confd protocols and handle
1508 a3758ab2 Guido Trotter
# them. For example by changing this we can move the whole payload to be
1509 a3758ab2 Guido Trotter
# compressed, or move away from json.
1510 d0c8c01d Iustin Pop
CONFD_MAGIC_FOURCC = "plj0"
1511 a3758ab2 Guido Trotter
1512 e4ccf6cd Guido Trotter
# By default a confd request is sent to the minimum between this number and all
1513 e4ccf6cd Guido Trotter
# MCs. 6 was chosen because even in the case of a disastrous 50% response rate,
1514 e4ccf6cd Guido Trotter
# we should have enough answers to be able to compare more than one.
1515 e4ccf6cd Guido Trotter
CONFD_DEFAULT_REQ_COVERAGE = 6
1516 e4ccf6cd Guido Trotter
1517 e4ccf6cd Guido Trotter
# Timeout in seconds to expire pending query request in the confd client
1518 e4ccf6cd Guido Trotter
# library. We don't actually expect any answer more than 10 seconds after we
1519 e4ccf6cd Guido Trotter
# sent a request.
1520 e4ccf6cd Guido Trotter
CONFD_CLIENT_EXPIRE_TIMEOUT = 10
1521 e4ccf6cd Guido Trotter
1522 c8eded0b Guido Trotter
# Maximum UDP datagram size.
1523 c8eded0b Guido Trotter
# On IPv4: 64K - 20 (ip header size) - 8 (udp header size) = 65507
1524 c8eded0b Guido Trotter
# On IPv6: 64K - 40 (ip6 header size) - 8 (udp header size) = 65487
1525 c8eded0b Guido Trotter
#   (assuming we can't use jumbo frames)
1526 c8eded0b Guido Trotter
# We just set this to 60K, which should be enough
1527 c8eded0b Guido Trotter
MAX_UDP_DATA_SIZE = 61440
1528 6d127406 Balazs Lecz
1529 6d127406 Balazs Lecz
# User-id pool minimum/maximum acceptable user-ids.
1530 6d127406 Balazs Lecz
UIDPOOL_UID_MIN = 0
1531 e687ec01 Michael Hanselmann
UIDPOOL_UID_MAX = 2 ** 32 - 1 # Assuming 32 bit user-ids
1532 649bcdd8 Balazs Lecz
1533 649bcdd8 Balazs Lecz
# Name or path of the pgrep command
1534 649bcdd8 Balazs Lecz
PGREP = "pgrep"
1535 75cf411a Adeodato Simo
1536 75cf411a Adeodato Simo
# Name of the node group that gets created at cluster init or upgrade
1537 75cf411a Adeodato Simo
INITIAL_NODE_GROUP_NAME = "default"
1538 90e99856 Adeodato Simo
1539 90e99856 Adeodato Simo
# Possible values for NodeGroup.alloc_policy
1540 90e99856 Adeodato Simo
ALLOC_POLICY_PREFERRED = "preferred"
1541 90e99856 Adeodato Simo
ALLOC_POLICY_LAST_RESORT = "last_resort"
1542 90e99856 Adeodato Simo
ALLOC_POLICY_UNALLOCABLE = "unallocable"
1543 90e99856 Adeodato Simo
VALID_ALLOC_POLICIES = [
1544 90e99856 Adeodato Simo
  ALLOC_POLICY_PREFERRED,
1545 90e99856 Adeodato Simo
  ALLOC_POLICY_LAST_RESORT,
1546 90e99856 Adeodato Simo
  ALLOC_POLICY_UNALLOCABLE,
1547 90e99856 Adeodato Simo
  ]
1548 b6135bbc Apollon Oikonomopoulos
1549 b6135bbc Apollon Oikonomopoulos
# Temporary external/shared storage parameters
1550 b6135bbc Apollon Oikonomopoulos
BLOCKDEV_DRIVER_MANUAL = "manual"
1551 e5395072 Iustin Pop
1552 e5395072 Iustin Pop
# Whether htools was enabled at compilation time
1553 e5395072 Iustin Pop
HTOOLS = _autoconf.HTOOLS
1554 e5395072 Iustin Pop
# The hail iallocator
1555 e5395072 Iustin Pop
IALLOC_HAIL = "hail"