blob: fd3d46ebd12821fbed62196e76b87ef25be6802e [file] [log] [blame]
Daniel P. Berrangea0901872015-03-13 17:39:26 +00001# -*- Mode: Python -*-
Andrea Bolognanif7160f32020-07-29 20:50:24 +02002# vim: filetype=python
Daniel P. Berrangea0901872015-03-13 17:39:26 +00003#
Marc-André Lureaud3a48372017-01-13 15:41:23 +01004
5##
Markus Armbrusterf5cf31c2017-08-24 21:14:08 +02006# = Cryptography
Marc-André Lureaud3a48372017-01-13 15:41:23 +01007##
Daniel P. Berrangea0901872015-03-13 17:39:26 +00008
9##
Marc-André Lureauc5927e72016-11-17 19:54:52 +040010# @QCryptoTLSCredsEndpoint:
Daniel P. Berrangea0901872015-03-13 17:39:26 +000011#
12# The type of network endpoint that will be using the credentials.
13# Most types of credential require different setup / structures
Markus Armbrustera937b6a2023-04-28 12:54:29 +020014# depending on whether they will be used in a server versus a client.
Daniel P. Berrangea0901872015-03-13 17:39:26 +000015#
16# @client: the network endpoint is acting as the client
17#
18# @server: the network endpoint is acting as the server
19#
20# Since: 2.5
21##
22{ 'enum': 'QCryptoTLSCredsEndpoint',
23 'prefix': 'QCRYPTO_TLS_CREDS_ENDPOINT',
24 'data': ['client', 'server']}
Daniel P. Berrangeac1d8872015-10-14 09:58:38 +010025
Daniel P. Berrangeac1d8872015-10-14 09:58:38 +010026##
Marc-André Lureauc5927e72016-11-17 19:54:52 +040027# @QCryptoSecretFormat:
Daniel P. Berrangeac1d8872015-10-14 09:58:38 +010028#
29# The data format that the secret is provided in
30#
Markus Armbrustera937b6a2023-04-28 12:54:29 +020031# @raw: raw bytes. When encoded in JSON only valid UTF-8 sequences
32# can be used
33#
Daniel P. Berrangeac1d8872015-10-14 09:58:38 +010034# @base64: arbitrary base64 encoded binary data
Andrea Bolognani4ae65a52022-05-03 09:37:32 +020035#
Daniel P. Berrangeac1d8872015-10-14 09:58:38 +010036# Since: 2.6
37##
38{ 'enum': 'QCryptoSecretFormat',
39 'prefix': 'QCRYPTO_SECRET_FORMAT',
40 'data': ['raw', 'base64']}
Daniel P. Berranged84b79d2015-11-19 17:09:01 +000041
Daniel P. Berranged84b79d2015-11-19 17:09:01 +000042##
Marc-André Lureauc5927e72016-11-17 19:54:52 +040043# @QCryptoHashAlgorithm:
Daniel P. Berranged84b79d2015-11-19 17:09:01 +000044#
45# The supported algorithms for computing content digests
46#
47# @md5: MD5. Should not be used in any new code, legacy compat only
Markus Armbrustera937b6a2023-04-28 12:54:29 +020048#
Daniel P. Berranged84b79d2015-11-19 17:09:01 +000049# @sha1: SHA-1. Should not be used in any new code, legacy compat only
Markus Armbrustera937b6a2023-04-28 12:54:29 +020050#
Daniel P. Berrange9164b892016-03-11 18:33:08 +000051# @sha224: SHA-224. (since 2.7)
Markus Armbrustera937b6a2023-04-28 12:54:29 +020052#
Daniel P. Berranged84b79d2015-11-19 17:09:01 +000053# @sha256: SHA-256. Current recommended strong hash.
Markus Armbrustera937b6a2023-04-28 12:54:29 +020054#
Daniel P. Berrange9164b892016-03-11 18:33:08 +000055# @sha384: SHA-384. (since 2.7)
Markus Armbrustera937b6a2023-04-28 12:54:29 +020056#
Daniel P. Berrange9164b892016-03-11 18:33:08 +000057# @sha512: SHA-512. (since 2.7)
Markus Armbrustera937b6a2023-04-28 12:54:29 +020058#
Daniel P. Berrange9164b892016-03-11 18:33:08 +000059# @ripemd160: RIPEMD-160. (since 2.7)
Andrea Bolognani4ae65a52022-05-03 09:37:32 +020060#
Daniel P. Berranged84b79d2015-11-19 17:09:01 +000061# Since: 2.6
62##
63{ 'enum': 'QCryptoHashAlgorithm',
64 'prefix': 'QCRYPTO_HASH_ALG',
Daniel P. Berrange9164b892016-03-11 18:33:08 +000065 'data': ['md5', 'sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'ripemd160']}
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +000066
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +000067##
Marc-André Lureauc5927e72016-11-17 19:54:52 +040068# @QCryptoCipherAlgorithm:
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +000069#
70# The supported algorithms for content encryption ciphers
71#
72# @aes-128: AES with 128 bit / 16 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020073#
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +000074# @aes-192: AES with 192 bit / 24 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020075#
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +000076# @aes-256: AES with 256 bit / 32 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020077#
78# @des: DES with 56 bit / 8 byte keys. Do not use except in VNC.
79# (since 6.1)
80#
Longpeng(Mike)ffb7bf42016-12-08 10:33:28 +080081# @3des: 3DES(EDE) with 192 bit / 24 byte keys (since 2.9)
Markus Armbrustera937b6a2023-04-28 12:54:29 +020082#
Daniel P. Berrange084a85e2016-02-10 17:07:42 +000083# @cast5-128: Cast5 with 128 bit / 16 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020084#
Daniel P. Berrange94318522016-02-10 17:07:42 +000085# @serpent-128: Serpent with 128 bit / 16 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020086#
Daniel P. Berrange94318522016-02-10 17:07:42 +000087# @serpent-192: Serpent with 192 bit / 24 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020088#
Daniel P. Berrange94318522016-02-10 17:07:42 +000089# @serpent-256: Serpent with 256 bit / 32 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020090#
Daniel P. Berrange50f67532016-02-10 17:07:42 +000091# @twofish-128: Twofish with 128 bit / 16 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020092#
Daniel P. Berrange50f67532016-02-10 17:07:42 +000093# @twofish-192: Twofish with 192 bit / 24 byte keys
Markus Armbrustera937b6a2023-04-28 12:54:29 +020094#
Daniel P. Berrange50f67532016-02-10 17:07:42 +000095# @twofish-256: Twofish with 256 bit / 32 byte keys
Andrea Bolognani4ae65a52022-05-03 09:37:32 +020096#
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +000097# Since: 2.6
98##
99{ 'enum': 'QCryptoCipherAlgorithm',
100 'prefix': 'QCRYPTO_CIPHER_ALG',
Daniel P. Berrange084a85e2016-02-10 17:07:42 +0000101 'data': ['aes-128', 'aes-192', 'aes-256',
Daniel P. Berrangé83bee4b2021-06-29 14:25:32 +0100102 'des', '3des',
Daniel P. Berrange94318522016-02-10 17:07:42 +0000103 'cast5-128',
Daniel P. Berrange50f67532016-02-10 17:07:42 +0000104 'serpent-128', 'serpent-192', 'serpent-256',
105 'twofish-128', 'twofish-192', 'twofish-256']}
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +0000106
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +0000107##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400108# @QCryptoCipherMode:
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +0000109#
110# The supported modes for content encryption ciphers
111#
112# @ecb: Electronic Code Book
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200113#
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +0000114# @cbc: Cipher Block Chaining
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200115#
Daniel P. Berrangeeaec9032016-02-11 14:05:21 +0000116# @xts: XEX with tweaked code book and ciphertext stealing
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200117#
Gonglei3c282922016-09-26 17:23:22 +0800118# @ctr: Counter (Since 2.8)
Andrea Bolognani4ae65a52022-05-03 09:37:32 +0200119#
Daniel P. Berranged8c02bc2015-11-19 17:09:01 +0000120# Since: 2.6
121##
122{ 'enum': 'QCryptoCipherMode',
123 'prefix': 'QCRYPTO_CIPHER_MODE',
Gonglei3c282922016-09-26 17:23:22 +0800124 'data': ['ecb', 'cbc', 'xts', 'ctr']}
Daniel P. Berrangecb730892015-10-15 12:35:28 +0100125
Daniel P. Berrangecb730892015-10-15 12:35:28 +0100126##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400127# @QCryptoIVGenAlgorithm:
Daniel P. Berrangecb730892015-10-15 12:35:28 +0100128#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200129# The supported algorithms for generating initialization vectors for
130# full disk encryption. The 'plain' generator should not be used for
131# disks with sector numbers larger than 2^32, except where
132# compatibility with pre-existing Linux dm-crypt volumes is required.
Daniel P. Berrangecb730892015-10-15 12:35:28 +0100133#
134# @plain: 64-bit sector number truncated to 32-bits
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200135#
Daniel P. Berrangecb730892015-10-15 12:35:28 +0100136# @plain64: 64-bit sector number
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200137#
138# @essiv: 64-bit sector number encrypted with a hash of the encryption
139# key
Andrea Bolognani4ae65a52022-05-03 09:37:32 +0200140#
Daniel P. Berrangecb730892015-10-15 12:35:28 +0100141# Since: 2.6
142##
143{ 'enum': 'QCryptoIVGenAlgorithm',
144 'prefix': 'QCRYPTO_IVGEN_ALG',
145 'data': ['plain', 'plain64', 'essiv']}
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100146
147##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400148# @QCryptoBlockFormat:
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100149#
150# The supported full disk encryption formats
151#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200152# @qcow: QCow/QCow2 built-in AES-CBC encryption. Use only for
153# liberating data from old images.
154#
155# @luks: LUKS encryption format. Recommended for new images
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100156#
157# Since: 2.6
158##
159{ 'enum': 'QCryptoBlockFormat',
160# 'prefix': 'QCRYPTO_BLOCK_FORMAT',
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100161 'data': ['qcow', 'luks']}
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100162
163##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400164# @QCryptoBlockOptionsBase:
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100165#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200166# The common options that apply to all full disk encryption formats
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100167#
168# @format: the encryption format
169#
170# Since: 2.6
171##
172{ 'struct': 'QCryptoBlockOptionsBase',
173 'data': { 'format': 'QCryptoBlockFormat' }}
174
175##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400176# @QCryptoBlockOptionsQCow:
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100177#
178# The options that apply to QCow/QCow2 AES-CBC encryption format
179#
Markus Armbruster1d8bda12017-03-15 13:57:06 +0100180# @key-secret: the ID of a QCryptoSecret object providing the
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200181# decryption key. Mandatory except when probing image for
182# metadata only.
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100183#
184# Since: 2.6
185##
186{ 'struct': 'QCryptoBlockOptionsQCow',
187 'data': { '*key-secret': 'str' }}
188
189##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400190# @QCryptoBlockOptionsLUKS:
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100191#
192# The options that apply to LUKS encryption format
193#
Markus Armbruster1d8bda12017-03-15 13:57:06 +0100194# @key-secret: the ID of a QCryptoSecret object providing the
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200195# decryption key. Mandatory except when probing image for
196# metadata only.
Andrea Bolognani4ae65a52022-05-03 09:37:32 +0200197#
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100198# Since: 2.6
199##
200{ 'struct': 'QCryptoBlockOptionsLUKS',
201 'data': { '*key-secret': 'str' }}
202
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100203##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400204# @QCryptoBlockCreateOptionsLUKS:
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100205#
206# The options that apply to LUKS encryption format initialization
207#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200208# @cipher-alg: the cipher algorithm for data encryption Currently
209# defaults to 'aes-256'.
210#
211# @cipher-mode: the cipher mode for data encryption Currently defaults
212# to 'xts'
213#
214# @ivgen-alg: the initialization vector generator Currently defaults
215# to 'plain64'
216#
217# @ivgen-hash-alg: the initialization vector generator hash Currently
218# defaults to 'sha256'
219#
220# @hash-alg: the master key hash algorithm Currently defaults to
221# 'sha256'
222#
223# @iter-time: number of milliseconds to spend in PBKDF passphrase
224# processing. Currently defaults to 2000. (since 2.8)
Andrea Bolognani4ae65a52022-05-03 09:37:32 +0200225#
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100226# Since: 2.6
227##
228{ 'struct': 'QCryptoBlockCreateOptionsLUKS',
229 'base': 'QCryptoBlockOptionsLUKS',
230 'data': { '*cipher-alg': 'QCryptoCipherAlgorithm',
231 '*cipher-mode': 'QCryptoCipherMode',
232 '*ivgen-alg': 'QCryptoIVGenAlgorithm',
233 '*ivgen-hash-alg': 'QCryptoHashAlgorithm',
Daniel P. Berrange3bd18892016-09-06 18:43:00 +0100234 '*hash-alg': 'QCryptoHashAlgorithm',
235 '*iter-time': 'int'}}
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100236
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100237##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400238# @QCryptoBlockOpenOptions:
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100239#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200240# The options that are available for all encryption formats when
241# opening an existing volume
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100242#
243# Since: 2.6
244##
245{ 'union': 'QCryptoBlockOpenOptions',
246 'base': 'QCryptoBlockOptionsBase',
247 'discriminator': 'format',
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100248 'data': { 'qcow': 'QCryptoBlockOptionsQCow',
249 'luks': 'QCryptoBlockOptionsLUKS' } }
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100250
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100251##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400252# @QCryptoBlockCreateOptions:
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100253#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200254# The options that are available for all encryption formats when
255# initializing a new volume
Daniel P. Berrange7d969012015-10-24 11:44:13 +0100256#
257# Since: 2.6
258##
259{ 'union': 'QCryptoBlockCreateOptions',
260 'base': 'QCryptoBlockOptionsBase',
261 'discriminator': 'format',
Daniel P. Berrange3e308f22015-10-24 11:55:48 +0100262 'data': { 'qcow': 'QCryptoBlockOptionsQCow',
263 'luks': 'QCryptoBlockCreateOptionsLUKS' } }
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100264
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100265##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400266# @QCryptoBlockInfoBase:
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100267#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200268# The common information that applies to all full disk encryption
269# formats
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100270#
271# @format: the encryption format
272#
273# Since: 2.7
274##
275{ 'struct': 'QCryptoBlockInfoBase',
276 'data': { 'format': 'QCryptoBlockFormat' }}
277
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100278##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400279# @QCryptoBlockInfoLUKSSlot:
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100280#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200281# Information about the LUKS block encryption key slot options
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100282#
283# @active: whether the key slot is currently in use
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200284#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100285# @key-offset: offset to the key material in bytes
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200286#
Markus Armbruster1d8bda12017-03-15 13:57:06 +0100287# @iters: number of PBKDF2 iterations for key material
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200288#
Markus Armbruster1d8bda12017-03-15 13:57:06 +0100289# @stripes: number of stripes for splitting key material
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100290#
291# Since: 2.7
292##
293{ 'struct': 'QCryptoBlockInfoLUKSSlot',
294 'data': {'active': 'bool',
295 '*iters': 'int',
296 '*stripes': 'int',
297 'key-offset': 'int' } }
298
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100299##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400300# @QCryptoBlockInfoLUKS:
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100301#
302# Information about the LUKS block encryption options
303#
304# @cipher-alg: the cipher algorithm for data encryption
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200305#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100306# @cipher-mode: the cipher mode for data encryption
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200307#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100308# @ivgen-alg: the initialization vector generator
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200309#
Markus Armbruster1d8bda12017-03-15 13:57:06 +0100310# @ivgen-hash-alg: the initialization vector generator hash
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200311#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100312# @hash-alg: the master key hash algorithm
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200313#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100314# @payload-offset: offset to the payload data in bytes
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200315#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100316# @master-key-iters: number of PBKDF2 iterations for key material
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200317#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100318# @uuid: unique identifier for the volume
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200319#
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100320# @slots: information about each key slot
321#
322# Since: 2.7
323##
324{ 'struct': 'QCryptoBlockInfoLUKS',
325 'data': {'cipher-alg': 'QCryptoCipherAlgorithm',
326 'cipher-mode': 'QCryptoCipherMode',
327 'ivgen-alg': 'QCryptoIVGenAlgorithm',
328 '*ivgen-hash-alg': 'QCryptoHashAlgorithm',
329 'hash-alg': 'QCryptoHashAlgorithm',
330 'payload-offset': 'int',
331 'master-key-iters': 'int',
332 'uuid': 'str',
333 'slots': [ 'QCryptoBlockInfoLUKSSlot' ] }}
334
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100335##
Marc-André Lureauc5927e72016-11-17 19:54:52 +0400336# @QCryptoBlockInfo:
Daniel P. Berrange40c85022016-07-22 13:53:34 +0100337#
338# Information about the block encryption options
339#
340# Since: 2.7
341##
342{ 'union': 'QCryptoBlockInfo',
343 'base': 'QCryptoBlockInfoBase',
344 'discriminator': 'format',
Anton Nefedov29cd0402018-06-18 11:40:06 +0300345 'data': { 'luks': 'QCryptoBlockInfoLUKS' } }
Maxim Levitsky43cbd062020-06-25 14:55:36 +0200346
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200347##
348# @QCryptoBlockLUKSKeyslotState:
349#
350# Defines state of keyslots that are affected by the update
351#
Andrea Bolognanic0ac5332022-05-03 09:37:36 +0200352# @active: The slots contain the given password and marked as active
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200353#
354# @inactive: The slots are erased (contain garbage) and marked as
355# inactive
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200356#
357# Since: 5.1
358##
359{ 'enum': 'QCryptoBlockLUKSKeyslotState',
360 'data': [ 'active', 'inactive' ] }
Maxim Levitsky43cbd062020-06-25 14:55:36 +0200361
Maxim Levitsky43cbd062020-06-25 14:55:36 +0200362##
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200363# @QCryptoBlockAmendOptionsLUKS:
364#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200365# This struct defines the update parameters that activate/de-activate
366# set of keyslots
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200367#
368# @state: the desired state of the keyslots
369#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200370# @new-secret: The ID of a QCryptoSecret object providing the password
371# to be written into added active keyslots
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200372#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200373# @old-secret: Optional (for deactivation only) If given will
374# deactivate all keyslots that match password located in
375# QCryptoSecret with this ID
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200376#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200377# @iter-time: Optional (for activation only) Number of milliseconds to
378# spend in PBKDF passphrase processing for the newly activated
379# keyslot. Currently defaults to 2000.
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200380#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200381# @keyslot: Optional. ID of the keyslot to activate/deactivate. For
382# keyslot activation, keyslot should not be active already (this
383# is unsafe to update an active keyslot), but possible if 'force'
384# parameter is given. If keyslot is not given, first free keyslot
385# will be written.
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200386#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200387# For keyslot deactivation, this parameter specifies the exact
388# keyslot to deactivate
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200389#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200390# @secret: Optional. The ID of a QCryptoSecret object providing the
391# password to use to retrieve current master key. Defaults to the
392# same secret that was used to open the image
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200393#
Markus Armbruster433a4fd2022-04-22 15:28:07 +0200394# Since: 5.1
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200395##
396{ 'struct': 'QCryptoBlockAmendOptionsLUKS',
397 'data': { 'state': 'QCryptoBlockLUKSKeyslotState',
398 '*new-secret': 'str',
399 '*old-secret': 'str',
400 '*keyslot': 'int',
401 '*iter-time': 'int',
402 '*secret': 'str' } }
403
404##
Maxim Levitsky43cbd062020-06-25 14:55:36 +0200405# @QCryptoBlockAmendOptions:
406#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200407# The options that are available for all encryption formats when
408# amending encryption settings
Maxim Levitsky43cbd062020-06-25 14:55:36 +0200409#
410# Since: 5.1
411##
412{ 'union': 'QCryptoBlockAmendOptions',
413 'base': 'QCryptoBlockOptionsBase',
414 'discriminator': 'format',
415 'data': {
Maxim Levitsky557d2bd2020-06-25 14:55:37 +0200416 'luks': 'QCryptoBlockAmendOptionsLUKS' } }
Kevin Wolf39c4c272020-10-20 12:47:58 +0200417
418##
419# @SecretCommonProperties:
420#
421# Properties for objects of classes derived from secret-common.
422#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200423# @loaded: if true, the secret is loaded immediately when applying
424# this option and will probably fail when processing the next
425# option. Don't use; only provided for compatibility.
426# (default: false)
Kevin Wolf39c4c272020-10-20 12:47:58 +0200427#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200428# @format: the data format that the secret is provided in
429# (default: raw)
Kevin Wolf39c4c272020-10-20 12:47:58 +0200430#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200431# @keyid: the name of another secret that should be used to decrypt
432# the provided data. If not present, the data is assumed to be
433# unencrypted.
Kevin Wolf39c4c272020-10-20 12:47:58 +0200434#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200435# @iv: the random initialization vector used for encryption of this
436# particular secret. Should be a base64 encrypted string of the
437# 16-byte IV. Mandatory if @keyid is given. Ignored if @keyid is
438# absent.
Kevin Wolf39c4c272020-10-20 12:47:58 +0200439#
440# Features:
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200441#
442# @deprecated: Member @loaded is deprecated. Setting true doesn't
443# make sense, and false is already the default.
Kevin Wolf39c4c272020-10-20 12:47:58 +0200444#
445# Since: 2.6
446##
447{ 'struct': 'SecretCommonProperties',
448 'data': { '*loaded': { 'type': 'bool', 'features': ['deprecated'] },
449 '*format': 'QCryptoSecretFormat',
450 '*keyid': 'str',
451 '*iv': 'str' } }
452
453##
454# @SecretProperties:
455#
456# Properties for secret objects.
457#
458# Either @data or @file must be provided, but not both.
459#
460# @data: the associated with the secret from
461#
462# @file: the filename to load the data associated with the secret from
463#
464# Since: 2.6
465##
466{ 'struct': 'SecretProperties',
467 'base': 'SecretCommonProperties',
468 'data': { '*data': 'str',
469 '*file': 'str' } }
470
471##
472# @SecretKeyringProperties:
473#
474# Properties for secret_keyring objects.
475#
476# @serial: serial number that identifies a key to get from the kernel
477#
478# Since: 5.1
479##
480{ 'struct': 'SecretKeyringProperties',
481 'base': 'SecretCommonProperties',
482 'data': { 'serial': 'int32' } }
Kevin Wolfd09e4932020-10-20 12:47:58 +0200483
484##
485# @TlsCredsProperties:
486#
487# Properties for objects of classes derived from tls-creds.
488#
489# @verify-peer: if true the peer credentials will be verified once the
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200490# handshake is completed. This is a no-op for anonymous
491# credentials. (default: true)
Kevin Wolfd09e4932020-10-20 12:47:58 +0200492#
493# @dir: the path of the directory that contains the credential files
494#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200495# @endpoint: whether the QEMU network backend that uses the
496# credentials will be acting as a client or as a server
497# (default: client)
Kevin Wolfd09e4932020-10-20 12:47:58 +0200498#
499# @priority: a gnutls priority string as described at
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200500# https://gnutls.org/manual/html_node/Priority-Strings.html
Kevin Wolfd09e4932020-10-20 12:47:58 +0200501#
502# Since: 2.5
503##
504{ 'struct': 'TlsCredsProperties',
505 'data': { '*verify-peer': 'bool',
506 '*dir': 'str',
507 '*endpoint': 'QCryptoTLSCredsEndpoint',
508 '*priority': 'str' } }
509
510##
511# @TlsCredsAnonProperties:
512#
513# Properties for tls-creds-anon objects.
514#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200515# @loaded: if true, the credentials are loaded immediately when
516# applying this option and will ignore options that are processed
517# later. Don't use; only provided for compatibility.
518# (default: false)
Kevin Wolfd09e4932020-10-20 12:47:58 +0200519#
520# Features:
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200521#
522# @deprecated: Member @loaded is deprecated. Setting true doesn't
523# make sense, and false is already the default.
Kevin Wolfd09e4932020-10-20 12:47:58 +0200524#
525# Since: 2.5
526##
527{ 'struct': 'TlsCredsAnonProperties',
528 'base': 'TlsCredsProperties',
529 'data': { '*loaded': { 'type': 'bool', 'features': ['deprecated'] } } }
530
531##
532# @TlsCredsPskProperties:
533#
534# Properties for tls-creds-psk objects.
535#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200536# @loaded: if true, the credentials are loaded immediately when
537# applying this option and will ignore options that are processed
538# later. Don't use; only provided for compatibility.
539# (default: false)
Kevin Wolfd09e4932020-10-20 12:47:58 +0200540#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200541# @username: the username which will be sent to the server. For
542# clients only. If absent, "qemu" is sent and the property will
543# read back as an empty string.
Kevin Wolfd09e4932020-10-20 12:47:58 +0200544#
545# Features:
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200546#
547# @deprecated: Member @loaded is deprecated. Setting true doesn't
548# make sense, and false is already the default.
Kevin Wolfd09e4932020-10-20 12:47:58 +0200549#
550# Since: 3.0
551##
552{ 'struct': 'TlsCredsPskProperties',
553 'base': 'TlsCredsProperties',
554 'data': { '*loaded': { 'type': 'bool', 'features': ['deprecated'] },
555 '*username': 'str' } }
556
557##
558# @TlsCredsX509Properties:
559#
560# Properties for tls-creds-x509 objects.
561#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200562# @loaded: if true, the credentials are loaded immediately when
563# applying this option and will ignore options that are processed
564# later. Don't use; only provided for compatibility.
565# (default: false)
Kevin Wolfd09e4932020-10-20 12:47:58 +0200566#
567# @sanity-check: if true, perform some sanity checks before using the
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200568# credentials (default: true)
Kevin Wolfd09e4932020-10-20 12:47:58 +0200569#
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200570# @passwordid: For the server-key.pem and client-key.pem files which
571# contain sensitive private keys, it is possible to use an
572# encrypted version by providing the @passwordid parameter. This
573# provides the ID of a previously created secret object containing
574# the password for decryption.
Kevin Wolfd09e4932020-10-20 12:47:58 +0200575#
576# Features:
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200577#
578# @deprecated: Member @loaded is deprecated. Setting true doesn't
579# make sense, and false is already the default.
Kevin Wolfd09e4932020-10-20 12:47:58 +0200580#
581# Since: 2.5
582##
583{ 'struct': 'TlsCredsX509Properties',
584 'base': 'TlsCredsProperties',
585 'data': { '*loaded': { 'type': 'bool', 'features': ['deprecated'] },
586 '*sanity-check': 'bool',
587 '*passwordid': 'str' } }
Lei Hedaa55f32022-05-25 17:01:11 +0800588##
589# @QCryptoAkCipherAlgorithm:
590#
591# The supported algorithms for asymmetric encryption ciphers
592#
593# @rsa: RSA algorithm
594#
595# Since: 7.1
596##
597{ 'enum': 'QCryptoAkCipherAlgorithm',
598 'prefix': 'QCRYPTO_AKCIPHER_ALG',
599 'data': ['rsa']}
600
601##
602# @QCryptoAkCipherKeyType:
603#
604# The type of asymmetric keys.
605#
606# Since: 7.1
607##
608{ 'enum': 'QCryptoAkCipherKeyType',
609 'prefix': 'QCRYPTO_AKCIPHER_KEY_TYPE',
610 'data': ['public', 'private']}
611
612##
613# @QCryptoRSAPaddingAlgorithm:
614#
615# The padding algorithm for RSA.
616#
617# @raw: no padding used
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200618#
Lei Hedaa55f32022-05-25 17:01:11 +0800619# @pkcs1: pkcs1#v1.5
620#
621# Since: 7.1
622##
623{ 'enum': 'QCryptoRSAPaddingAlgorithm',
624 'prefix': 'QCRYPTO_RSA_PADDING_ALG',
625 'data': ['raw', 'pkcs1']}
626
627##
628# @QCryptoAkCipherOptionsRSA:
629#
630# Specific parameters for RSA algorithm.
631#
632# @hash-alg: QCryptoHashAlgorithm
Markus Armbrustera937b6a2023-04-28 12:54:29 +0200633#
Lei Hedaa55f32022-05-25 17:01:11 +0800634# @padding-alg: QCryptoRSAPaddingAlgorithm
635#
636# Since: 7.1
637##
638{ 'struct': 'QCryptoAkCipherOptionsRSA',
639 'data': { 'hash-alg':'QCryptoHashAlgorithm',
640 'padding-alg': 'QCryptoRSAPaddingAlgorithm'}}
641
642##
643# @QCryptoAkCipherOptions:
644#
645# The options that are available for all asymmetric key algorithms
646# when creating a new QCryptoAkCipher.
647#
648# Since: 7.1
649##
650{ 'union': 'QCryptoAkCipherOptions',
651 'base': { 'alg': 'QCryptoAkCipherAlgorithm' },
652 'discriminator': 'alg',
653 'data': { 'rsa': 'QCryptoAkCipherOptionsRSA' }}