security_manager.h 10.4 KB
Newer Older
1 2 3
/*
 * security_manager.h: Internal security manager API
 *
4
 * Copyright (C) 2010-2013 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 24 25
 *
 * Author: Daniel P. Berrange <berrange@redhat.com>
 */

#ifndef VIR_SECURITY_MANAGER_H__
# define VIR_SECURITY_MANAGER_H__

26
# include "domain_conf.h"
27
# include "vircommand.h"
28
# include "virstoragefile.h"
29

30 31 32
typedef struct _virSecurityManager virSecurityManager;
typedef virSecurityManager *virSecurityManagerPtr;

33 34 35 36 37
typedef enum {
    VIR_SECURITY_MANAGER_DEFAULT_CONFINED   = 1 << 1,
    VIR_SECURITY_MANAGER_REQUIRE_CONFINED   = 1 << 2,
    VIR_SECURITY_MANAGER_PRIVILEGED         = 1 << 3,
    VIR_SECURITY_MANAGER_DYNAMIC_OWNERSHIP  = 1 << 4,
38
    VIR_SECURITY_MANAGER_MOUNT_NAMESPACE    = 1 << 5,
39 40
} virSecurityManagerNewFlags;

41
# define VIR_SECURITY_MANAGER_NEW_MASK \
42
    (VIR_SECURITY_MANAGER_DEFAULT_CONFINED  | \
43 44 45
     VIR_SECURITY_MANAGER_REQUIRE_CONFINED  | \
     VIR_SECURITY_MANAGER_PRIVILEGED)

46
virSecurityManagerPtr virSecurityManagerNew(const char *name,
47
                                            const char *virtDriver,
48
                                            const char *lockManagerPluginName,
49
                                            unsigned int flags);
50

51 52 53
virSecurityManagerPtr virSecurityManagerNewStack(virSecurityManagerPtr primary);
int virSecurityManagerStackAddNested(virSecurityManagerPtr stack,
                                     virSecurityManagerPtr nested);
54

55 56 57 58 59 60 61 62 63 64
/**
 * virSecurityManagerDACChownCallback:
 * @src: Storage file to chown
 * @uid: target uid
 * @gid: target gid
 *
 * A function callback to chown image files described by the disk source struct
 * @src. The callback shall return 0 on success, -1 on error and errno set (no
 * libvirt error reported) OR -2 and a libvirt error reported. */
typedef int
65
(*virSecurityManagerDACChownCallback)(const virStorageSource *src,
66 67 68 69
                                      uid_t uid,
                                      gid_t gid);


70 71
virSecurityManagerPtr virSecurityManagerNewDAC(const char *virtDriver,
                                               uid_t user,
72
                                               gid_t group,
73
                                               unsigned int flags,
74
                                               const char *lockManagerPluginName,
75
                                               virSecurityManagerDACChownCallback chownCallback);
76

77
int virSecurityManagerPreFork(virSecurityManagerPtr mgr);
78 79
void virSecurityManagerPostFork(virSecurityManagerPtr mgr);

80 81
int virSecurityManagerTransactionStart(virSecurityManagerPtr mgr);
int virSecurityManagerTransactionCommit(virSecurityManagerPtr mgr,
82 83
                                        pid_t pid,
                                        bool lock);
84 85
void virSecurityManagerTransactionAbort(virSecurityManagerPtr mgr);

86 87
void *virSecurityManagerGetPrivateData(virSecurityManagerPtr mgr);

88
const char *virSecurityManagerGetDriver(virSecurityManagerPtr mgr);
89 90
const char *virSecurityManagerGetDOI(virSecurityManagerPtr mgr);
const char *virSecurityManagerGetModel(virSecurityManagerPtr mgr);
91 92
const char *virSecurityManagerGetBaseLabel(virSecurityManagerPtr mgr, int virtType);

93 94
bool virSecurityManagerGetDefaultConfined(virSecurityManagerPtr mgr);
bool virSecurityManagerGetRequireConfined(virSecurityManagerPtr mgr);
95
bool virSecurityManagerGetPrivileged(virSecurityManagerPtr mgr);
96

97 98 99
int virSecurityManagerRestoreDiskLabel(virSecurityManagerPtr mgr,
                                       virDomainDefPtr def,
                                       virDomainDiskDefPtr disk);
100
int virSecurityManagerSetDaemonSocketLabel(virSecurityManagerPtr mgr,
101
                                           virDomainDefPtr vm);
102
int virSecurityManagerSetSocketLabel(virSecurityManagerPtr mgr,
103
                                     virDomainDefPtr def);
104
int virSecurityManagerClearSocketLabel(virSecurityManagerPtr mgr,
105
                                       virDomainDefPtr def);
106 107 108
int virSecurityManagerSetDiskLabel(virSecurityManagerPtr mgr,
                                   virDomainDefPtr def,
                                   virDomainDiskDefPtr disk);
109
int virSecurityManagerRestoreHostdevLabel(virSecurityManagerPtr mgr,
110
                                          virDomainDefPtr def,
111 112
                                          virDomainHostdevDefPtr dev,
                                          const char *vroot);
113
int virSecurityManagerSetHostdevLabel(virSecurityManagerPtr mgr,
114
                                      virDomainDefPtr def,
115 116
                                      virDomainHostdevDefPtr dev,
                                      const char *vroot);
117
int virSecurityManagerSetSavedStateLabel(virSecurityManagerPtr mgr,
118
                                         virDomainDefPtr def,
119 120
                                         const char *savefile);
int virSecurityManagerRestoreSavedStateLabel(virSecurityManagerPtr mgr,
121
                                             virDomainDefPtr def,
122 123
                                             const char *savefile);
int virSecurityManagerGenLabel(virSecurityManagerPtr mgr,
124
                               virDomainDefPtr sec);
125
int virSecurityManagerReserveLabel(virSecurityManagerPtr mgr,
126 127
                                   virDomainDefPtr sec,
                                   pid_t pid);
128
int virSecurityManagerReleaseLabel(virSecurityManagerPtr mgr,
129
                                   virDomainDefPtr sec);
130 131
int virSecurityManagerCheckAllLabel(virSecurityManagerPtr mgr,
                                    virDomainDefPtr sec);
132
int virSecurityManagerSetAllLabel(virSecurityManagerPtr mgr,
133
                                  virDomainDefPtr sec,
134 135
                                  const char *stdin_path,
                                  bool chardevStdioLogd);
136
int virSecurityManagerRestoreAllLabel(virSecurityManagerPtr mgr,
137
                                      virDomainDefPtr def,
138 139
                                      bool migrated,
                                      bool chardevStdioLogd);
140
int virSecurityManagerGetProcessLabel(virSecurityManagerPtr mgr,
141 142
                                      virDomainDefPtr def,
                                      pid_t pid,
143 144
                                      virSecurityLabelPtr sec);
int virSecurityManagerSetProcessLabel(virSecurityManagerPtr mgr,
145
                                      virDomainDefPtr def);
146 147 148
int virSecurityManagerSetChildProcessLabel(virSecurityManagerPtr mgr,
                                           virDomainDefPtr def,
                                           virCommandPtr cmd);
149 150
int virSecurityManagerVerify(virSecurityManagerPtr mgr,
                             virDomainDefPtr def);
151
int virSecurityManagerSetImageFDLabel(virSecurityManagerPtr mgr,
152
                                      virDomainDefPtr def,
153
                                      int fd);
154 155 156
int virSecurityManagerSetTapFDLabel(virSecurityManagerPtr mgr,
                                    virDomainDefPtr vm,
                                    int fd);
157
char *virSecurityManagerGetMountOptions(virSecurityManagerPtr mgr,
158 159
                                        virDomainDefPtr vm);
virSecurityManagerPtr* virSecurityManagerGetNested(virSecurityManagerPtr mgr);
160

161 162 163 164 165 166 167
int virSecurityManagerSetImageLabel(virSecurityManagerPtr mgr,
                                    virDomainDefPtr vm,
                                    virStorageSourcePtr src);
int virSecurityManagerRestoreImageLabel(virSecurityManagerPtr mgr,
                                        virDomainDefPtr vm,
                                        virStorageSourcePtr src);

168 169 170 171 172 173 174
int virSecurityManagerSetMemoryLabel(virSecurityManagerPtr mgr,
                                     virDomainDefPtr vm,
                                     virDomainMemoryDefPtr mem);
int virSecurityManagerRestoreMemoryLabel(virSecurityManagerPtr mgr,
                                        virDomainDefPtr vm,
                                        virDomainMemoryDefPtr mem);

175 176 177 178 179 180 181
int virSecurityManagerSetInputLabel(virSecurityManagerPtr mgr,
                                    virDomainDefPtr vm,
                                    virDomainInputDefPtr input);
int virSecurityManagerRestoreInputLabel(virSecurityManagerPtr mgr,
                                        virDomainDefPtr vm,
                                        virDomainInputDefPtr input);

182 183
int virSecurityManagerDomainSetPathLabel(virSecurityManagerPtr mgr,
                                         virDomainDefPtr vm,
184 185
                                         const char *path,
                                         bool allowSubtree);
186

187 188 189 190 191 192 193 194 195 196
int virSecurityManagerSetChardevLabel(virSecurityManagerPtr mgr,
                                      virDomainDefPtr def,
                                      virDomainChrSourceDefPtr dev_source,
                                      bool chardevStdioLogd);

int virSecurityManagerRestoreChardevLabel(virSecurityManagerPtr mgr,
                                          virDomainDefPtr def,
                                          virDomainChrSourceDefPtr dev_source,
                                          bool chardevStdioLogd);

197 198 199 200 201 202
int virSecurityManagerSetTPMLabels(virSecurityManagerPtr mgr,
                                   virDomainDefPtr vm);

int virSecurityManagerRestoreTPMLabels(virSecurityManagerPtr mgr,
                                       virDomainDefPtr vm);

203 204 205 206 207 208 209 210 211 212 213
typedef struct _virSecurityManagerMetadataLockState virSecurityManagerMetadataLockState;
typedef virSecurityManagerMetadataLockState *virSecurityManagerMetadataLockStatePtr;

virSecurityManagerMetadataLockStatePtr
virSecurityManagerMetadataLock(virSecurityManagerPtr mgr,
                               const char **paths,
                               size_t npaths);

void
virSecurityManagerMetadataUnlock(virSecurityManagerPtr mgr,
                                 virSecurityManagerMetadataLockStatePtr *state);
214

215
#endif /* VIR_SECURITY_MANAGER_H__ */