csomh / source-git / rpm

Forked from source-git/rpm 4 years ago
Clone
2ff057
#ifndef H_RPMTS
2ff057
#define H_RPMTS
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * \file lib/rpmts.h
2ff057
 * Structures and prototypes used for an "rpmts" transaction set.
2ff057
 */
2ff057
2ff057
#include <sys/types.h>
2ff057
2ff057
#include <rpm/rpmtypes.h>
2ff057
#include <rpm/rpmte.h>
2ff057
#include <rpm/rpmps.h>
2ff057
#include <rpm/rpmsw.h>
2ff057
#include <rpm/rpmpgp.h>
2ff057
#include <rpm/rpmfi.h>
2ff057
#include <rpm/rpmcallback.h>
2ff057
2ff057
#ifdef __cplusplus
2ff057
extern "C" {
2ff057
#endif
2ff057
2ff057
extern int _rpmts_stats;
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Bit(s) to control rpmtsRun() operation.
2ff057
 */
2ff057
enum rpmtransFlags_e {
2ff057
    RPMTRANS_FLAG_NONE		= 0,
2ff057
    RPMTRANS_FLAG_TEST		= (1 <<  0),	/*!< from --test */
2ff057
    RPMTRANS_FLAG_BUILD_PROBS	= (1 <<  1),	/*!< don't process payload */
2ff057
    RPMTRANS_FLAG_NOSCRIPTS	= (1 <<  2),	/*!< from --noscripts */
2ff057
    RPMTRANS_FLAG_JUSTDB	= (1 <<  3),	/*!< from --justdb */
2ff057
    RPMTRANS_FLAG_NOTRIGGERS	= (1 <<  4),	/*!< from --notriggers */
2ff057
    RPMTRANS_FLAG_NODOCS	= (1 <<  5),	/*!< from --excludedocs */
2ff057
    RPMTRANS_FLAG_ALLFILES	= (1 <<  6),	/*!< from --allfiles */
2ff057
    RPMTRANS_FLAG_NOPLUGINS	= (1 <<  7),	/*!< from --noplugins */
2ff057
    RPMTRANS_FLAG_NOCONTEXTS	= (1 <<  8),	/*!< from --nocontexts */
2ff057
    RPMTRANS_FLAG_NOCAPS	= (1 <<  9),	/*!< from --nocaps */
2ff057
    /* bits 10-15 unused */
2ff057
    RPMTRANS_FLAG_NOTRIGGERPREIN= (1 << 16),	/*!< from --notriggerprein */
2ff057
    RPMTRANS_FLAG_NOPRE		= (1 << 17),	/*!< from --nopre */
2ff057
    RPMTRANS_FLAG_NOPOST	= (1 << 18),	/*!< from --nopost */
2ff057
    RPMTRANS_FLAG_NOTRIGGERIN	= (1 << 19),	/*!< from --notriggerin */
2ff057
    RPMTRANS_FLAG_NOTRIGGERUN	= (1 << 20),	/*!< from --notriggerun */
2ff057
    RPMTRANS_FLAG_NOPREUN	= (1 << 21),	/*!< from --nopreun */
2ff057
    RPMTRANS_FLAG_NOPOSTUN	= (1 << 22),	/*!< from --nopostun */
2ff057
    RPMTRANS_FLAG_NOTRIGGERPOSTUN = (1 << 23),	/*!< from --notriggerpostun */
2ff057
    RPMTRANS_FLAG_NOPRETRANS	= (1 << 24),	/*!< from --nopretrans */
2ff057
    RPMTRANS_FLAG_NOPOSTTRANS	= (1 << 25),	/*!< from --noposttrans */
2ff057
    /* bit 26 unused */
2ff057
    RPMTRANS_FLAG_NOMD5		= (1 << 27),	/*!< from --nomd5 */
2ff057
    RPMTRANS_FLAG_NOFILEDIGEST	= (1 << 27),	/*!< from --nofiledigest (alias to --nomd5) */
2ff057
    /* bits 28-29 unused */
2ff057
    RPMTRANS_FLAG_NOCONFIGS	= (1 << 30),	/*!< from --noconfigs */
2ff057
    RPMTRANS_FLAG_DEPLOOPS	= (1 << 31)	/*!< from --deploops */
2ff057
};
2ff057
2ff057
typedef rpmFlags rpmtransFlags;
2ff057
2ff057
#define	_noTransScripts		\
2ff057
  ( RPMTRANS_FLAG_NOPRE |	\
2ff057
    RPMTRANS_FLAG_NOPOST |	\
2ff057
    RPMTRANS_FLAG_NOPREUN |	\
2ff057
    RPMTRANS_FLAG_NOPOSTUN |	\
2ff057
    RPMTRANS_FLAG_NOPRETRANS |	\
2ff057
    RPMTRANS_FLAG_NOPOSTTRANS \
2ff057
  )
2ff057
2ff057
#define	_noTransTriggers	\
2ff057
  ( RPMTRANS_FLAG_NOTRIGGERPREIN | \
2ff057
    RPMTRANS_FLAG_NOTRIGGERIN |	\
2ff057
    RPMTRANS_FLAG_NOTRIGGERUN |	\
2ff057
    RPMTRANS_FLAG_NOTRIGGERPOSTUN \
2ff057
  )
2ff057
2ff057
/* Avoid unnecessary breakage for stuff referring to these unused flags */
2ff057
#define RPMTRANS_FLAG_NOPAYLOAD 0
2ff057
#define RPMTRANS_FLAG_APPLYONLY 0
2ff057
#define RPMTRANS_FLAG_KEEPOBSOLETE 0
2ff057
#define RPMTRANS_FLAG_DIRSTASH 0
2ff057
#define RPMTRANS_FLAG_REPACKAGE 0
2ff057
#define RPMTRANS_FLAG_PKGCOMMIT 0
2ff057
#define RPMTRANS_FLAG_PKGUNDO 0
2ff057
#define RPMTRANS_FLAG_COMMIT 0
2ff057
#define RPMTRANS_FLAG_UNDO 0
2ff057
#define RPMTRANS_FLAG_REVERSE 0
2ff057
#define RPMTRANS_FLAG_NOSUGGEST 0
2ff057
#define RPMTRANS_FLAG_ADDINDEPS 0
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Bit(s) to control digest and signature verification.
2ff057
 */
2ff057
enum rpmVSFlags_e {
2ff057
    RPMVSF_DEFAULT	= 0,
2ff057
    RPMVSF_NOHDRCHK	= (1 <<  0),
2ff057
    RPMVSF_NEEDPAYLOAD	= (1 <<  1),
2ff057
    /* bit(s) 2-7 unused */
2ff057
    RPMVSF_NOSHA1HEADER	= (1 <<  8),
2ff057
    RPMVSF_NOSHA256HEADER = (1 <<  9),
2ff057
    RPMVSF_NODSAHEADER	= (1 << 10),
2ff057
    RPMVSF_NORSAHEADER	= (1 << 11),
2ff057
    /* bit(s) 12-15 unused */
2ff057
    RPMVSF_NOPAYLOAD	= (1 << 16),
2ff057
    RPMVSF_NOMD5	= (1 << 17),
2ff057
    RPMVSF_NODSA	= (1 << 18),
2ff057
    RPMVSF_NORSA	= (1 << 19)
2ff057
    /* bit(s) 16-31 unused */
2ff057
};
2ff057
2ff057
typedef rpmFlags rpmVSFlags;
2ff057
2ff057
#define	RPMVSF_MASK_NODIGESTS	\
2ff057
  ( RPMVSF_NOSHA1HEADER |	\
2ff057
    RPMVSF_NOSHA256HEADER |	\
2ff057
    RPMVSF_NOPAYLOAD |	\
2ff057
    RPMVSF_NOMD5 )
2ff057
#define	_RPMVSF_NODIGESTS	RPMVSF_MASK_NODIGESTS
2ff057
2ff057
#define	RPMVSF_MASK_NOSIGNATURES	\
2ff057
  ( RPMVSF_NODSAHEADER |	\
2ff057
    RPMVSF_NORSAHEADER |	\
2ff057
    RPMVSF_NODSA |		\
2ff057
    RPMVSF_NORSA )
2ff057
#define	_RPMVSF_NOSIGNATURES	RPMVSF_MASK_NOSIGNATURES
2ff057
2ff057
#define	RPMVSF_MASK_NOHEADER	\
2ff057
  ( RPMVSF_NOSHA1HEADER |	\
2ff057
    RPMVSF_NOSHA256HEADER |	\
2ff057
    RPMVSF_NODSAHEADER |	\
2ff057
    RPMVSF_NORSAHEADER )
2ff057
#define	_RPMVSF_NOHEADER	RPMVSF_MASK_NOHEADER
2ff057
2ff057
#define	RPMVSF_MASK_NOPAYLOAD	\
2ff057
  ( RPMVSF_NOMD5 |		\
2ff057
    RPMVSF_NOPAYLOAD |		\
2ff057
    RPMVSF_NODSA |		\
2ff057
    RPMVSF_NORSA )
2ff057
#define	_RPMVSF_NOPAYLOAD	RPMVSF_MASK_NOPAYLOAD
2ff057
2ff057
enum {
2ff057
    RPMSIG_NONE_TYPE		= 0,
2ff057
    RPMSIG_DIGEST_TYPE		= (1 << 0),
2ff057
    RPMSIG_SIGNATURE_TYPE	= (1 << 1),
2ff057
    RPMSIG_OTHER_TYPE		= (1 << 2),
2ff057
};
2ff057
2ff057
#define RPMSIG_VERIFIABLE_TYPE (RPMSIG_DIGEST_TYPE|RPMSIG_SIGNATURE_TYPE)
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Indices for timestamps.
2ff057
 */
2ff057
typedef	enum rpmtsOpX_e {
2ff057
    RPMTS_OP_TOTAL		=  0,
2ff057
    RPMTS_OP_CHECK		=  1,
2ff057
    RPMTS_OP_ORDER		=  2,
2ff057
    RPMTS_OP_FINGERPRINT	=  3,
2ff057
    RPMTS_OP_INSTALL		=  5,
2ff057
    RPMTS_OP_ERASE		=  6,
2ff057
    RPMTS_OP_SCRIPTLETS		=  7,
2ff057
    RPMTS_OP_COMPRESS		=  8,
2ff057
    RPMTS_OP_UNCOMPRESS		=  9,
2ff057
    RPMTS_OP_DIGEST		= 10,
2ff057
    RPMTS_OP_SIGNATURE		= 11,
2ff057
    RPMTS_OP_DBADD		= 12,
2ff057
    RPMTS_OP_DBREMOVE		= 13,
2ff057
    RPMTS_OP_DBGET		= 14,
2ff057
    RPMTS_OP_DBPUT		= 15,
2ff057
    RPMTS_OP_DBDEL		= 16,
2ff057
    RPMTS_OP_VERIFY		= 17,
2ff057
    RPMTS_OP_MAX		= 18
2ff057
} rpmtsOpX;
2ff057
2ff057
enum rpmtxnFlags_e {
2ff057
    RPMTXN_READ		= (1 << 0),
2ff057
    RPMTXN_WRITE	= (1 << 1),
2ff057
};
2ff057
typedef rpmFlags rpmtxnFlags;
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Perform dependency resolution on the transaction set.
2ff057
 *
2ff057
 * Any problems found by rpmtsCheck() can be examined by retrieving the 
2ff057
 * problem set with rpmtsProblems(), success here only means that
2ff057
 * the resolution was successfully attempted for all packages in the set.
2ff057
 *
2ff057
 * @param ts		transaction set
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsCheck(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Determine package order in a transaction set according to dependencies.
2ff057
 *
2ff057
 * Order packages, returning error if circular dependencies cannot be
2ff057
 * eliminated by removing Requires's from the loop(s). Only dependencies from
2ff057
 * added or removed packages are used to determine ordering using a
2ff057
 * topological sort (Knuth vol. 1, p. 262). Use rpmtsCheck() to verify
2ff057
 * that all dependencies can be resolved.
2ff057
 *
2ff057
 * The final order ends up as installed packages followed by removed packages,
2ff057
 * with packages removed for upgrades immediately following the new package
2ff057
 * to be installed.
2ff057
 *
2ff057
 * @param ts		transaction set
2ff057
 * @return		no. of (added) packages that could not be ordered
2ff057
 */
2ff057
int rpmtsOrder(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Process all package elements in a transaction set.  Before calling
2ff057
 * rpmtsRun be sure to have:
2ff057
 *
2ff057
 *    - setup the rpm root dir via rpmtsSetRoot().
2ff057
 *    - setup the rpm notify callback via rpmtsSetNotifyCallback().
2ff057
 *    - setup the rpm transaction flags via rpmtsSetFlags().
2ff057
 * 
2ff057
 * Additionally, though not required you may want to:
2ff057
 *
2ff057
 *    - setup the rpm verify signature flags via rpmtsSetVSFlags().
2ff057
 *       
2ff057
 * @param ts		transaction set
2ff057
 * @param okProbs	unused
2ff057
 * @param ignoreSet	bits to filter problem types
2ff057
 * @return		0 on success, -1 on error, >0 with newProbs set
2ff057
 */
2ff057
int rpmtsRun(rpmts ts, rpmps okProbs, rpmprobFilterFlags ignoreSet);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Reference a transaction set instance.
2ff057
 * @param ts		transaction set
2ff057
 * @return		new transaction set reference
2ff057
 */
2ff057
rpmts rpmtsLink (rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Close the database used by the transaction.
2ff057
 * @param ts		transaction set
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsCloseDB(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Open the database used by the transaction.
2ff057
 * @param ts		transaction set
2ff057
 * @param dbmode	O_RDONLY or O_RDWR
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsOpenDB(rpmts ts, int dbmode);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Initialize the database used by the transaction.
2ff057
 * @deprecated An explicit rpmdbInit() is almost never needed.
2ff057
 * @param ts		transaction set
2ff057
 * @param dbmode	O_RDONLY or O_RDWR
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsInitDB(rpmts ts, int dbmode);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Return the transaction database mode
2ff057
 * @param ts		transaction set
2ff057
 * @return		O_RDONLY, O_RDWR or -1 (lazy opens disabled)
2ff057
 */
2ff057
int rpmtsGetDBMode(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set the transaction database mode. Only permitted when when backing
2ff057
 * database hasn't been opened yet (ie rpmtsGetRdb(ts) == NULL)
2ff057
 * @param ts		transaction set
2ff057
 * @param dbmode	O_RDONLY, O_RDWR or -1 (disable lazy opens)
2ff057
 * @return		0 on success, 1 on error 
2ff057
 */
2ff057
int rpmtsSetDBMode(rpmts ts, int dbmode);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Rebuild the database used by the transaction.
2ff057
 * @param ts		transaction set
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsRebuildDB(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Verify the database used by the transaction.
2ff057
 * @param ts		transaction set
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsVerifyDB(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Return transaction database iterator.
2ff057
 * @param ts		transaction set
2ff057
 * @param rpmtag	database index tag
2ff057
 * @param keyp		key data (NULL for sequential access)
2ff057
 * @param keylen	key data length (0 will use strlen(keyp))
2ff057
 * @return		NULL on failure
2ff057
 */
2ff057
rpmdbMatchIterator rpmtsInitIterator(const rpmts ts, rpmDbiTagVal rpmtag,
2ff057
			const void * keyp, size_t keylen);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Import a header into the rpmdb
2ff057
 * @param txn		transaction handle
2ff057
 * @param h		header
2ff057
 * @param flags		(unused)
2ff057
 * @return              RPMRC_OK/RPMRC_FAIL
2ff057
 */
2ff057
rpmRC rpmtsImportHeader(rpmtxn txn, Header h, rpmFlags flags);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Import public key packet(s).
2ff057
 * @todo Implicit --update policy for gpg-pubkey headers.
2ff057
 * @param ts            transaction set
2ff057
 * @param pkt           pgp pubkey packet(s)
2ff057
 * @param pktlen        pgp pubkey length
2ff057
 * @return              RPMRC_OK/RPMRC_FAIL
2ff057
 */
2ff057
rpmRC rpmtsImportPubkey(rpmts ts, const unsigned char * pkt, size_t pktlen);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Retrieve handle for keyring used for this transaction set
2ff057
 * @param ts            transaction set
2ff057
 * @param autoload	load default keyring if keyring is not set
2ff057
 * @return              keyring handle (or NULL)
2ff057
 */
2ff057
rpmKeyring rpmtsGetKeyring(rpmts ts, int autoload);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set keyring to use for this transaction set.
2ff057
 * Keyring can be only changed while the underlying rpm database is not
2ff057
 * yet open.
2ff057
 * @param ts            transaction set
2ff057
 * @param keyring	keyring handle (NULL to free current keyring)
2ff057
 * @return              0 on success, -1 on error
2ff057
 */
2ff057
int rpmtsSetKeyring(rpmts ts, rpmKeyring keyring);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set dependency solver callback.
2ff057
 * @param ts		transaction set
2ff057
 * @param (*solve)	dependency solver callback
2ff057
 * @param solveData	dependency solver callback data (opaque)
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsSetSolveCallback(rpmts ts,
2ff057
		int (*solve) (rpmts ts, rpmds ds, const void * data),
2ff057
		const void * solveData);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Return current transaction set problems.
2ff057
 * @param ts		transaction set
2ff057
 * @return		current problem set (or NULL if no problems)
2ff057
 */
2ff057
rpmps rpmtsProblems(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Clean current transaction problem set.
2ff057
 * @param ts		transaction set
2ff057
 */
2ff057
void rpmtsCleanProblems(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Free memory needed only for dependency checks and ordering.
2ff057
 * @param ts		transaction set
2ff057
 */
2ff057
void rpmtsClean(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Re-create an empty transaction set.
2ff057
 * @param ts		transaction set
2ff057
 */
2ff057
void rpmtsEmpty(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Destroy transaction set, closing the database as well.
2ff057
 * @param ts		transaction set
2ff057
 * @return		NULL always
2ff057
 */
2ff057
rpmts rpmtsFree(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get verify signatures flag(s).
2ff057
 * @param ts		transaction set
2ff057
 * @return		verify signatures flags
2ff057
 */
2ff057
rpmVSFlags rpmtsVSFlags(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set verify signatures flag(s).
2ff057
 * @param ts		transaction set
2ff057
 * @param vsflags	new verify signatures flags
2ff057
 * @return		previous value
2ff057
 */
2ff057
rpmVSFlags rpmtsSetVSFlags(rpmts ts, rpmVSFlags vsflags);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get package verify flag(s).
2ff057
 * @param ts		transaction set
2ff057
 * @return		verify signatures flags
2ff057
 */
2ff057
rpmVSFlags rpmtsVfyFlags(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set package verify flag(s).
2ff057
 * @param ts		transaction set
2ff057
 * @param vfyflags	new package verify flags
2ff057
 * @return		old package verify flags
2ff057
 */
2ff057
rpmVSFlags rpmtsSetVfyFlags(rpmts ts, rpmVSFlags vfyflags);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get enforced package verify level
2ff057
 * @param ts		transaction set
2ff057
 * @return		package verify level
2ff057
 */
2ff057
int rpmtsVfyLevel(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set enforced package verify level
2ff057
 * @param ts		transaction set
2ff057
 * @param vfylevel	new package verify level
2ff057
 * @return		old package verify level
2ff057
 */
2ff057
int rpmtsSetVfyLevel(rpmts ts, int vfylevel);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get transaction rootDir, i.e. path to chroot(2).
2ff057
 * @param ts		transaction set
2ff057
 * @return		transaction rootDir
2ff057
 */
2ff057
const char * rpmtsRootDir(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set transaction rootDir, i.e. path to chroot(2).
2ff057
 * @param ts		transaction set
2ff057
 * @param rootDir	new transaction rootDir (or NULL)
2ff057
 * @return		0 on success, -1 on error (invalid rootDir)
2ff057
 */
2ff057
int rpmtsSetRootDir(rpmts ts, const char * rootDir);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get transaction script file handle, i.e. stdout/stderr on scriptlet execution
2ff057
 * @param ts		transaction set
2ff057
 * @return		transaction script file handle
2ff057
 */
2ff057
FD_t rpmtsScriptFd(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set transaction script file handle, i.e. stdout/stderr on scriptlet execution
2ff057
 * @param ts		transaction set
2ff057
 * @param scriptFd	new script file handle (or NULL)
2ff057
 */
2ff057
void rpmtsSetScriptFd(rpmts ts, FD_t scriptFd);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get transaction id, i.e. transaction time stamp.
2ff057
 * @param ts		transaction set
2ff057
 * @return		transaction id
2ff057
 */
2ff057
rpm_tid_t rpmtsGetTid(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set transaction id, i.e. transaction time stamp.
2ff057
 * @param ts		transaction set
2ff057
 * @param tid		new transaction id
2ff057
 * @return		previous transaction id
2ff057
 */
2ff057
rpm_tid_t rpmtsSetTid(rpmts ts, rpm_tid_t tid);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get transaction set database handle.
2ff057
 * @param ts		transaction set
2ff057
 * @return		transaction database handle
2ff057
 */
2ff057
rpmdb rpmtsGetRdb(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Perform transaction progress notify callback.
2ff057
 * @param ts		transaction set
2ff057
 * @param te		current transaction element
2ff057
 * @param what		type of call back
2ff057
 * @param amount	current value
2ff057
 * @param total		final value
2ff057
 * @return		callback dependent pointer
2ff057
 */
2ff057
void * rpmtsNotify(rpmts ts, rpmte te,
2ff057
                rpmCallbackType what, rpm_loff_t amount, rpm_loff_t total);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Return number of (ordered) transaction set elements.
2ff057
 * @param ts		transaction set
2ff057
 * @return		no. of transaction set elements
2ff057
 */
2ff057
int rpmtsNElements(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Return (ordered) transaction set element.
2ff057
 * @param ts		transaction set
2ff057
 * @param ix		transaction element index
2ff057
 * @return		transaction element (or NULL)
2ff057
 */
2ff057
rpmte rpmtsElement(rpmts ts, int ix);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get problem ignore bit mask, i.e. bits to filter encountered problems.
2ff057
 * @param ts		transaction set
2ff057
 * @return		ignore bit mask
2ff057
 */
2ff057
rpmprobFilterFlags rpmtsFilterFlags(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get transaction flags, i.e. bits that control rpmtsRun().
2ff057
 * @param ts		transaction set
2ff057
 * @return		transaction flags
2ff057
 */
2ff057
rpmtransFlags rpmtsFlags(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set transaction flags, i.e. bits that control rpmtsRun().
2ff057
 * @param ts		transaction set
2ff057
 * @param transFlags	new transaction flags
2ff057
 * @return		previous transaction flags
2ff057
 */
2ff057
rpmtransFlags rpmtsSetFlags(rpmts ts, rpmtransFlags transFlags);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Retrieve color bits of transaction set.
2ff057
 * @param ts		transaction set
2ff057
 * @return		color bits
2ff057
 */
2ff057
rpm_color_t rpmtsColor(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Retrieve preferred file color
2ff057
 * @param ts		transaction set
2ff057
 * @return		color bits
2ff057
 */
2ff057
rpm_color_t rpmtsPrefColor(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set color bits of transaction set.
2ff057
 * @param ts		transaction set
2ff057
 * @param color		new color bits
2ff057
 * @return		previous color bits
2ff057
 */
2ff057
rpm_color_t rpmtsSetColor(rpmts ts, rpm_color_t color);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set preferred file color
2ff057
 * @param ts		transaction set
2ff057
 * @param color		new color bits
2ff057
 * @return		previous color bits
2ff057
 */
2ff057
rpm_color_t rpmtsSetPrefColor(rpmts ts, rpm_color_t color);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Retrieve operation timestamp from a transaction set.
2ff057
 * @param ts		transaction set
2ff057
 * @param opx		operation timestamp index
2ff057
 * @return		pointer to operation timestamp.
2ff057
 */
2ff057
rpmop rpmtsOp(rpmts ts, rpmtsOpX opx);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Get the plugins associated with a transaction set
2ff057
 * @param ts		transaction set
2ff057
 * @return		plugins
2ff057
 */
2ff057
rpmPlugins rpmtsPlugins(rpmts ts);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Set transaction notify callback function and argument.
2ff057
 *
2ff057
 * @warning This call must be made before rpmtsRun() for
2ff057
 *	install/upgrade/freshen to function correctly.
2ff057
 *
2ff057
 * @param ts		transaction set
2ff057
 * @param notify	progress callback
2ff057
 * @param notifyData	progress callback private data
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsSetNotifyCallback(rpmts ts,
2ff057
		rpmCallbackFunction notify,
2ff057
		rpmCallbackData notifyData);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Create an empty transaction set.
2ff057
 * @return		new transaction set
2ff057
 */
2ff057
rpmts rpmtsCreate(void);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Add package to be installed to transaction set.
2ff057
 *
2ff057
 * The transaction set is checked for duplicate package names.
2ff057
 * If found, the package with the "newest" EVR will be replaced.
2ff057
 *
2ff057
 * @param ts		transaction set
2ff057
 * @param h		header
2ff057
 * @param key		package retrieval key (e.g. file name)
2ff057
 * @param upgrade	is package being upgraded?
2ff057
 * @param relocs	package file relocations
2ff057
 * @return		0 on success, 1 on I/O error, 2 needs capabilities
2ff057
 */
2ff057
int rpmtsAddInstallElement(rpmts ts, Header h,
2ff057
		const fnpyKey key, int upgrade,
2ff057
		rpmRelocation * relocs);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Add package to be reinstalled to transaction set.
2ff057
 *
2ff057
 * @param ts		transaction set
2ff057
 * @param h		header
2ff057
 * @param key		package retrieval key (e.g. file name)
2ff057
 * @return		0 on success
2ff057
 */
2ff057
int rpmtsAddReinstallElement(rpmts ts, Header h, const fnpyKey key);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Add package to be erased to transaction set.
2ff057
 * @param ts		transaction set
2ff057
 * @param h		header
2ff057
 * @param dboffset	ununsed
2ff057
 * @return		0 on success, 1 on error (not installed)
2ff057
 */
2ff057
int rpmtsAddEraseElement(rpmts ts, Header h, int dboffset);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Create a transaction (lock) handle
2ff057
 * @param ts		transaction set
2ff057
 * @param flags		flags
2ff057
 * @return		transaction handle
2ff057
 */
2ff057
rpmtxn rpmtxnBegin(rpmts ts, rpmtxnFlags flags);
2ff057
2ff057
/** \ingroup rpmts
2ff057
 * Destroy transaction (lock) handle
2ff057
 * @param txn		transaction handle
2ff057
 * @return		NULL always
2ff057
 */
2ff057
rpmtxn rpmtxnEnd(rpmtxn txn);
2ff057
2ff057
/** \ingroup rpmte
2ff057
 * Destroy transaction element iterator.
2ff057
 * @param tsi		transaction element iterator
2ff057
 * @return		NULL always
2ff057
 */
2ff057
rpmtsi rpmtsiFree(rpmtsi tsi);
2ff057
2ff057
/** \ingroup rpmte
2ff057
 * Create transaction element iterator.
2ff057
 * @param ts		transaction set
2ff057
 * @return		transaction element iterator
2ff057
 */
2ff057
rpmtsi rpmtsiInit(rpmts ts);
2ff057
2ff057
/** \ingroup rpmte
2ff057
 * Return next transaction element of type.
2ff057
 * @param tsi		transaction element iterator
2ff057
 * @param types		transaction element type selector (0 for any)
2ff057
 * @return		next transaction element of type, NULL on termination
2ff057
 */
2ff057
rpmte rpmtsiNext(rpmtsi tsi, rpmElementTypes types);
2ff057
2ff057
#ifdef __cplusplus
2ff057
}
2ff057
#endif
2ff057
2ff057
2ff057
#endif	/* H_RPMTS */