rpm  5.4.14
Macros | Functions | Variables
rpmchecksig.c File Reference

Verify the signature of a package. More...

#include "system.h"
#include <rpmio_internal.h>
#include <poptIO.h>
#include <rpmbc.h>
#include <rpmhkp.h>
#include <rpmtag.h>
#include <rpmtypes.h>
#include <rpmevr.h>
#include <rpmdb.h>
#include <rpmtxn.h>
#include <rpmxar.h>
#include <pkgio.h>
#include "signature.h"
#include <rpmts.h>
#include "rpmgi.h"
#include <rpmversion.h>
#include <rpmcli.h>
#include "debug.h"
Include dependency graph for rpmchecksig.c:

Go to the source code of this file.

Macros

#define _RPMHKP_INTERNAL   /* XXX internal prototypes. */
 
#define _RPMEVR_INTERNAL   /* XXX RPMSENSE_KEYRING */
 
#define _RPMDB_INTERNAL   /* XXX db_txn */
 
#define _RPMTS_INTERNAL   /* XXX ts->hkp */
 

Functions

static int manageFile (FD_t *fdp, const char **fnp, int flags, int rc)
 
static int copyFile (FD_t *sfdp, const char **sfnp, FD_t *tfdp, const char **tfnp)
 Copy header+payload, calculating digest(s) on the fly. More...
 
static int getSignid (Header sigh, rpmSigTag sigtag, unsigned char *signid)
 Retrieve signer fingerprint from an OpenPGP signature tag. More...
 
static int rpmReSign (rpmts ts, QVA_t qva, const char **argv)
 Create/modify elements in signature header. More...
 
rpmRC rpmcliImportPubkey (const rpmts ts, const unsigned char *pkt, ssize_t pktlen)
 Import public key packet(s). More...
 
static int rpmcliImportPubkeys (const rpmts ts, QVA_t qva, const char **argv)
 Import public key(s). More...
 
static rpmRC readFile (FD_t fd, const char *fn)
 
int rpmVerifySignatures (QVA_t qva, rpmts ts, void *_fd, const char *fn)
 Check package and header signatures. More...
 
int rpmcliSign (rpmts ts, QVA_t qva, const char **argv)
 Create/Modify/Check elements from signature header. More...
 

Variables

int _print_pkts = 0
 

Detailed Description

Verify the signature of a package.

Definition in file rpmchecksig.c.

Macro Definition Documentation

#define _RPMDB_INTERNAL   /* XXX db_txn */

Definition at line 19 of file rpmchecksig.c.

#define _RPMEVR_INTERNAL   /* XXX RPMSENSE_KEYRING */

Definition at line 17 of file rpmchecksig.c.

#define _RPMHKP_INTERNAL   /* XXX internal prototypes. */

Definition at line 12 of file rpmchecksig.c.

#define _RPMTS_INTERNAL   /* XXX ts->hkp */

Definition at line 26 of file rpmchecksig.c.

Function Documentation

static int copyFile ( FD_t sfdp,
const char **  sfnp,
FD_t tfdp,
const char **  tfnp 
)
static

Copy header+payload, calculating digest(s) on the fly.

Definition at line 110 of file rpmchecksig.c.

References _, buf, count, exit, Fflush(), Fread(), Fstrerror(), Fwrite(), manageFile(), NULL, rc, rpmlog(), RPMLOG_ERR, and void.

Referenced by rpmReSign().

static int getSignid ( Header  sigh,
rpmSigTag  sigtag,
unsigned char *  signid 
)
static

Retrieve signer fingerprint from an OpenPGP signature tag.

Parameters
sighsignature header
sigtagsignature tag
Return values
signidsigner fingerprint
Returns
0 on success

Definition at line 159 of file rpmchecksig.c.

References _free(), alloca(), _HE_s::c, dig, headerGet(), memset(), NULL, _HE_s::p, pgpDigFree(), pgpDigNew(), pgpPktLen(), PGPPUBKEYALGO_UNKNOWN, rpmDataType_u::ptr, rc, RPMVSF_DEFAULT, _HE_s::tag, rpmDataType_u::ui8p, void, and xx.

Referenced by rpmReSign().

static int manageFile ( FD_t fdp,
const char **  fnp,
int  flags,
int  rc 
)
static

Definition at line 51 of file rpmchecksig.c.

References _, Fclose(), fd, fdFree(), fdLink(), Ferror(), fn, Fopen(), Fstrerror(), NULL, rpmlog(), RPMLOG_ERR, rpmTempFile(), and void.

Referenced by copyFile(), and rpmReSign().

static rpmRC readFile ( FD_t  fd,
const char *  fn 
)
static
int rpmVerifySignatures ( QVA_t  qva,
rpmts  ts,
void _fd,
const char *  fn 
)

Variable Documentation

int _print_pkts = 0

Definition at line 47 of file rpmchecksig.c.