security_manager.h 5.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
/*
 * security_manager.h: Internal security manager API
 *
 * Copyright (C) 2010-2011 Red Hat, Inc.
 *
 * 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 24 25
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */

#ifndef VIR_SECURITY_MANAGER_H__
# define VIR_SECURITY_MANAGER_H__

26 27
# include "domain_conf.h"

28 29 30 31
typedef struct _virSecurityManager virSecurityManager;
typedef virSecurityManager *virSecurityManagerPtr;

virSecurityManagerPtr virSecurityManagerNew(const char *name,
32
                                            const char *virtDriver,
33 34 35
                                            bool allowDiskFormatProbing,
                                            bool defaultConfined,
                                            bool requireConfined);
36

37 38 39
virSecurityManagerPtr virSecurityManagerNewStack(virSecurityManagerPtr primary);
int virSecurityManagerStackAddNested(virSecurityManagerPtr stack,
                                     virSecurityManagerPtr nested);
40

41 42
virSecurityManagerPtr virSecurityManagerNewDAC(const char *virtDriver,
                                               uid_t user,
43 44
                                               gid_t group,
                                               bool allowDiskFormatProbing,
45 46
                                               bool defaultConfined,
                                               bool requireConfined,
47 48 49 50 51 52
                                               bool dynamicOwnership);

void *virSecurityManagerGetPrivateData(virSecurityManagerPtr mgr);

void virSecurityManagerFree(virSecurityManagerPtr mgr);

53
const char *virSecurityManagerGetDriver(virSecurityManagerPtr mgr);
54 55 56
const char *virSecurityManagerGetDOI(virSecurityManagerPtr mgr);
const char *virSecurityManagerGetModel(virSecurityManagerPtr mgr);
bool virSecurityManagerGetAllowDiskFormatProbing(virSecurityManagerPtr mgr);
57 58
bool virSecurityManagerGetDefaultConfined(virSecurityManagerPtr mgr);
bool virSecurityManagerGetRequireConfined(virSecurityManagerPtr mgr);
59 60

int virSecurityManagerRestoreImageLabel(virSecurityManagerPtr mgr,
61
                                        virDomainDefPtr def,
62
                                        virDomainDiskDefPtr disk);
63
int virSecurityManagerSetDaemonSocketLabel(virSecurityManagerPtr mgr,
64
                                           virDomainDefPtr vm);
65
int virSecurityManagerSetSocketLabel(virSecurityManagerPtr mgr,
66
                                     virDomainDefPtr def);
67
int virSecurityManagerClearSocketLabel(virSecurityManagerPtr mgr,
68
                                       virDomainDefPtr def);
69
int virSecurityManagerSetImageLabel(virSecurityManagerPtr mgr,
70
                                    virDomainDefPtr def,
71 72
                                    virDomainDiskDefPtr disk);
int virSecurityManagerRestoreHostdevLabel(virSecurityManagerPtr mgr,
73
                                          virDomainDefPtr def,
74 75
                                          virDomainHostdevDefPtr dev);
int virSecurityManagerSetHostdevLabel(virSecurityManagerPtr mgr,
76
                                      virDomainDefPtr def,
77 78
                                      virDomainHostdevDefPtr dev);
int virSecurityManagerSetSavedStateLabel(virSecurityManagerPtr mgr,
79
                                         virDomainDefPtr def,
80 81
                                         const char *savefile);
int virSecurityManagerRestoreSavedStateLabel(virSecurityManagerPtr mgr,
82
                                             virDomainDefPtr def,
83 84
                                             const char *savefile);
int virSecurityManagerGenLabel(virSecurityManagerPtr mgr,
85
                               virDomainDefPtr sec);
86
int virSecurityManagerReserveLabel(virSecurityManagerPtr mgr,
87 88
                                   virDomainDefPtr sec,
                                   pid_t pid);
89
int virSecurityManagerReleaseLabel(virSecurityManagerPtr mgr,
90
                                   virDomainDefPtr sec);
91
int virSecurityManagerSetAllLabel(virSecurityManagerPtr mgr,
92
                                  virDomainDefPtr sec,
93 94
                                  const char *stdin_path);
int virSecurityManagerRestoreAllLabel(virSecurityManagerPtr mgr,
95
                                      virDomainDefPtr def,
96 97
                                      int migrated);
int virSecurityManagerGetProcessLabel(virSecurityManagerPtr mgr,
98 99
                                      virDomainDefPtr def,
                                      pid_t pid,
100 101
                                      virSecurityLabelPtr sec);
int virSecurityManagerSetProcessLabel(virSecurityManagerPtr mgr,
102
                                      virDomainDefPtr def);
103 104
int virSecurityManagerVerify(virSecurityManagerPtr mgr,
                             virDomainDefPtr def);
105
int virSecurityManagerSetImageFDLabel(virSecurityManagerPtr mgr,
106
                                      virDomainDefPtr def,
107
                                      int fd);
108 109 110
int virSecurityManagerSetTapFDLabel(virSecurityManagerPtr mgr,
                                    virDomainDefPtr vm,
                                    int fd);
111 112
char *virSecurityManagerGetMountOptions(virSecurityManagerPtr mgr,
                                              virDomainDefPtr vm);
113 114 115
virSecurityManagerPtr*
virSecurityManagerGetNested(virSecurityManagerPtr mgr);

116
#endif /* VIR_SECURITY_MANAGER_H__ */