virstorageencryption.h 3.1 KB
Newer Older
1
/*
2
 * virstorageencryption.h: volume encryption information
3
 *
4
 * Copyright (C) 2009-2011, 2014 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
17
 * License along with this library.  If not, see
O
Osier Yang 已提交
18
 * <http://www.gnu.org/licenses/>.
19 20 21
 */

#ifndef __VIR_STORAGE_ENCRYPTION_H__
22
# define __VIR_STORAGE_ENCRYPTION_H__
23

24
# include "internal.h"
25
# include "virbuffer.h"
J
John Ferlan 已提交
26
# include "virsecret.h"
27
# include "virutil.h"
28

29
# include <libxml/tree.h>
30

31
typedef enum {
32 33 34
    VIR_STORAGE_ENCRYPTION_SECRET_TYPE_PASSPHRASE = 0,

    VIR_STORAGE_ENCRYPTION_SECRET_TYPE_LAST
35
} virStorageEncryptionSecretType;
36
VIR_ENUM_DECL(virStorageEncryptionSecret)
37 38 39 40

typedef struct _virStorageEncryptionSecret virStorageEncryptionSecret;
typedef virStorageEncryptionSecret *virStorageEncryptionSecretPtr;
struct _virStorageEncryptionSecret {
41
    int type; /* virStorageEncryptionSecretType */
J
John Ferlan 已提交
42
    virSecretLookupTypeDef seclookupdef;
43 44
};

45 46 47 48 49 50 51 52 53 54 55 56
/* It's possible to dictate the cipher and if necessary iv */
typedef struct _virStorageEncryptionInfoDef virStorageEncryptionInfoDef;
typedef virStorageEncryptionInfoDef *virStorageEncryptionInfoDefPtr;
struct _virStorageEncryptionInfoDef {
    unsigned int cipher_size;
    char *cipher_name;
    char *cipher_mode;
    char *cipher_hash;
    char *ivgen_name;
    char *ivgen_hash;
};

57
typedef enum {
58 59 60
    /* "default" is only valid for volume creation */
    VIR_STORAGE_ENCRYPTION_FORMAT_DEFAULT = 0,
    VIR_STORAGE_ENCRYPTION_FORMAT_QCOW, /* Both qcow and qcow2 */
61
    VIR_STORAGE_ENCRYPTION_FORMAT_LUKS,
62 63

    VIR_STORAGE_ENCRYPTION_FORMAT_LAST,
64
} virStorageEncryptionFormatType;
65 66 67 68 69
VIR_ENUM_DECL(virStorageEncryptionFormat)

typedef struct _virStorageEncryption virStorageEncryption;
typedef virStorageEncryption *virStorageEncryptionPtr;
struct _virStorageEncryption {
70
    int format; /* virStorageEncryptionFormatType */
71
    int payload_offset;
72 73 74

    size_t nsecrets;
    virStorageEncryptionSecretPtr *secrets;
75 76

    virStorageEncryptionInfoDef encinfo;
77 78
};

79 80 81
virStorageEncryptionPtr virStorageEncryptionCopy(const virStorageEncryption *src)
    ATTRIBUTE_NONNULL(1);

82
void virStorageEncryptionFree(virStorageEncryptionPtr enc);
83

84 85
virStorageEncryptionPtr virStorageEncryptionParseNode(xmlNodePtr node,
                                                      xmlXPathContextPtr ctxt);
86
int virStorageEncryptionFormat(virBufferPtr buf,
87
                               virStorageEncryptionPtr enc);
88

89 90 91 92 93
/* A helper for VIR_STORAGE_ENCRYPTION_FORMAT_QCOW */
enum {
  VIR_STORAGE_QCOW_PASSPHRASE_SIZE = 16
};

94
int virStorageGenerateQcowPassphrase(unsigned char *dest);
95

96
#endif /* __VIR_STORAGE_ENCRYPTION_H__ */