rpm  4.18.2
rpmpgp.h
Go to the documentation of this file.
1 #ifndef H_RPMPGP
2 #define H_RPMPGP
3 
17 #include <string.h>
18 #include <stdio.h>
19 #include <stdlib.h>
20 #include <rpm/rpmtypes.h>
21 #include <rpm/rpmstring.h>
22 #include <rpm/rpmcrypto.h>
23 
24 #ifdef __cplusplus
25 extern "C" {
26 #endif
27 
30 typedef struct pgpDig_s * pgpDig;
31 
34 typedef struct pgpDigParams_s * pgpDigParams;
35 
36 
40 #define PGP_KEYID_LEN 8
41 
42 typedef uint8_t pgpKeyID_t[PGP_KEYID_LEN];
43 typedef uint8_t pgpTime_t[4];
44 
52 typedef enum pgpTag_e {
65  PGPTAG_TRUST = 12,
71  PGPTAG_MDC = 19,
76 } pgpTag;
77 
112 typedef struct pgpPktPubkey_s {
113  uint8_t version;
114  pgpKeyID_t keyid;
115  uint8_t algo;
116 } pgpPktPubkey;
117 
118 
125 typedef enum pgpSigType_e {
143 } pgpSigType;
144 
169 typedef enum pgpPubkeyAlgo_e {
180 } pgpPubkeyAlgo;
181 
206 typedef enum pgpSymkeyAlgo_e {
219 } pgpSymkeyAlgo;
220 
236 typedef enum pgpCompressAlgo_e {
242 
266 typedef enum pgpHashAlgo_e {
277 } pgpHashAlgo;
278 
285 typedef enum pgpCurveId_e {
293 } pgpCurveId;
294 
316 typedef struct pgpPktSigV3_s {
317  uint8_t version;
318  uint8_t hashlen;
319  uint8_t sigtype;
320  pgpTime_t time;
321  pgpKeyID_t signid;
322  uint8_t pubkey_algo;
323  uint8_t hash_algo;
324  uint8_t signhash16[2];
325 } * pgpPktSigV3;
326 
348 typedef struct pgpPktSigV4_s {
349  uint8_t version;
350  uint8_t sigtype;
351  uint8_t pubkey_algo;
352  uint8_t hash_algo;
353  uint8_t hashlen[2];
354 } * pgpPktSigV4;
355 
422 typedef enum pgpSubType_e {
461 } pgpSubType;
462 
483 typedef union pgpPktSig_u {
486 } * pgpPktSig;
487 
516 typedef struct pgpPktSymkey_s {
517  uint8_t version;
518  uint8_t symkey_algo;
519  uint8_t s2k[1];
520 } pgpPktSymkey;
521 
551 typedef struct pgpPktOnepass_s {
552  uint8_t version;
553  uint8_t sigtype;
554  uint8_t hash_algo;
555  uint8_t pubkey_algo;
556  pgpKeyID_t signid;
557  uint8_t nested;
558 } * pgpPktOnepass;
559 
632 typedef struct pgpPktKeyV3_s {
633  uint8_t version;
634  pgpTime_t time;
635  uint8_t valid[2];
636  uint8_t pubkey_algo;
637 } * pgpPktKeyV3;
638 
675 typedef struct pgpPktKeyV4_s {
676  uint8_t version;
677  pgpTime_t time;
678  uint8_t pubkey_algo;
679 } * pgpPktKeyV4;
680 
745 typedef union pgpPktKey_u {
748 } pgpPktKey;
749 
774 typedef struct pgpPktCdata_s {
775  uint8_t compressalgo;
776  uint8_t data[1];
777 } pgpPktCdata;
778 
813 typedef struct pgpPktEdata_s {
814  uint8_t data[1];
815 } pgpPktEdata;
816 
864 typedef struct pgpPktLdata_s {
865  uint8_t format;
866  uint8_t filenamelen;
867  uint8_t filename[1];
868 } pgpPktLdata;
869 
883 typedef struct pgpPktTrust_s {
884  uint8_t flag;
885 } pgpPktTrust;
886 
897 typedef struct pgpPktUid_s {
898  uint8_t userid[1];
899 } pgpPktUid;
900 
903 union pgpPktPre_u {
915 };
916 
919 typedef enum pgpArmor_e {
927 #define PGPARMOR_ERROR PGPARMOR_ERR_NO_BEGIN_PGP
936 } pgpArmor;
937 
940 typedef enum pgpArmorKey_e {
946 } pgpArmorKey;
947 
948 typedef enum pgpValType_e {
959 } pgpValType;
960 
967 const char * pgpValString(pgpValType type, uint8_t val);
968 
975 static inline
976 unsigned int pgpGrab(const uint8_t *s, size_t nbytes)
977 {
978  size_t i = 0;
979  size_t nb = (nbytes <= sizeof(i) ? nbytes : sizeof(i));
980  while (nb--)
981  i = (i << 8) | *s++;
982  return i;
983 }
984 
993 int pgpPubkeyFingerprint(const uint8_t * pkt, size_t pktlen,
994  uint8_t **fp, size_t *fplen);
995 
1003 int pgpPubkeyKeyID(const uint8_t * pkt, size_t pktlen, pgpKeyID_t keyid);
1004 
1013 int pgpPrtParams(const uint8_t *pkts, size_t pktlen, unsigned int pkttype,
1014  pgpDigParams * ret);
1015 
1025 int pgpPrtParamsSubkeys(const uint8_t *pkts, size_t pktlen,
1026  pgpDigParams mainkey, pgpDigParams **subkeys,
1027  int *subkeysCount);
1038 int pgpPrtPkts(const uint8_t *pkts, size_t pktlen, pgpDig dig, int printing);
1039 
1047 pgpArmor pgpReadPkts(const char * fn, uint8_t ** pkt, size_t * pktlen);
1048 
1056 pgpArmor pgpParsePkts(const char *armor, uint8_t ** pkt, size_t * pktlen);
1057 
1070 int pgpPubKeyCertLen(const uint8_t *pkts, size_t pktslen, size_t *certlen);
1071 
1096 rpmRC pgpPubKeyLint(const uint8_t *pkts, size_t pktslen, char **explanation);
1097 
1105 char * pgpArmorWrap(int atype, const unsigned char * s, size_t ns);
1106 
1113 pgpDig pgpNewDig(void);
1114 
1121 void pgpCleanDig(pgpDig dig);
1122 
1130 pgpDig pgpFreeDig(pgpDig dig);
1131 
1138 pgpDigParams pgpDigGetParams(pgpDig dig, unsigned int pkttype);
1139 
1146 int pgpDigParamsCmp(pgpDigParams p1, pgpDigParams p2);
1147 
1154 unsigned int pgpDigParamsAlgo(pgpDigParams digp, unsigned int algotype);
1155 
1172 const uint8_t *pgpDigParamsSignID(pgpDigParams digp);
1173 
1192 const char *pgpDigParamsUserID(pgpDigParams digp);
1193 
1211 int pgpDigParamsVersion(pgpDigParams digp);
1212 
1219 uint32_t pgpDigParamsCreationTime(pgpDigParams digp);
1220 
1226 pgpDigParams pgpDigParamsFree(pgpDigParams digp);
1227 
1235 rpmRC pgpVerifySignature(pgpDigParams key, pgpDigParams sig, DIGEST_CTX hashctx);
1236 
1245 rpmRC pgpVerifySig(pgpDig dig, DIGEST_CTX hashctx);
1246 
1254 int pgpSignatureType(pgpDigParams sig);
1255 
1261 char *pgpIdentItem(pgpDigParams digp);
1262 
1263 #ifdef __cplusplus
1264 }
1265 #endif
1266 
1267 #endif /* H_RPMPGP */
uint8_t userid[1]
Definition: rpmpgp.h:898
int pgpSignatureType(pgpDigParams sig)
Return the type of a PGP signature.
struct pgpPktSigV3_s v3
Definition: rpmpgp.h:484
5.5.1.
Definition: rpmpgp.h:632
uint8_t hash_algo
Definition: rpmpgp.h:352
struct pgpPktLdata_s pgpPktLdata
5.8.
5.7.
Definition: rpmpgp.h:813
pgpArmor pgpParsePkts(const char *armor, uint8_t **pkt, size_t *pktlen)
Parse armored OpenPGP packets from memory.
enum pgpPubkeyAlgo_e pgpPubkeyAlgo
9.1.
pgpDig pgpNewDig(void)
Create a container for parsed OpenPGP packet(s).
uint8_t hash_algo
Definition: rpmpgp.h:554
struct pgpPktSigV4_s * pgpPktSigV4
5.2.3.
struct pgpPktTrust_s pgpPktTrust
5.10.
struct pgpPktPubkey_s pgpPktPubkey
5.1.
const uint8_t * pgpDigParamsSignID(pgpDigParams digp)
Returns the issuer or the object's Key ID.
pgpPktCdata cdata
Definition: rpmpgp.h:909
uint8_t pubkey_algo
Definition: rpmpgp.h:678
const char * pgpDigParamsUserID(pgpDigParams digp)
Retrieve the primary User ID, if any.
5.6.
Definition: rpmpgp.h:774
struct pgpPktKeyV3_s * pgpPktKeyV3
5.5.1.
pgpValType_e
Definition: rpmpgp.h:948
enum pgpSymkeyAlgo_e pgpSymkeyAlgo
9.2.
5.11.
Definition: rpmpgp.h:897
pgpPktOnepass onepass
Definition: rpmpgp.h:907
struct pgpPktCdata_s pgpPktCdata
5.6.
pgpTime_t time
Definition: rpmpgp.h:677
int pgpDigParamsCmp(pgpDigParams p1, pgpDigParams p2)
Compare OpenPGP packet parameters param p1 1st parameter container param p2 2nd parameter container r...
pgpTag_e
4.3.
Definition: rpmpgp.h:52
pgpArmor pgpReadPkts(const char *fn, uint8_t **pkt, size_t *pktlen)
Parse armored OpenPGP packets from a file.
uint8_t version
Definition: rpmpgp.h:317
uint8_t version
Definition: rpmpgp.h:633
String manipulation helper functions.
pgpCurveId_e
ECC Curves.
Definition: rpmpgp.h:285
uint8_t signhash16[2]
Definition: rpmpgp.h:324
pgpPubkeyAlgo_e
9.1.
Definition: rpmpgp.h:169
uint8_t version
Definition: rpmpgp.h:552
struct pgpPktKeyV4_s * pgpPktKeyV4
The version 4 format is similar to the version 3 format except for the absence of a validity period...
Typedefs for RPM abstract data types.
5.2.3.
Definition: rpmpgp.h:348
enum pgpCurveId_e pgpCurveId
ECC Curves.
enum pgpCompressAlgo_e pgpCompressAlgo
9.3.
int pgpDigParamsVersion(pgpDigParams digp)
Retrieve the object's version.
uint8_t version
Definition: rpmpgp.h:113
pgpPktSig sig
Definition: rpmpgp.h:905
enum pgpArmorKey_e pgpArmorKey
uint8_t version
Definition: rpmpgp.h:349
uint8_t valid[2]
Definition: rpmpgp.h:635
pgpArmorKey_e
Definition: rpmpgp.h:940
uint8_t pubkey_algo
Definition: rpmpgp.h:555
pgpDig pgpFreeDig(pgpDig dig)
Destroy a container for parsed OpenPGP packet(s).
uint8_t flag
Definition: rpmpgp.h:884
struct pgpDig_s * pgpDig
Definition: rpmpgp.h:30
rpmRC pgpVerifySignature(pgpDigParams key, pgpDigParams sig, DIGEST_CTX hashctx)
Verify a PGP signature.
5.2.2.
Definition: rpmpgp.h:316
int pgpPubkeyKeyID(const uint8_t *pkt, size_t pktlen, pgpKeyID_t keyid)
Calculate OpenPGP public key Key ID.
5.5.3.
Definition: rpmpgp.h:745
uint8_t pgpKeyID_t[8]
Definition: rpmpgp.h:42
uint8_t s2k[1]
Definition: rpmpgp.h:519
static unsigned int pgpGrab(const uint8_t *s, size_t nbytes)
Return (native-endian) integer from big-endian representation.
Definition: rpmpgp.h:976
uint8_t pubkey_algo
Definition: rpmpgp.h:351
uint8_t data[1]
Definition: rpmpgp.h:776
pgpArmor_e
Definition: rpmpgp.h:919
pgpPktPubkey pubkey
Definition: rpmpgp.h:904
enum pgpHashAlgo_e pgpHashAlgo
9.4.
enum pgpValType_e pgpValType
struct pgpPktEdata_s pgpPktEdata
5.7.
uint8_t version
Definition: rpmpgp.h:517
uint8_t symkey_algo
Definition: rpmpgp.h:518
uint8_t data[1]
Definition: rpmpgp.h:814
uint8_t format
Definition: rpmpgp.h:865
uint8_t sigtype
Definition: rpmpgp.h:350
uint8_t hash_algo
Definition: rpmpgp.h:323
pgpPktKey key
Definition: rpmpgp.h:908
pgpDigParams pgpDigParamsFree(pgpDigParams digp)
Destroy parsed OpenPGP packet parameter(s).
pgpDigParams pgpDigGetParams(pgpDig dig, unsigned int pkttype)
Retrieve parameters for parsed OpenPGP packet(s).
union pgpPktKey_u pgpPktKey
5.5.3.
rpmRC pgpVerifySig(pgpDig dig, DIGEST_CTX hashctx)
Verify a PGP signature.
int pgpPubkeyFingerprint(const uint8_t *pkt, size_t pktlen, uint8_t **fp, size_t *fplen)
Calculate OpenPGP public key fingerprint.
enum pgpSubType_e pgpSubType
5.2.3.1.
#define PGP_KEYID_LEN
The length (in bytes) of a binary (not hex encoded) key ID.
Definition: rpmpgp.h:40
uint8_t algo
Definition: rpmpgp.h:115
pgpTime_t time
Definition: rpmpgp.h:634
pgpSubType_e
5.2.3.1.
Definition: rpmpgp.h:422
pgpPktLdata ldata
Definition: rpmpgp.h:912
char * pgpArmorWrap(int atype, const unsigned char *s, size_t ns)
Wrap a OpenPGP packets in ascii armor for transport.
uint8_t nested
Definition: rpmpgp.h:557
struct pgpPktUid_s pgpPktUid
5.11.
uint8_t compressalgo
Definition: rpmpgp.h:775
pgpHashAlgo_e
9.4.
Definition: rpmpgp.h:266
uint8_t filename[1]
Definition: rpmpgp.h:867
struct DIGEST_CTX_s * DIGEST_CTX
Definition: rpmcrypto.h:12
pgpTime_t time
Definition: rpmpgp.h:320
uint8_t hashlen[2]
Definition: rpmpgp.h:353
struct pgpPktSigV3_s * pgpPktSigV3
5.2.2.
pgpKeyID_t signid
Definition: rpmpgp.h:321
rpmRC pgpPubKeyLint(const uint8_t *pkts, size_t pktslen, char **explanation)
Lints the certificate.
pgpPktUid uid
Definition: rpmpgp.h:914
enum pgpTag_e pgpTag
4.3.
uint8_t pgpTime_t[4]
Definition: rpmpgp.h:43
uint32_t pgpDigParamsCreationTime(pgpDigParams digp)
Retrieve the object's creation time.
unsigned int pgpDigParamsAlgo(pgpDigParams digp, unsigned int algotype)
Retrieve OpenPGP algorithm parameters param digp parameter container param algotype PGPVAL_HASHALGO /...
uint8_t version
Definition: rpmpgp.h:676
uint8_t pubkey_algo
Definition: rpmpgp.h:636
char * pgpIdentItem(pgpDigParams digp)
Return a string identification of a PGP signature/pubkey.
pgpPktEdata edata
Definition: rpmpgp.h:910
pgpSigType_e
5.2.1.
Definition: rpmpgp.h:125
struct pgpPktKeyV4_s v4
Definition: rpmpgp.h:747
uint8_t hashlen
Definition: rpmpgp.h:318
pgpPktTrust tdata
Definition: rpmpgp.h:913
uint8_t pubkey_algo
Definition: rpmpgp.h:322
5.2.
Definition: rpmpgp.h:483
struct pgpPktSigV4_s v4
Definition: rpmpgp.h:485
pgpKeyID_t keyid
Definition: rpmpgp.h:114
struct pgpDigParams_s * pgpDigParams
Definition: rpmpgp.h:34
int pgpPubKeyCertLen(const uint8_t *pkts, size_t pktslen, size_t *certlen)
Return a length of the first public key certificate in a buffer given by pkts that contains one or mo...
struct pgpPktSymkey_s pgpPktSymkey
5.3.
pgpSymkeyAlgo_e
9.2.
Definition: rpmpgp.h:206
int pgpPrtParamsSubkeys(const uint8_t *pkts, size_t pktlen, pgpDigParams mainkey, pgpDigParams **subkeys, int *subkeysCount)
Parse subkey parameters from OpenPGP packet(s).
struct pgpPktKeyV3_s v3
Definition: rpmpgp.h:746
const char * pgpValString(pgpValType type, uint8_t val)
Return string representation of am OpenPGP value.
enum pgpSigType_e pgpSigType
5.2.1.
5.8.
Definition: rpmpgp.h:864
int pgpPrtParams(const uint8_t *pkts, size_t pktlen, unsigned int pkttype, pgpDigParams *ret)
Parse a OpenPGP packet(s).
union pgpPktSig_u * pgpPktSig
5.2.
uint8_t sigtype
Definition: rpmpgp.h:319
void pgpCleanDig(pgpDig dig)
Release (malloc'd) data from container.
pgpCompressAlgo_e
9.3.
Definition: rpmpgp.h:236
int pgpPrtPkts(const uint8_t *pkts, size_t pktlen, pgpDig dig, int printing)
Print/parse a OpenPGP packet(s).
The version 4 format is similar to the version 3 format except for the absence of a validity period...
Definition: rpmpgp.h:675
5.10.
Definition: rpmpgp.h:883
uint8_t sigtype
Definition: rpmpgp.h:553
pgpKeyID_t signid
Definition: rpmpgp.h:556
enum pgpArmor_e pgpArmor
uint8_t filenamelen
Definition: rpmpgp.h:866
enum rpmRC_e rpmRC
Package read return codes.
pgpPktSymkey symkey
Definition: rpmpgp.h:906
struct pgpPktOnepass_s * pgpPktOnepass
5.4.