* Mon Apr 22 2013 Kai Engert <kaie@redhat.com> - 2012.87-12

- Use both label and serial to identify cert during conversion, rhbz#927601
- Add myself as contributor to certdata2.pem.py and remove use of rcs/ident.
  (thanks to Michael Shuler for suggesting to do so)
- Update source URLs and comments, add source file for version information.
This commit is contained in:
Kai Engert 2013-04-22 14:58:59 +02:00
parent 34f352da5f
commit b2e71a9f9a
3 changed files with 96 additions and 22 deletions

View File

@ -12,13 +12,13 @@ Name: ca-certificates
# For the package version number, we use: year.{upstream version} # For the package version number, we use: year.{upstream version}
# #
# The {upstream version} can be found as symbol NSS_BUILTINS_LIBRARY_VERSION at # The {upstream version} can be found as symbol NSS_BUILTINS_LIBRARY_VERSION at
# http://hg.mozilla.org/projects/nss/file/default/lib/ckfw/builtins/nssckbi.h # http://hg.mozilla.org/projects/nss/raw-file/default/lib/ckfw/builtins/nssckbi.h
# which corresponds to # which corresponds to
# http://hg.mozilla.org/projects/nss/file/default/lib/ckfw/builtins/certdata.txt # http://hg.mozilla.org/projects/nss/raw-file/default/lib/ckfw/builtins/certdata.txt
# (these revisions are the tip of development and might be unreleased). # (these revisions are the tip of development and might be unreleased).
# For the latest release used in RTM versions of Mozilla Firefox, check: # For the latest release used in RTM versions of Mozilla Firefox, check:
# https://hg.mozilla.org/releases/mozilla-release/file/default/security/nss/lib/ckfw/builtins/nssckbi.h # https://hg.mozilla.org/releases/mozilla-release/raw-file/default/security/nss/lib/ckfw/builtins/nssckbi.h
# https://hg.mozilla.org/releases/mozilla-release/file/default/security/nss/lib/ckfw/builtins/certdata.txt # https://hg.mozilla.org/releases/mozilla-release/raw-file/default/security/nss/lib/ckfw/builtins/certdata.txt
# #
# (until 2012.87 the version was based on the cvs revision ID of certdata.txt, # (until 2012.87 the version was based on the cvs revision ID of certdata.txt,
# but in 2013 the NSS projected was migrated to HG. Old version 2012.87 is # but in 2013 the NSS projected was migrated to HG. Old version 2012.87 is
@ -27,16 +27,18 @@ Name: ca-certificates
# because all future versions will start with 2013 or larger.) # because all future versions will start with 2013 or larger.)
Version: 2012.87 Version: 2012.87
Release: 11%{?dist} Release: 12%{?dist}
License: Public Domain License: Public Domain
Group: System Environment/Base Group: System Environment/Base
URL: http://www.mozilla.org/ URL: http://www.mozilla.org/
#Please always update both certdata.txt and nssckbi.h
Source0: certdata.txt Source0: certdata.txt
Source1: update-ca-trust Source1: nssckbi.h
Source2: trust-fixes Source2: update-ca-trust
Source3: certdata2pem.py Source3: trust-fixes
Source4: certdata2pem.py
Source11: README.usr Source11: README.usr
Source12: README.etc Source12: README.etc
Source13: README.extr Source13: README.extr
@ -68,7 +70,7 @@ mkdir %{name}/java
pushd %{name}/certs pushd %{name}/certs
pwd pwd
cp %{SOURCE0} . cp %{SOURCE0} .
python %{SOURCE3} >c2p.log 2>c2p.err python %{SOURCE4} >c2p.log 2>c2p.err
popd popd
pushd %{name} pushd %{name}
( (
@ -78,11 +80,12 @@ pushd %{name}
# These certificates are in the OpenSSL "TRUSTED CERTIFICATE" # These certificates are in the OpenSSL "TRUSTED CERTIFICATE"
# format and have trust bits set accordingly. # format and have trust bits set accordingly.
# #
# Source: mozilla/security/nss/lib/ckfw/builtins/certdata.txt # Source: nss/lib/ckfw/builtins/certdata.txt
# Source: nss/lib/ckfw/builtins/nssckbi.h
# #
# Generated from: # Generated from:
EOF EOF
ident -q %{SOURCE0} | sed '1d;s/^/#/'; cat %{SOURCE1} |grep -w NSS_BUILTINS_LIBRARY_VERSION | awk '{print "# " $2 " " $3}';
echo '#'; echo '#';
) > %{trusted_all_bundle} ) > %{trusted_all_bundle}
for f in certs/*.crt; do for f in certs/*.crt; do
@ -112,7 +115,7 @@ EOF
cat "$p" >> %{bundle_supplement} cat "$p" >> %{bundle_supplement}
done done
# Append our trust fixes # Append our trust fixes
cat %{SOURCE2} >> %{bundle_supplement} cat %{SOURCE3} >> %{bundle_supplement}
popd popd
@ -150,7 +153,7 @@ touch -r %{SOURCE0} $RPM_BUILD_ROOT%{_datadir}/pki/ca-trust-source/%{bundle_supp
# TODO: consider to dynamically create the update-ca-trust script from within # TODO: consider to dynamically create the update-ca-trust script from within
# this .spec file, in order to have the output file+directory names at once place only. # this .spec file, in order to have the output file+directory names at once place only.
install -p -m 755 %{SOURCE1} $RPM_BUILD_ROOT%{_bindir}/update-ca-trust install -p -m 755 %{SOURCE2} $RPM_BUILD_ROOT%{_bindir}/update-ca-trust
# touch ghosted files that will be extracted dynamically # touch ghosted files that will be extracted dynamically
touch $RPM_BUILD_ROOT%{catrustdir}/extracted/pem/tls-ca-bundle.pem touch $RPM_BUILD_ROOT%{catrustdir}/extracted/pem/tls-ca-bundle.pem
@ -271,6 +274,12 @@ fi
%changelog %changelog
* Mon Apr 22 2013 Kai Engert <kaie@redhat.com> - 2012.87-12
- Use both label and serial to identify cert during conversion, rhbz#927601
- Add myself as contributor to certdata2.pem.py and remove use of rcs/ident.
(thanks to Michael Shuler for suggesting to do so)
- Update source URLs and comments, add source file for version information.
* Tue Mar 19 2013 Kai Engert <kaie@redhat.com> - 2012.87-11 * Tue Mar 19 2013 Kai Engert <kaie@redhat.com> - 2012.87-11
- adjust to changed and new functionality provided by p11-kit 0.17.3 - adjust to changed and new functionality provided by p11-kit 0.17.3
- updated READMEs to describe the new directory-specific treatment of files - updated READMEs to describe the new directory-specific treatment of files

View File

@ -4,6 +4,7 @@
# certdata2pem.py - splits certdata.txt into multiple files # certdata2pem.py - splits certdata.txt into multiple files
# #
# Copyright (C) 2009 Philipp Kern <pkern@debian.org> # Copyright (C) 2009 Philipp Kern <pkern@debian.org>
# Copyright (C) 2013 Kai Engert <kaie@redhat.com>
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
@ -29,6 +30,9 @@ import urllib
objects = [] objects = []
def printable_serial(obj):
return ".".join(map(lambda x:str(ord(x)), obj['CKA_SERIAL_NUMBER']))
# Dirty file parser. # Dirty file parser.
in_data, in_multiline, in_obj = False, False, False in_data, in_multiline, in_obj = False, False, False
field, type, value, obj = None, None, None, dict() field, type, value, obj = None, None, None, dict()
@ -85,18 +89,18 @@ trustmap = dict()
for obj in objects: for obj in objects:
if obj['CKA_CLASS'] != 'CKO_NSS_TRUST': if obj['CKA_CLASS'] != 'CKO_NSS_TRUST':
continue continue
label = obj['CKA_LABEL'] key = obj['CKA_LABEL'] + printable_serial(obj)
trustmap[label] = obj trustmap[key] = obj
print " added trust", label print " added trust", key
# Build up cert database. # Build up cert database.
certmap = dict() certmap = dict()
for obj in objects: for obj in objects:
if obj['CKA_CLASS'] != 'CKO_CERTIFICATE': if obj['CKA_CLASS'] != 'CKO_CERTIFICATE':
continue continue
label = obj['CKA_LABEL'] key = obj['CKA_LABEL'] + printable_serial(obj)
certmap[label] = obj certmap[key] = obj
print " added cert", label print " added cert", key
def obj_to_filename(obj): def obj_to_filename(obj):
label = obj['CKA_LABEL'][1:-1] label = obj['CKA_LABEL'][1:-1]
@ -106,7 +110,7 @@ def obj_to_filename(obj):
.replace(')', '=')\ .replace(')', '=')\
.replace(',', '_') .replace(',', '_')
label = re.sub(r'\\x[0-9a-fA-F]{2}', lambda m:chr(int(m.group(0)[2:], 16)), label) label = re.sub(r'\\x[0-9a-fA-F]{2}', lambda m:chr(int(m.group(0)[2:], 16)), label)
serial = ".".join(map(lambda x:str(ord(x)), obj['CKA_SERIAL_NUMBER'])) serial = printable_serial(obj)
return label + ":" + serial return label + ":" + serial
trust_types = { trust_types = {
@ -137,7 +141,8 @@ openssl_trust = {
for tobj in objects: for tobj in objects:
if tobj['CKA_CLASS'] == 'CKO_NSS_TRUST': if tobj['CKA_CLASS'] == 'CKO_NSS_TRUST':
print "producing trust for " + tobj['CKA_LABEL'] key = tobj['CKA_LABEL'] + printable_serial(tobj)
print "producing trust for " + key
trustbits = [] trustbits = []
distrustbits = [] distrustbits = []
openssl_trustflags = [] openssl_trustflags = []
@ -154,7 +159,7 @@ for tobj in objects:
fname = obj_to_filename(tobj) fname = obj_to_filename(tobj)
try: try:
obj = certmap[tobj['CKA_LABEL']] obj = certmap[key]
except: except:
obj = None obj = None

60
nssckbi.h Normal file
View File

@ -0,0 +1,60 @@
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef NSSCKBI_H
#define NSSCKBI_H
/*
* NSS BUILTINS Version numbers.
*
* These are the version numbers for the builtins module packaged with
* this release on NSS. To determine the version numbers of the builtin
* module you are using, use the appropriate PKCS #11 calls.
*
* These version numbers detail changes to the PKCS #11 interface. They map
* to the PKCS #11 spec versions.
*/
#define NSS_BUILTINS_CRYPTOKI_VERSION_MAJOR 2
#define NSS_BUILTINS_CRYPTOKI_VERSION_MINOR 20
/* These version numbers detail the changes
* to the list of trusted certificates.
*
* The NSS_BUILTINS_LIBRARY_VERSION_MINOR macro needs to be bumped
* for each NSS minor release AND whenever we change the list of
* trusted certificates. 10 minor versions are allocated for each
* NSS 3.x branch as follows, allowing us to change the list of
* trusted certificates up to 9 times on each branch.
* - NSS 3.5 branch: 3-9
* - NSS 3.6 branch: 10-19
* - NSS 3.7 branch: 20-29
* - NSS 3.8 branch: 30-39
* - NSS 3.9 branch: 40-49
* - NSS 3.10 branch: 50-59
* - NSS 3.11 branch: 60-69
* ...
* - NSS 3.12 branch: 70-89
* - NSS 3.13 branch: 90-99
* - NSS 3.14 branch: 100-109
* ...
* - NSS 3.29 branch: 250-255
*
* NSS_BUILTINS_LIBRARY_VERSION_MINOR is a CK_BYTE. It's not clear
* whether we may use its full range (0-255) or only 0-99 because
* of the comment in the CK_VERSION type definition.
*/
#define NSS_BUILTINS_LIBRARY_VERSION_MAJOR 1
#define NSS_BUILTINS_LIBRARY_VERSION_MINOR 94
#define NSS_BUILTINS_LIBRARY_VERSION "1.94"
/* These version numbers detail the semantic changes to the ckfw engine. */
#define NSS_BUILTINS_HARDWARE_VERSION_MAJOR 1
#define NSS_BUILTINS_HARDWARE_VERSION_MINOR 0
/* These version numbers detail the semantic changes to ckbi itself
* (new PKCS #11 objects), etc. */
#define NSS_BUILTINS_FIRMWARE_VERSION_MAJOR 1
#define NSS_BUILTINS_FIRMWARE_VERSION_MINOR 0
#endif /* NSSCKBI_H */