virstorageencryption.h 2.5 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 22 23
 *
 * Red Hat Author: Miloslav Trmač <mitr@redhat.com>
 */

#ifndef __VIR_STORAGE_ENCRYPTION_H__
24
# define __VIR_STORAGE_ENCRYPTION_H__
25

26
# include "internal.h"
27
# include "virbuffer.h"
28
# include "virutil.h"
29

30
# include <libxml/tree.h>
31

32
typedef enum {
33 34 35
    VIR_STORAGE_ENCRYPTION_SECRET_TYPE_PASSPHRASE = 0,

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

typedef struct _virStorageEncryptionSecret virStorageEncryptionSecret;
typedef virStorageEncryptionSecret *virStorageEncryptionSecretPtr;
struct _virStorageEncryptionSecret {
42
    int type; /* virStorageEncryptionSecretType */
43
    unsigned char uuid[VIR_UUID_BUFLEN];
44 45
};

46
typedef enum {
47 48 49 50 51
    /* "default" is only valid for volume creation */
    VIR_STORAGE_ENCRYPTION_FORMAT_DEFAULT = 0,
    VIR_STORAGE_ENCRYPTION_FORMAT_QCOW, /* Both qcow and qcow2 */

    VIR_STORAGE_ENCRYPTION_FORMAT_LAST,
52
} virStorageEncryptionFormatType;
53 54 55 56 57
VIR_ENUM_DECL(virStorageEncryptionFormat)

typedef struct _virStorageEncryption virStorageEncryption;
typedef virStorageEncryption *virStorageEncryptionPtr;
struct _virStorageEncryption {
58
    int format; /* virStorageEncryptionFormatType */
59 60 61 62 63 64

    size_t nsecrets;
    virStorageEncryptionSecretPtr *secrets;
};

void virStorageEncryptionFree(virStorageEncryptionPtr enc);
65

66
virStorageEncryptionPtr virStorageEncryptionParseNode(xmlDocPtr xml,
67
                                                      xmlNodePtr root);
68
int virStorageEncryptionFormat(virBufferPtr buf,
69
                               virStorageEncryptionPtr enc);
70

71 72 73 74 75
/* A helper for VIR_STORAGE_ENCRYPTION_FORMAT_QCOW */
enum {
  VIR_STORAGE_QCOW_PASSPHRASE_SIZE = 16
};

76
int virStorageGenerateQcowPassphrase(unsigned char *dest);
77

78
#endif /* __VIR_STORAGE_ENCRYPTION_H__ */