* 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:
parent
34f352da5f
commit
b2e71a9f9a
@ -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
|
||||||
|
@ -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
60
nssckbi.h
Normal 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 */
|
Loading…
Reference in New Issue
Block a user