2010-05-25 12:14:06 +01:00
|
|
|
/*
|
2012-12-12 16:27:01 +00:00
|
|
|
* vircommand.h: Child command execution
|
2010-05-25 12:14:06 +01:00
|
|
|
*
|
2014-07-15 17:07:02 +02:00
|
|
|
* Copyright (C) 2010-2014 Red Hat, Inc.
|
2010-05-25 12:14:06 +01:00
|
|
|
*
|
|
|
|
* 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
|
2012-09-20 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-21 18:06:23 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2010-05-25 12:14:06 +01:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-06-18 11:12:58 -05:00
|
|
|
#pragma once
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2019-06-18 11:12:58 -05:00
|
|
|
#include "internal.h"
|
|
|
|
#include "virbuffer.h"
|
2010-05-25 12:14:06 +01:00
|
|
|
|
|
|
|
typedef struct _virCommand virCommand;
|
|
|
|
|
2011-05-10 14:42:59 -04:00
|
|
|
/* This will execute in the context of the first child
|
2011-07-14 13:47:25 -06:00
|
|
|
* after fork() but before execve(). As such, it is unsafe to
|
|
|
|
* call any function that is not async-signal-safe. */
|
2011-05-10 14:42:59 -04:00
|
|
|
typedef int (*virExecHook)(void *data);
|
|
|
|
|
2019-10-14 14:25:14 +02:00
|
|
|
pid_t virFork(void) G_GNUC_WARN_UNUSED_RESULT;
|
2011-05-10 14:42:59 -04:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
virCommand *virCommandNew(const char *binary) ATTRIBUTE_NONNULL(1);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
virCommand *virCommandNewArgs(const char *const*args) ATTRIBUTE_NONNULL(1);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
virCommand *virCommandNewArgList(const char *binary, ...)
|
2019-10-14 14:13:31 +02:00
|
|
|
ATTRIBUTE_NONNULL(1) G_GNUC_NULL_TERMINATED;
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
virCommand *virCommandNewVAList(const char *binary, va_list list)
|
2012-07-31 22:56:06 +04:00
|
|
|
ATTRIBUTE_NONNULL(1);
|
|
|
|
|
2010-05-25 12:14:06 +01:00
|
|
|
/* All error report from these setup APIs is
|
|
|
|
* delayed until the Run/RunAsync methods
|
|
|
|
*/
|
|
|
|
|
2018-03-21 17:17:54 +01:00
|
|
|
typedef enum {
|
2013-07-11 11:31:56 +01:00
|
|
|
/* Close the FD in the parent */
|
|
|
|
VIR_COMMAND_PASS_FD_CLOSE_PARENT = (1 << 0),
|
2018-03-21 17:17:54 +01:00
|
|
|
} virCommandPassFDFlags;
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandPassFD(virCommand *cmd,
|
2013-07-11 11:31:56 +01:00
|
|
|
int fd,
|
2019-10-15 13:24:34 +02:00
|
|
|
unsigned int flags) G_GNUC_NO_INLINE;
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetPidFile(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *pidfile) ATTRIBUTE_NONNULL(2);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
gid_t virCommandGetGID(virCommand *cmd) ATTRIBUTE_NONNULL(1);
|
2017-10-09 21:14:55 +02:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
uid_t virCommandGetUID(virCommand *cmd) ATTRIBUTE_NONNULL(1);
|
2017-10-09 21:14:55 +02:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetGID(virCommand *cmd, gid_t gid);
|
2013-01-30 14:47:56 -05:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetUID(virCommand *cmd, uid_t uid);
|
2013-01-30 14:47:56 -05:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetMaxMemLock(virCommand *cmd, unsigned long long bytes);
|
|
|
|
void virCommandSetMaxProcesses(virCommand *cmd, unsigned int procs);
|
|
|
|
void virCommandSetMaxFiles(virCommand *cmd, unsigned int files);
|
|
|
|
void virCommandSetMaxCoreSize(virCommand *cmd, unsigned long long bytes);
|
|
|
|
void virCommandSetUmask(virCommand *cmd, int umask);
|
2013-04-25 12:10:10 -04:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandClearCaps(virCommand *cmd);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAllowCap(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
int capability);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetSELinuxLabel(virCommand *cmd,
|
2013-02-01 14:32:37 -05:00
|
|
|
const char *label);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetAppArmorProfile(virCommand *cmd,
|
2013-02-01 14:32:37 -05:00
|
|
|
const char *profile);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandDaemonize(virCommand *cmd);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandNonblockingFDs(virCommand *cmd);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandRawStatus(virCommand *cmd);
|
2014-02-19 17:32:19 -07:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddEnvFormat(virCommand *cmd, const char *format, ...)
|
2019-10-15 13:35:07 +02:00
|
|
|
ATTRIBUTE_NONNULL(2) G_GNUC_PRINTF(2, 3);
|
2011-05-05 16:32:52 -04:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddEnvPair(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *name,
|
|
|
|
const char *value) ATTRIBUTE_NONNULL(2);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddEnvString(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *str) ATTRIBUTE_NONNULL(2);
|
2010-12-10 11:33:53 -07:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddEnvPass(virCommand *cmd,
|
2019-08-01 13:52:00 +01:00
|
|
|
const char *name) ATTRIBUTE_NONNULL(2);
|
2011-07-14 13:47:25 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddEnvPassCommon(virCommand *cmd);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddEnvXDG(virCommand *cmd, const char *baseDir);
|
2019-03-04 12:47:08 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddArg(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *val) ATTRIBUTE_NONNULL(2);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddArgBuffer(virCommand *cmd,
|
|
|
|
virBuffer *buf);
|
2010-12-10 11:33:53 -07:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddArgFormat(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *format, ...)
|
2019-10-15 13:35:07 +02:00
|
|
|
ATTRIBUTE_NONNULL(2) G_GNUC_PRINTF(2, 3);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddArgPair(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *name,
|
2020-06-06 18:52:35 +08:00
|
|
|
const char *val);
|
2011-07-14 13:47:25 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddArgSet(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *const*vals) ATTRIBUTE_NONNULL(2);
|
2011-07-14 13:47:25 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAddArgList(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
... /* const char *arg, ..., NULL */)
|
2019-10-14 14:13:31 +02:00
|
|
|
G_GNUC_NULL_TERMINATED;
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetWorkingDirectory(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *pwd) ATTRIBUTE_NONNULL(2);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandSetSendBuffer(virCommand *cmd,
|
2021-03-01 11:04:54 +01:00
|
|
|
unsigned char *buffer,
|
|
|
|
size_t buflen)
|
|
|
|
ATTRIBUTE_NONNULL(2);
|
2019-07-25 14:22:06 -04:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetInputBuffer(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
const char *inbuf) ATTRIBUTE_NONNULL(2);
|
2011-07-14 13:47:25 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetOutputBuffer(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
char **outbuf) ATTRIBUTE_NONNULL(2);
|
2011-07-14 13:47:25 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetErrorBuffer(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
char **errbuf) ATTRIBUTE_NONNULL(2);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetInputFD(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
int infd);
|
2011-07-14 13:47:25 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetOutputFD(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
int *outfd) ATTRIBUTE_NONNULL(2);
|
2011-07-14 13:47:25 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetErrorFD(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
int *errfd) ATTRIBUTE_NONNULL(2);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandSetPreExecHook(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
virExecHook hook,
|
|
|
|
void *opaque) ATTRIBUTE_NONNULL(2);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandWriteArgLog(virCommand *cmd,
|
2010-05-25 12:14:06 +01:00
|
|
|
int logfd);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
char *virCommandToString(virCommand *cmd, bool linebreaks) G_GNUC_WARN_UNUSED_RESULT;
|
|
|
|
char *virCommandToStringFull(virCommand *cmd,
|
2021-04-01 16:09:54 +02:00
|
|
|
bool linebreaks,
|
|
|
|
bool stripCommandPath);
|
2021-06-10 17:43:59 +02:00
|
|
|
int virCommandToStringBuf(virCommand *cmd,
|
|
|
|
virBuffer *buf,
|
|
|
|
bool linebreaks,
|
|
|
|
bool stripCommandPath);
|
2021-04-01 16:09:54 +02:00
|
|
|
|
2021-09-24 13:32:16 +02:00
|
|
|
int virCommandGetArgList(virCommand *cmd, char ***args);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandExec(virCommand *cmd, gid_t *groups, int ngroups) G_GNUC_WARN_UNUSED_RESULT;
|
2011-05-06 10:37:36 -04:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandRun(virCommand *cmd,
|
2019-10-14 14:25:14 +02:00
|
|
|
int *exitstatus) G_GNUC_WARN_UNUSED_RESULT;
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandRunAsync(virCommand *cmd,
|
2019-10-14 14:25:14 +02:00
|
|
|
pid_t *pid) G_GNUC_WARN_UNUSED_RESULT;
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandWait(virCommand *cmd,
|
2019-10-14 14:25:14 +02:00
|
|
|
int *exitstatus) G_GNUC_WARN_UNUSED_RESULT;
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandRequireHandshake(virCommand *cmd);
|
2010-11-22 13:31:35 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandHandshakeWait(virCommand *cmd)
|
2019-10-14 14:25:14 +02:00
|
|
|
G_GNUC_WARN_UNUSED_RESULT;
|
2010-11-22 13:31:35 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandHandshakeNotify(virCommand *cmd)
|
2019-10-14 14:25:14 +02:00
|
|
|
G_GNUC_WARN_UNUSED_RESULT;
|
2010-11-22 13:31:35 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandAbort(virCommand *cmd);
|
2011-03-22 16:22:37 -06:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandFree(virCommand *cmd);
|
2010-05-25 12:14:06 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCommandDoAsyncIO(virCommand *cmd);
|
2014-03-07 11:39:48 +00:00
|
|
|
|
2014-03-18 15:35:01 +01:00
|
|
|
typedef int (*virCommandRunRegexFunc)(char **const groups,
|
|
|
|
void *data);
|
|
|
|
typedef int (*virCommandRunNulFunc)(size_t n_tokens,
|
|
|
|
char **const groups,
|
|
|
|
void *data);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandRunRegex(virCommand *cmd,
|
2014-03-18 15:35:01 +01:00
|
|
|
int nregex,
|
|
|
|
const char **regex,
|
|
|
|
int *nvars,
|
|
|
|
virCommandRunRegexFunc func,
|
|
|
|
void *data,
|
2016-05-13 12:36:39 -04:00
|
|
|
const char *cmd_to_ignore,
|
|
|
|
int *exitstatus);
|
2014-03-18 15:35:01 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCommandRunNul(virCommand *cmd,
|
2014-03-18 15:35:01 +01:00
|
|
|
size_t n_columns,
|
|
|
|
virCommandRunNulFunc func,
|
|
|
|
void *data);
|
|
|
|
|
2019-10-15 14:47:50 +02:00
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virCommand, virCommandFree);
|