diff options
author | Panu Matilainen <pmatilai@redhat.com> | 2011-11-07 13:18:13 +0200 |
---|---|---|
committer | Panu Matilainen <pmatilai@redhat.com> | 2011-11-07 13:29:29 +0200 |
commit | 45c880304b78cc7e77a94a309303bc53f96024c6 (patch) | |
tree | 93f1dac02324f3c7381070dcc6314c73315c615a /sign/rpmgensig.c | |
parent | 41a3fda32b9092bbf5562b1716463480b99b78d0 (diff) | |
download | librpm-tizen-45c880304b78cc7e77a94a309303bc53f96024c6.tar.gz librpm-tizen-45c880304b78cc7e77a94a309303bc53f96024c6.tar.bz2 librpm-tizen-45c880304b78cc7e77a94a309303bc53f96024c6.zip |
Add an API for comparing two digest parameter containers
- Lift the digest parameter comparison from librpmsign to rpmpgp.c
where it really belongs.
Diffstat (limited to 'sign/rpmgensig.c')
-rw-r--r-- | sign/rpmgensig.c | 26 |
1 files changed, 3 insertions, 23 deletions
diff --git a/sign/rpmgensig.c b/sign/rpmgensig.c index 202b4cb6f..368f2aa41 100644 --- a/sign/rpmgensig.c +++ b/sign/rpmgensig.c @@ -372,33 +372,13 @@ static int sameSignature(rpmTagVal sigtag, Header h1, Header h2) { pgpDig dig1 = NULL; pgpDig dig2 = NULL; - pgpDigParams sig1 = getSig(h1, sigtag, &dig1); - pgpDigParams sig2 = getSig(h2, sigtag, &dig2); - int rc = 0; /* assume different, eg if either signature doesn't exist */ - /* XXX This part really belongs to rpmpgp.[ch] */ - if (sig1 && sig2) { + int rc = pgpDigParamsCmp(getSig(h1, sigtag, &dig1), + getSig(h2, sigtag, &dig2)); - /* XXX Should we compare something else too? */ - if (sig1->hash_algo != sig2->hash_algo) - goto exit; - if (sig1->pubkey_algo != sig2->pubkey_algo) - goto exit; - if (sig1->version != sig2->version) - goto exit; - if (sig1->sigtype != sig2->sigtype) - goto exit; - if (memcmp(sig1->signid, sig2->signid, sizeof(sig1->signid)) != 0) - goto exit; - - /* Parameters match, assume same signature */ - rc = 1; - } - -exit: pgpFreeDig(dig1); pgpFreeDig(dig2); - return rc; + return (rc == 0); } static int replaceSignature(Header sigh, const char *sigtarget, |