2001-06-09 04:45:59 +08:00
|
|
|
#ifndef H_RPMCLI
|
|
|
|
#define H_RPMCLI
|
|
|
|
|
|
|
|
/** \ingroup rpmcli rpmbuild
|
|
|
|
* \file lib/rpmcli.h
|
|
|
|
*/
|
|
|
|
|
2001-06-18 06:18:03 +08:00
|
|
|
#include "rpmlib.h"
|
|
|
|
#include "rpmurl.h"
|
|
|
|
#include "rpmmacro.h"
|
2001-06-09 04:45:59 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Should version 3 packages be produced?
|
|
|
|
*/
|
2001-10-18 00:43:36 +08:00
|
|
|
/*@-redecl@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern int _noDirTokens;
|
2001-10-18 00:43:36 +08:00
|
|
|
/*@=redecl@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ==================================================================== */
|
|
|
|
/** \name RPMBT */
|
|
|
|
/*@{*/
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Describe build command line request.
|
|
|
|
*/
|
|
|
|
struct rpmBuildArguments_s {
|
|
|
|
int buildAmount; /*!< Bit(s) to control operation. */
|
|
|
|
/*@null@*/ const char * buildRootOverride; /*!< from --buildroot */
|
|
|
|
/*@null@*/ char * targets; /*!< Target platform(s), comma separated. */
|
2001-10-24 00:48:20 +08:00
|
|
|
/*@observer@*/
|
|
|
|
const char * passPhrase; /*!< Pass phrase. */
|
|
|
|
/*@only@*/ /*@null@*/
|
|
|
|
const char * cookie; /*!< NULL for binary, ??? for source, rpm's */
|
2001-06-09 04:45:59 +08:00
|
|
|
int force; /*!< from --force */
|
|
|
|
int noBuild; /*!< from --nobuild */
|
|
|
|
int noDeps; /*!< from --nodeps */
|
|
|
|
int noLang; /*!< from --nolang */
|
|
|
|
int shortCircuit; /*!< from --short-circuit */
|
|
|
|
int sign; /*!< from --sign */
|
|
|
|
int useCatalog; /*!< from --usecatalog */
|
|
|
|
char buildMode; /*!< Build mode (one of "btBC") */
|
|
|
|
char buildChar; /*!< Build stage (one of "abcilps ") */
|
|
|
|
/*@observer@*/ /*@null@*/ const char * rootdir;
|
|
|
|
};
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
|
|
|
typedef struct rpmBuildArguments_s * BTA_t;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@unchecked@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern struct rpmBuildArguments_s rpmBTArgs;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@unchecked@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern struct poptOption rpmBuildPoptTable[];
|
|
|
|
|
|
|
|
/*@}*/
|
|
|
|
/* ==================================================================== */
|
|
|
|
/** \name RPMQV */
|
|
|
|
/*@{*/
|
|
|
|
|
2001-10-25 09:36:32 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Query/Verify argument qualifiers.
|
|
|
|
* @todo Reassign to tag values.
|
|
|
|
*/
|
|
|
|
typedef enum rpmQVSources_e {
|
|
|
|
RPMQV_PACKAGE = 0, /*!< ... from package name db search. */
|
|
|
|
RPMQV_PATH, /*!< ... from file path db search. */
|
|
|
|
RPMQV_ALL, /*!< ... from each installed package. */
|
|
|
|
RPMQV_RPM, /*!< ... from reading binary rpm package. */
|
|
|
|
RPMQV_GROUP, /*!< ... from group db search. */
|
|
|
|
RPMQV_WHATPROVIDES, /*!< ... from provides db search. */
|
|
|
|
RPMQV_WHATREQUIRES, /*!< ... from requires db search. */
|
|
|
|
RPMQV_TRIGGEREDBY, /*!< ... from trigger db search. */
|
|
|
|
RPMQV_DBOFFSET, /*!< ... from database header instance. */
|
|
|
|
RPMQV_SPECFILE /*!< ... from spec file parse (query only). */
|
|
|
|
} rpmQVSources;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Bit(s) for rpmVerifyFile() attributes and result.
|
|
|
|
*/
|
|
|
|
typedef enum rpmVerifyAttrs_e {
|
|
|
|
RPMVERIFY_NONE = 0, /*!< */
|
|
|
|
RPMVERIFY_MD5 = (1 << 0), /*!< from %verify(md5) */
|
|
|
|
RPMVERIFY_FILESIZE = (1 << 1), /*!< from %verify(size) */
|
|
|
|
RPMVERIFY_LINKTO = (1 << 2), /*!< from %verify(link) */
|
|
|
|
RPMVERIFY_USER = (1 << 3), /*!< from %verify(user) */
|
|
|
|
RPMVERIFY_GROUP = (1 << 4), /*!< from %verify(group) */
|
|
|
|
RPMVERIFY_MTIME = (1 << 5), /*!< from %verify(mtime) */
|
|
|
|
RPMVERIFY_MODE = (1 << 6), /*!< from %verify(mode) */
|
|
|
|
RPMVERIFY_RDEV = (1 << 7), /*!< from %verify(rdev) */
|
|
|
|
/* bits 8-15 unused, reserved for rpmVerifyAttrs */
|
|
|
|
/* bits 16-20 used in rpmVerifyFlags */
|
|
|
|
/* bits 21-22 unused */
|
|
|
|
/* bits 23-27 used in rpmQueryFlags */
|
|
|
|
RPMVERIFY_READLINKFAIL= (1 << 28), /*!< */
|
|
|
|
RPMVERIFY_READFAIL = (1 << 29), /*!< */
|
|
|
|
RPMVERIFY_LSTATFAIL = (1 << 30) /*!< */
|
|
|
|
/* bit 31 unused */
|
|
|
|
} rpmVerifyAttrs;
|
|
|
|
#define RPMVERIFY_ALL ~(RPMVERIFY_NONE)
|
|
|
|
|
2001-06-09 04:45:59 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Bit(s) to control rpmQuery() operation, stored in qva_flags.
|
2001-06-13 01:06:47 +08:00
|
|
|
* @todo Merge rpmQueryFlags, rpmVerifyFlags, and rpmVerifyAttrs?.
|
2001-06-09 04:45:59 +08:00
|
|
|
*/
|
|
|
|
typedef enum rpmQueryFlags_e {
|
2001-06-13 01:06:47 +08:00
|
|
|
QUERY_FOR_DEFAULT = 0, /*!< */
|
2001-06-12 12:10:21 +08:00
|
|
|
/*@-enummemuse@*/
|
2001-06-13 01:06:47 +08:00
|
|
|
QUERY_MD5 = (1 << 0), /*!< from --nomd5 */
|
|
|
|
QUERY_SIZE = (1 << 1), /*!< from --nosize */
|
|
|
|
QUERY_LINKTO = (1 << 2), /*!< from --nolink */
|
|
|
|
QUERY_USER = (1 << 3), /*!< from --nouser) */
|
|
|
|
QUERY_GROUP = (1 << 4), /*!< from --nogroup) */
|
|
|
|
QUERY_MTIME = (1 << 5), /*!< from --nomtime) */
|
|
|
|
QUERY_MODE = (1 << 6), /*!< from --nomode) */
|
|
|
|
QUERY_RDEV = (1 << 7), /*!< from --nodev */
|
|
|
|
/* bits 8-15 unused, reserved for rpmVerifyAttrs */
|
|
|
|
QUERY_FILES = (1 << 16), /*!< verify: from --nofiles */
|
|
|
|
QUERY_DEPS = (1 << 17), /*!< verify: from --nodeps */
|
|
|
|
QUERY_SCRIPT = (1 << 18), /*!< verify: from --noscripts */
|
|
|
|
QUERY_DIGEST = (1 << 19), /*!< verify: from --nodigest */
|
2001-10-25 09:36:32 +08:00
|
|
|
QUERY_SIGNATURE = (1 << 20), /*!< verify: from --nosignature */
|
2001-06-12 12:10:21 +08:00
|
|
|
/*@=enummemuse@*/
|
2001-10-25 09:36:32 +08:00
|
|
|
/* bits 21-22 unused */
|
2001-06-13 01:06:47 +08:00
|
|
|
QUERY_FOR_LIST = (1 << 23), /*!< query: from --list */
|
|
|
|
QUERY_FOR_STATE = (1 << 24), /*!< query: from --state */
|
|
|
|
QUERY_FOR_DOCS = (1 << 25), /*!< query: from --docfiles */
|
|
|
|
QUERY_FOR_CONFIG = (1 << 26), /*!< query: from --configfiles */
|
2001-12-21 00:28:46 +08:00
|
|
|
QUERY_FOR_DUMPFILES = (1 << 27) /*!< query: from --dump */
|
2001-06-09 04:45:59 +08:00
|
|
|
} rpmQueryFlags;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Bit(s) to control rpmVerify() operation, stored in qva_flags.
|
2001-06-13 01:06:47 +08:00
|
|
|
* @todo Merge rpmQueryFlags, rpmVerifyFlags, and rpmVerifyAttrs values?.
|
2001-06-09 04:45:59 +08:00
|
|
|
*/
|
|
|
|
typedef enum rpmVerifyFlags_e {
|
2001-06-12 12:10:21 +08:00
|
|
|
/*@-enummemuse@*/
|
2001-06-13 01:06:47 +08:00
|
|
|
VERIFY_DEFAULT = 0, /*!< */
|
2001-06-12 12:10:21 +08:00
|
|
|
/*@=enummemuse@*/
|
2001-06-13 01:06:47 +08:00
|
|
|
VERIFY_MD5 = (1 << 0), /*!< from --nomd5 */
|
|
|
|
VERIFY_SIZE = (1 << 1), /*!< from --nosize */
|
|
|
|
VERIFY_LINKTO = (1 << 2), /*!< from --nolinkto */
|
|
|
|
VERIFY_USER = (1 << 3), /*!< from --nouser */
|
|
|
|
VERIFY_GROUP = (1 << 4), /*!< from --nogroup */
|
|
|
|
VERIFY_MTIME = (1 << 5), /*!< from --nomtime */
|
|
|
|
VERIFY_MODE = (1 << 6), /*!< from --nomode */
|
|
|
|
VERIFY_RDEV = (1 << 7), /*!< from --nodev */
|
|
|
|
/* bits 8-15 unused, reserved for rpmVerifyAttrs */
|
|
|
|
VERIFY_FILES = (1 << 16), /*!< verify: from --nofiles */
|
|
|
|
VERIFY_DEPS = (1 << 17), /*!< verify: from --nodeps */
|
|
|
|
VERIFY_SCRIPT = (1 << 18), /*!< verify: from --noscripts */
|
|
|
|
VERIFY_DIGEST = (1 << 19), /*!< verify: from --nodigest */
|
2001-10-25 09:36:32 +08:00
|
|
|
VERIFY_SIGNATURE = (1 << 20), /*!< verify: from --nosignature */
|
|
|
|
/* bits 21-22 unused */
|
2001-06-13 01:06:47 +08:00
|
|
|
/*@-enummemuse@*/
|
|
|
|
VERIFY_FOR_LIST = (1 << 23), /*!< query: from --list */
|
|
|
|
VERIFY_FOR_STATE = (1 << 24), /*!< query: from --state */
|
|
|
|
VERIFY_FOR_DOCS = (1 << 25), /*!< query: from --docfiles */
|
|
|
|
VERIFY_FOR_CONFIG = (1 << 26), /*!< query: from --configfiles */
|
2001-12-21 00:28:46 +08:00
|
|
|
VERIFY_FOR_DUMPFILES= (1 << 27) /*!< query: from --dump */
|
2001-06-13 01:06:47 +08:00
|
|
|
/*@=enummemuse@*/
|
|
|
|
/* bits 28-30 used in rpmVerifyAttrs */
|
2001-06-09 04:45:59 +08:00
|
|
|
} rpmVerifyFlags;
|
2001-06-13 01:06:47 +08:00
|
|
|
|
|
|
|
#define VERIFY_ATTRS \
|
|
|
|
( VERIFY_MD5 | VERIFY_SIZE | VERIFY_LINKTO | VERIFY_USER | VERIFY_GROUP | \
|
|
|
|
VERIFY_MTIME | VERIFY_MODE | VERIFY_RDEV )
|
2001-06-12 12:10:21 +08:00
|
|
|
#define VERIFY_ALL \
|
2001-10-25 09:36:32 +08:00
|
|
|
( VERIFY_ATTRS | VERIFY_FILES | VERIFY_DEPS | VERIFY_SCRIPT | VERIFY_DIGEST |\
|
|
|
|
VERIFY_SIGNATURE )
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
|
|
|
typedef struct rpmQVKArguments_s * QVA_t;
|
2001-06-09 04:45:59 +08:00
|
|
|
|
2001-06-12 12:10:21 +08:00
|
|
|
/** \ingroup rpmcli
|
2001-10-25 09:36:32 +08:00
|
|
|
* Function to display iterator matches.
|
|
|
|
*
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param qva parsed query/verify options
|
2001-10-24 21:48:55 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param h header to use for query/verify
|
|
|
|
*/
|
2001-10-24 21:48:55 +08:00
|
|
|
typedef int (*QVF_t) (QVA_t qva, rpmTransactionSet ts, Header h)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals fileSystem@*/
|
2001-10-24 21:48:55 +08:00
|
|
|
/*@modifies qva, ts, fileSystem @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
2001-10-25 09:36:32 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Describe query/verify/signature command line operation.
|
|
|
|
*/
|
|
|
|
struct rpmQVKArguments_s {
|
|
|
|
rpmQVSources qva_source; /*!< Identify CLI arg type. */
|
|
|
|
int qva_sourceCount;/*!< Exclusive option check (>1 is error). */
|
|
|
|
rpmQueryFlags qva_flags; /*!< Bit(s) to control operation. */
|
|
|
|
rpmfileAttrs qva_fflags; /*!< Bit(s) to filter on attribute. */
|
|
|
|
/*@only@*/ /*@null@*/
|
|
|
|
rpmdbMatchIterator qva_mi; /*!< Match iterator on selected headers. */
|
|
|
|
/*@null@*/
|
|
|
|
QVF_t qva_showPackage; /*!< Function to display iterator matches. */
|
|
|
|
/*@unused@*/ int qva_verbose; /*!< (unused) */
|
|
|
|
/*@only@*/ /*@null@*/
|
|
|
|
const char * qva_queryFormat;/*!< Format for headerSprintf(). */
|
|
|
|
int sign; /*!< Is a passphrase needed? */
|
|
|
|
/*@observer@*/
|
|
|
|
const char * passPhrase; /*!< Pass phrase. */
|
|
|
|
/*@observer@*/ /*@null@*/
|
|
|
|
const char * qva_prefix; /*!< Path to top of install tree. */
|
|
|
|
char qva_mode;
|
|
|
|
/*!<
|
|
|
|
- 'q' from --query, -q
|
|
|
|
- 'Q' from --querytags
|
|
|
|
- 'V' from --verify, -V
|
|
|
|
- 'A' from --addsign
|
|
|
|
- 'I' from --import
|
|
|
|
- 'K' from --checksig, -K
|
|
|
|
- 'R' from --resign
|
|
|
|
*/
|
|
|
|
char qva_char; /*!< (unused) always ' ' */
|
|
|
|
};
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
|
|
|
/*@unchecked@*/
|
|
|
|
extern struct rpmQVKArguments_s rpmQVKArgs;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
|
|
|
/*@unchecked@*/
|
|
|
|
extern struct poptOption rpmQVSourcePoptTable[];
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
|
|
|
/*@unchecked@*/
|
|
|
|
extern int specedit;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
|
|
|
/*@unchecked@*/
|
|
|
|
extern struct poptOption rpmQueryPoptTable[];
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
|
|
|
/*@unchecked@*/
|
|
|
|
extern struct poptOption rpmVerifyPoptTable[];
|
|
|
|
|
2001-06-12 12:10:21 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Display query/verify information for each header in iterator.
|
2001-10-24 21:48:55 +08:00
|
|
|
*
|
|
|
|
* This routine uses:
|
|
|
|
* - qva->qva_mi rpm database iterator
|
|
|
|
* - qva->qva_showPackage query/verify display routine
|
|
|
|
*
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param qva parsed query/verify options
|
2001-10-24 21:48:55 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @return result of last non-zero showPackage() return
|
|
|
|
*/
|
2001-10-24 21:48:55 +08:00
|
|
|
int showMatches(QVA_t qva, rpmTransactionSet ts)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals fileSystem@*/
|
2001-10-24 21:48:55 +08:00
|
|
|
/*@modifies qva, fileSystem @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Display list of tags that can be used in --queryformat.
|
|
|
|
* @param fp file handle to use for display
|
|
|
|
*/
|
|
|
|
void rpmDisplayQueryTags(FILE * fp)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals fileSystem@*/
|
2001-06-12 12:10:21 +08:00
|
|
|
/*@modifies *fp, fileSystem @*/;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Common query/verify source interface, called once for each CLI arg.
|
2001-10-24 21:48:55 +08:00
|
|
|
*
|
|
|
|
* This routine uses:
|
|
|
|
* - qva->qva_mi rpm database iterator
|
|
|
|
* - qva->qva_showPackage query/verify display routine
|
|
|
|
*
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param qva parsed query/verify options
|
2001-10-24 21:48:55 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param arg name of source to query/verify
|
|
|
|
* @return showPackage() result, 1 if rpmdbInitIterator() is NULL
|
|
|
|
*/
|
2001-10-24 21:48:55 +08:00
|
|
|
int rpmQueryVerify(QVA_t qva, rpmTransactionSet ts, const char * arg)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals rpmGlobalMacroContext,
|
|
|
|
fileSystem, internalState @*/
|
2001-10-24 21:48:55 +08:00
|
|
|
/*@modifies qva, ts, rpmGlobalMacroContext,
|
2001-10-18 00:43:36 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Display results of package query.
|
|
|
|
* @todo Devise a meaningful return code.
|
|
|
|
* @param qva parsed query/verify options
|
2001-10-24 21:48:55 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param h header to use for query
|
|
|
|
* @return 0 always
|
|
|
|
*/
|
2001-10-24 21:48:55 +08:00
|
|
|
int showQueryPackage(QVA_t qva, rpmTransactionSet ts, Header h)
|
|
|
|
/*@modifies ts @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Display package information.
|
2001-06-14 04:57:06 +08:00
|
|
|
* @todo hack: RPMQV_ALL can pass char ** arglist = NULL, not char * arg. Union?
|
2001-10-28 06:31:10 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param qva parsed query/verify options
|
2001-10-24 21:48:55 +08:00
|
|
|
* @param argv query argument(s) (or NULL)
|
|
|
|
* @return 0 on success, else no. of failures
|
2001-06-12 12:10:21 +08:00
|
|
|
*/
|
2001-10-28 06:31:10 +08:00
|
|
|
int rpmcliQuery(rpmTransactionSet ts, QVA_t qva, /*@null@*/ const char ** argv)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals rpmGlobalMacroContext,
|
|
|
|
fileSystem, internalState @*/
|
2001-10-28 06:31:10 +08:00
|
|
|
/*@modifies ts, qva, rpmGlobalMacroContext,
|
2001-10-18 00:43:36 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
2001-10-25 09:36:32 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Verify file attributes (including MD5 sum).
|
|
|
|
* @todo gnorpm and python bindings prevent this from being static.
|
|
|
|
* @param root path to top of install tree
|
|
|
|
* @param h header
|
|
|
|
* @param filenum index of file in header file info arrays
|
|
|
|
* @retval result address of bit(s) returned to indicate failure
|
|
|
|
* @param omitMask bit(s) to disable verify checks
|
|
|
|
* @return 0 on success (or not installed), 1 on error
|
|
|
|
*/
|
|
|
|
int rpmVerifyFile(const char * root, Header h, int filenum,
|
|
|
|
/*@out@*/ rpmVerifyAttrs * result, rpmVerifyAttrs omitMask)
|
|
|
|
/*@globals fileSystem @*/
|
|
|
|
/*@modifies h, *result, fileSystem @*/;
|
|
|
|
|
2001-06-12 12:10:21 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Display results of package verify.
|
|
|
|
* @param qva parsed query/verify options
|
2001-10-24 21:48:55 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param h header to use for verify
|
|
|
|
* @return result of last non-zero verify return
|
|
|
|
*/
|
2001-10-24 21:48:55 +08:00
|
|
|
int showVerifyPackage(QVA_t qva, rpmTransactionSet ts, Header h)
|
2001-10-18 00:43:36 +08:00
|
|
|
/*@globals rpmGlobalMacroContext,
|
|
|
|
fileSystem, internalState @*/
|
2001-10-24 21:48:55 +08:00
|
|
|
/*@modifies ts, h, rpmGlobalMacroContext,
|
2001-10-18 00:43:36 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
2001-07-07 04:37:42 +08:00
|
|
|
/**
|
|
|
|
* Check original header digest.
|
|
|
|
* @todo Make digest check part of rpmdb iterator.
|
2001-10-24 21:48:55 +08:00
|
|
|
* @todo Wire transaction set here, python bindings prevent.
|
2001-07-07 04:37:42 +08:00
|
|
|
* @param h header
|
|
|
|
* @return 0 on success (or unavailable), 1 on digest mismatch
|
|
|
|
*/
|
|
|
|
int rpmVerifyDigest(Header h)
|
|
|
|
/*@modifies nothing @*/;
|
|
|
|
|
2001-10-25 09:36:32 +08:00
|
|
|
/**
|
|
|
|
* Check package and header signatures.
|
|
|
|
* @param qva parsed query/verify options
|
|
|
|
* @param ts transaction set
|
|
|
|
* @param fd package file handle
|
|
|
|
* @param fn package file name
|
|
|
|
* @return 0 on success, 1 on failure
|
|
|
|
*/
|
|
|
|
int rpmVerifySignatures(QVA_t qva, rpmTransactionSet ts, FD_t fd,
|
|
|
|
const char * fn)
|
|
|
|
/*@globals fileSystem, internalState @*/
|
|
|
|
/*@modifies qva, ts, fd,
|
|
|
|
fileSystem, internalState @*/;
|
|
|
|
|
2001-06-12 12:10:21 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Verify package install.
|
2001-10-24 21:48:55 +08:00
|
|
|
* @todo hack: RPMQV_ALL can pass char ** arglist = NULL, not char * arg. Union?
|
2001-10-28 06:31:10 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param qva parsed query/verify options
|
2001-10-24 21:48:55 +08:00
|
|
|
* @param argv verify argument(s) (or NULL)
|
|
|
|
* @return 0 on success, else no. of failures
|
2001-06-12 12:10:21 +08:00
|
|
|
*/
|
2001-10-28 06:31:10 +08:00
|
|
|
int rpmcliVerify(rpmTransactionSet ts, QVA_t qva, /*@null@*/ const char ** argv)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals rpmGlobalMacroContext,
|
|
|
|
fileSystem, internalState @*/
|
2001-10-28 06:31:10 +08:00
|
|
|
/*@modifies ts, qva, rpmGlobalMacroContext,
|
2001-10-18 00:43:36 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
2001-06-09 04:45:59 +08:00
|
|
|
/*@}*/
|
|
|
|
/* ==================================================================== */
|
|
|
|
/** \name RPMEIU */
|
|
|
|
/*@{*/
|
|
|
|
/* --- install/upgrade/erase modes */
|
|
|
|
|
2001-10-18 00:43:36 +08:00
|
|
|
/*@unchecked@*/
|
|
|
|
extern int packagesTotal;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* The rpm CLI generic transaction callback.
|
|
|
|
* @deprecated Transaction callback arguments need to change, so don't rely on
|
|
|
|
* this routine in the rpmcli API.
|
|
|
|
*
|
|
|
|
* @param arg per-callback private data (e.g. an rpm header)
|
|
|
|
* @param what callback identifier
|
|
|
|
* @param amount per-callback progress info
|
|
|
|
* @param total per-callback progress info
|
|
|
|
* @param pkgkey opaque header key (e.g. file name or PyObject)
|
|
|
|
* @param data private data (e.g. rpmInstallInterfaceFlags)
|
|
|
|
* @return per-callback data (e.g. an opened FD_t)
|
|
|
|
*/
|
|
|
|
/*@null@*/ void * rpmShowProgress(/*@null@*/ const void * arg,
|
|
|
|
const rpmCallbackType what,
|
|
|
|
const unsigned long amount,
|
|
|
|
const unsigned long total,
|
2001-11-08 08:12:49 +08:00
|
|
|
/*@null@*/ fnpyKey key,
|
2001-10-18 00:43:36 +08:00
|
|
|
/*@null@*/ void * data)
|
|
|
|
/*@globals fileSystem, internalState @*/
|
|
|
|
/*@modifies fileSystem, internalState @*/;
|
|
|
|
|
2001-06-12 12:10:21 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Install/upgrade/freshen binary rpm package.
|
2001-10-28 06:31:10 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param fileArgv array of package file names (NULL terminated)
|
|
|
|
* @param transFlags bits to control rpmRunTransactions()
|
|
|
|
* @param interfaceFlags bits to control rpmInstall()
|
|
|
|
* @param probFilter bits to filter problem types
|
|
|
|
* @param relocations package file relocations
|
|
|
|
* @return 0 on success
|
|
|
|
*/
|
2001-10-28 06:31:10 +08:00
|
|
|
int rpmInstall(rpmTransactionSet ts,
|
2001-06-12 12:10:21 +08:00
|
|
|
/*@null@*/ const char ** fileArgv,
|
|
|
|
rpmtransFlags transFlags,
|
|
|
|
rpmInstallInterfaceFlags interfaceFlags,
|
|
|
|
rpmprobFilterFlags probFilter,
|
|
|
|
/*@null@*/ rpmRelocation * relocations)
|
2001-10-18 00:43:36 +08:00
|
|
|
/*@globals packagesTotal, rpmGlobalMacroContext,
|
2001-10-15 11:22:10 +08:00
|
|
|
fileSystem, internalState@*/
|
2001-10-28 06:31:10 +08:00
|
|
|
/*@modifies ts, *relocations, packagesTotal, rpmGlobalMacroContext,
|
2001-10-18 00:43:36 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Install source rpm package.
|
2001-10-26 12:16:19 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param arg source rpm file name
|
|
|
|
* @retval specFile address of (installed) spec file name
|
|
|
|
* @retval cookie
|
|
|
|
* @return 0 on success
|
|
|
|
*/
|
2001-10-26 12:16:19 +08:00
|
|
|
int rpmInstallSource(rpmTransactionSet ts, const char * arg,
|
2001-06-12 12:10:21 +08:00
|
|
|
/*@null@*/ /*@out@*/ const char ** specFile,
|
2001-10-24 00:48:20 +08:00
|
|
|
/*@null@*/ /*@out@*/ const char ** cookie)
|
2001-10-18 00:43:36 +08:00
|
|
|
/*@globals rpmGlobalMacroContext,
|
|
|
|
fileSystem, internalState@*/
|
2001-10-26 12:16:19 +08:00
|
|
|
/*@modifies ts, *specFile, *cookie, rpmGlobalMacroContext,
|
2001-10-18 00:43:36 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Erase binary rpm package.
|
2001-10-28 06:31:10 +08:00
|
|
|
* @param ts transaction set
|
2001-06-12 12:10:21 +08:00
|
|
|
* @param argv array of package file names (NULL terminated)
|
|
|
|
* @param transFlags bits to control rpmRunTransactions()
|
|
|
|
* @param interfaceFlags bits to control rpmInstall()
|
|
|
|
* @return 0 on success
|
|
|
|
*/
|
2001-10-28 06:31:10 +08:00
|
|
|
int rpmErase(rpmTransactionSet ts, /*@null@*/ const char ** argv,
|
2001-06-12 12:10:21 +08:00
|
|
|
rpmtransFlags transFlags,
|
|
|
|
rpmEraseInterfaceFlags interfaceFlags)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals rpmGlobalMacroContext,
|
|
|
|
fileSystem, internalState @*/
|
2001-10-28 06:31:10 +08:00
|
|
|
/*@modifies ts, rpmGlobalMacroContext,
|
2001-10-18 00:43:36 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-06-12 12:10:21 +08:00
|
|
|
|
2001-06-09 04:45:59 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Describe database command line requests.
|
|
|
|
*/
|
|
|
|
struct rpmInstallArguments_s {
|
|
|
|
rpmtransFlags transFlags;
|
|
|
|
rpmprobFilterFlags probFilter;
|
|
|
|
rpmInstallInterfaceFlags installInterfaceFlags;
|
|
|
|
rpmEraseInterfaceFlags eraseInterfaceFlags;
|
2001-07-07 04:37:42 +08:00
|
|
|
/*@only@*/ /*@null@*/ rpmRelocation * relocations;
|
2001-06-09 04:45:59 +08:00
|
|
|
int numRelocations;
|
|
|
|
int noDeps;
|
|
|
|
int incldocs;
|
2001-07-07 04:37:42 +08:00
|
|
|
/*@null@*/ const char * prefix;
|
|
|
|
/*@observer@*/ /*@null@*/ const char * rootdir;
|
|
|
|
int_32 rbtid; /*!< from --rollback */
|
2001-06-09 04:45:59 +08:00
|
|
|
};
|
|
|
|
|
2001-07-07 04:37:42 +08:00
|
|
|
/**
|
|
|
|
* A rollback transaction id element.
|
|
|
|
*/
|
2001-09-25 05:53:14 +08:00
|
|
|
/*@-fielduse@*/
|
2001-07-07 04:37:42 +08:00
|
|
|
typedef /*@abstract@*/ struct IDT_s {
|
|
|
|
unsigned int instance; /*!< installed package transaction id. */
|
|
|
|
/*@owned@*/ /*@null@*/ const char * key; /*! removed package file name. */
|
|
|
|
Header h; /*!< removed package header. */
|
|
|
|
union {
|
|
|
|
int_32 i32; /*!< install/remove transaction id */
|
|
|
|
} val;
|
|
|
|
} * IDT;
|
2001-09-25 05:53:14 +08:00
|
|
|
/*@=fielduse@*/
|
2001-07-07 04:37:42 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A rollback transaction id index.
|
|
|
|
*/
|
|
|
|
typedef /*@abstract@*/ struct IDTindex_s {
|
|
|
|
int delta; /*!< no. elements to realloc as a chunk. */
|
|
|
|
int size; /*!< size of id index element. */
|
|
|
|
int alloced; /*!< current number of elements allocated. */
|
|
|
|
int nidt; /*!< current number of elements initialized. */
|
|
|
|
/*@only@*/ /*@null@*/ IDT idt; /*!< id index elements. */
|
|
|
|
} * IDTX;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroy id index.
|
|
|
|
* @param idtx id index
|
|
|
|
* @return NULL always
|
|
|
|
*/
|
|
|
|
/*@null@*/ IDTX IDTXfree(/*@only@*/ /*@null@*/ IDTX idtx)
|
|
|
|
/*@modifies idtx @*/;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create id index.
|
|
|
|
* @return new id index
|
|
|
|
*/
|
|
|
|
/*@only@*/ IDTX IDTXnew(void)
|
|
|
|
/*@*/;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Insure that index has room for "need" elements.
|
|
|
|
* @param idtx id index
|
|
|
|
* @param need additional no. of elements needed
|
|
|
|
* @return id index (with room for "need" elements)
|
|
|
|
*/
|
|
|
|
/*@only@*/ /*@null@*/ IDTX IDTXgrow(/*@only@*/ /*@null@*/ IDTX idtx, int need)
|
|
|
|
/*@modifies idtx @*/;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sort tag (instance,value) pairs.
|
|
|
|
* @param idtx id index
|
|
|
|
* @return id index
|
|
|
|
*/
|
|
|
|
/*@only@*/ /*@null@*/ IDTX IDTXsort(/*@only@*/ /*@null@*/ IDTX idtx)
|
|
|
|
/*@modifies idtx @*/;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load tag (instance,value) pairs from rpm databse, and return sorted id index.
|
2001-10-25 09:36:32 +08:00
|
|
|
* @param ts transaction set
|
2001-07-07 04:37:42 +08:00
|
|
|
* @param tag rpm tag
|
|
|
|
* @return id index
|
|
|
|
*/
|
2001-10-25 09:36:32 +08:00
|
|
|
/*@only@*/ /*@null@*/ IDTX IDTXload(rpmTransactionSet ts, rpmTag tag)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals fileSystem@*/
|
2001-10-25 09:36:32 +08:00
|
|
|
/*@modifies ts, fileSystem @*/;
|
2001-07-07 04:37:42 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Load tag (instance,value) pairs from packages, and return sorted id index.
|
2001-10-26 12:16:19 +08:00
|
|
|
* @param ts transaction set
|
2001-10-25 09:36:32 +08:00
|
|
|
* @param globstr glob expression
|
2001-07-07 04:37:42 +08:00
|
|
|
* @param tag rpm tag
|
|
|
|
* @return id index
|
|
|
|
*/
|
2001-10-26 12:16:19 +08:00
|
|
|
/*@only@*/ /*@null@*/ IDTX IDTXglob(rpmTransactionSet ts,
|
|
|
|
const char * globstr, rpmTag tag)
|
|
|
|
/*@globals fileSystem, internalState @*/
|
|
|
|
/*@modifies ts, fileSystem, internalState @*/;
|
2001-07-07 04:37:42 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Rollback transactions, erasing new, reinstalling old, package(s).
|
2001-10-28 06:31:10 +08:00
|
|
|
* @param ts transaction set
|
2001-07-07 04:37:42 +08:00
|
|
|
* @return 0 on success
|
|
|
|
*/
|
2001-10-28 06:31:10 +08:00
|
|
|
int rpmRollback(rpmTransactionSet ts, struct rpmInstallArguments_s * ia,
|
2001-07-07 04:37:42 +08:00
|
|
|
/*@null@*/ const char ** argv)
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@globals rpmGlobalMacroContext,
|
2001-10-26 12:16:19 +08:00
|
|
|
fileSystem, internalState @*/
|
2001-10-28 06:31:10 +08:00
|
|
|
/*@modifies ts, rpmGlobalMacroContext,
|
2001-10-26 12:16:19 +08:00
|
|
|
fileSystem, internalState @*/;
|
2001-07-07 04:37:42 +08:00
|
|
|
|
2001-06-09 04:45:59 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@unchecked@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern struct rpmInstallArguments_s rpmIArgs;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@unchecked@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern struct poptOption rpmInstallPoptTable[];
|
|
|
|
|
|
|
|
/*@}*/
|
|
|
|
/* ==================================================================== */
|
|
|
|
/** \name RPMDB */
|
|
|
|
/*@{*/
|
|
|
|
/* --- database modes */
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Describe database command line requests.
|
|
|
|
*/
|
|
|
|
struct rpmDatabaseArguments_s {
|
|
|
|
int init; /*!< from --initdb */
|
|
|
|
int rebuild; /*!< from --rebuilddb */
|
|
|
|
int verify; /*!< from --verifydb */
|
|
|
|
};
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@unchecked@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern struct rpmDatabaseArguments_s rpmDBArgs;
|
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@unchecked@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern struct poptOption rpmDatabasePoptTable[];
|
|
|
|
|
|
|
|
/*@}*/
|
|
|
|
/* ==================================================================== */
|
|
|
|
/** \name RPMK */
|
|
|
|
/*@{*/
|
|
|
|
|
2001-06-12 12:10:21 +08:00
|
|
|
/** \ingroup rpmcli
|
|
|
|
* Bit(s) to control rpmReSign() operation.
|
|
|
|
*/
|
2001-10-25 09:36:32 +08:00
|
|
|
/*@-typeuse@*/
|
2001-10-24 00:48:20 +08:00
|
|
|
typedef enum rpmSignFlags_e {
|
|
|
|
RPMSIGN_NONE = 0,
|
2001-10-25 09:36:32 +08:00
|
|
|
RPMSIGN_CHK_SIGNATURE = 'K', /*!< from --checksig */
|
|
|
|
RPMSIGN_NEW_SIGNATURE = 'R', /*!< from --resign */
|
|
|
|
RPMSIGN_ADD_SIGNATURE = 'A', /*!< from --addsign */
|
|
|
|
RPMSIGN_IMPORT_PUBKEY = 'I', /*!< from --import */
|
2001-10-24 00:48:20 +08:00
|
|
|
} rpmSignFlags;
|
2001-10-25 09:36:32 +08:00
|
|
|
/*@=typeuse@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
|
|
|
|
/** \ingroup rpmcli
|
|
|
|
*/
|
2001-10-15 11:22:10 +08:00
|
|
|
/*@unchecked@*/
|
2001-06-09 04:45:59 +08:00
|
|
|
extern struct poptOption rpmSignPoptTable[];
|
|
|
|
|
2001-10-24 00:48:20 +08:00
|
|
|
/** \ingroup rpmcli
|
2001-10-24 04:52:51 +08:00
|
|
|
* Create/Modify/Check elements from signature header.
|
2001-10-25 09:36:32 +08:00
|
|
|
* @param qva mode flags and parameters
|
2001-10-24 00:48:20 +08:00
|
|
|
* @param argv array of package file names (NULL terminated)
|
|
|
|
* @return 0 on success
|
|
|
|
*/
|
2001-10-25 09:36:32 +08:00
|
|
|
int rpmcliSign(QVA_t qva, /*@null@*/ const char ** argv)
|
2001-11-03 10:34:15 +08:00
|
|
|
/*@globals RPMVERSION, rpmGlobalMacroContext,
|
2001-10-24 00:48:20 +08:00
|
|
|
fileSystem, internalState @*/
|
2001-10-25 09:36:32 +08:00
|
|
|
/*@modifies qva, rpmGlobalMacroContext,
|
2001-10-24 00:48:20 +08:00
|
|
|
fileSystem, internalState @*/;
|
|
|
|
|
2001-06-09 04:45:59 +08:00
|
|
|
/*@}*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* H_RPMCLI */
|