xref: /freebsd/crypto/heimdal/lib/hx509/test_windows.in (revision 6a068746777241722b2b32c5d0bc443a2a64d80b)
1c19800e8SDoug Rabson#!/bin/sh
2c19800e8SDoug Rabson#
3*ae771770SStanislav Sedov# Copyright (c) 2007 Kungliga Tekniska Högskolan
4c19800e8SDoug Rabson# (Royal Institute of Technology, Stockholm, Sweden).
5c19800e8SDoug Rabson# All rights reserved.
6c19800e8SDoug Rabson#
7c19800e8SDoug Rabson# Redistribution and use in source and binary forms, with or without
8c19800e8SDoug Rabson# modification, are permitted provided that the following conditions
9c19800e8SDoug Rabson# are met:
10c19800e8SDoug Rabson#
11c19800e8SDoug Rabson# 1. Redistributions of source code must retain the above copyright
12c19800e8SDoug Rabson#    notice, this list of conditions and the following disclaimer.
13c19800e8SDoug Rabson#
14c19800e8SDoug Rabson# 2. Redistributions in binary form must reproduce the above copyright
15c19800e8SDoug Rabson#    notice, this list of conditions and the following disclaimer in the
16c19800e8SDoug Rabson#    documentation and/or other materials provided with the distribution.
17c19800e8SDoug Rabson#
18c19800e8SDoug Rabson# 3. Neither the name of the Institute nor the names of its contributors
19c19800e8SDoug Rabson#    may be used to endorse or promote products derived from this software
20c19800e8SDoug Rabson#    without specific prior written permission.
21c19800e8SDoug Rabson#
22c19800e8SDoug Rabson# THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
23c19800e8SDoug Rabson# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24c19800e8SDoug Rabson# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25c19800e8SDoug Rabson# ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
26c19800e8SDoug Rabson# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27c19800e8SDoug Rabson# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28c19800e8SDoug Rabson# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29c19800e8SDoug Rabson# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30c19800e8SDoug Rabson# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31c19800e8SDoug Rabson# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32c19800e8SDoug Rabson# SUCH DAMAGE.
33c19800e8SDoug Rabson#
34*ae771770SStanislav Sedov# $Id$
35c19800e8SDoug Rabson#
36c19800e8SDoug Rabson
37c19800e8SDoug Rabsonsrcdir="@srcdir@"
38c19800e8SDoug Rabsonobjdir="@objdir@"
39c19800e8SDoug Rabson
40c19800e8SDoug Rabsonstat="--statistic-file=${objdir}/statfile"
41c19800e8SDoug Rabson
42c19800e8SDoug Rabsonhxtool="${TESTS_ENVIRONMENT} ./hxtool ${stat}"
43c19800e8SDoug Rabson
44c19800e8SDoug Rabsonif ${hxtool} info | grep 'rsa: hcrypto null RSA' > /dev/null ; then
45c19800e8SDoug Rabson    exit 77
46c19800e8SDoug Rabsonfi
47c19800e8SDoug Rabsonif ${hxtool} info | grep 'rand: not available' > /dev/null ; then
48c19800e8SDoug Rabson    exit 77
49c19800e8SDoug Rabsonfi
50c19800e8SDoug Rabson
51c19800e8SDoug Rabsonecho "Create trust anchor"
52c19800e8SDoug Rabson${hxtool} issue-certificate \
53c19800e8SDoug Rabson    --self-signed \
54c19800e8SDoug Rabson    --issue-ca \
55c19800e8SDoug Rabson    --generate-key=rsa \
56c19800e8SDoug Rabson    --subject="CN=Windows-CA,DC=heimdal,DC=pki" \
57c19800e8SDoug Rabson    --lifetime=10years \
58c19800e8SDoug Rabson    --certificate="FILE:wca.pem" || exit 1
59c19800e8SDoug Rabson
60c19800e8SDoug Rabsonecho "Create domain controller cert"
61c19800e8SDoug Rabson${hxtool} issue-certificate \
62c19800e8SDoug Rabson    --type="pkinit-kdc" \
63c19800e8SDoug Rabson    --pk-init-principal="krbtgt/HEIMDAL.PKI@HEIMDAL.PKI" \
64c19800e8SDoug Rabson    --hostname=kdc.heimdal.pki \
65c19800e8SDoug Rabson    --generate-key=rsa \
66c19800e8SDoug Rabson    --subject="CN=kdc.heimdal.pki,dc=heimdal,dc=pki" \
67c19800e8SDoug Rabson    --certificate="FILE:wdc.pem" \
68c19800e8SDoug Rabson    --domain-controller \
69c19800e8SDoug Rabson    --crl-uri="http://www.test.h5l.se/test-hemdal-pki-crl1.crl" \
70c19800e8SDoug Rabson    --ca-certificate=FILE:wca.pem || exit 1
71c19800e8SDoug Rabson
72c19800e8SDoug Rabson
73c19800e8SDoug Rabsonecho "Create user cert"
74c19800e8SDoug Rabson${hxtool} issue-certificate \
75c19800e8SDoug Rabson    --type="pkinit-client" \
76c19800e8SDoug Rabson    --pk-init-principal="user@HEIMDAL.PKI" \
77c19800e8SDoug Rabson    --generate-key=rsa \
78c19800e8SDoug Rabson    --subject="CN=User,DC=heimdal,DC=pki" \
79c19800e8SDoug Rabson    --ms-upn="user@heimdal.pki" \
80c19800e8SDoug Rabson    --crl-uri="http://www.test.h5l.se/test-hemdal-pki-crl1.crl" \
81c19800e8SDoug Rabson    --certificate="FILE:wuser.pem" \
82c19800e8SDoug Rabson    --ca-certificate=FILE:wca.pem || exit 1
83c19800e8SDoug Rabson
84c19800e8SDoug Rabsonecho "Create crl"
85c19800e8SDoug Rabson${hxtool} crl-sign \
86c19800e8SDoug Rabson	--crl-file=wcrl.crl \
87c19800e8SDoug Rabson	--signer=FILE:wca.pem || exit 1
88c19800e8SDoug Rabson
89c19800e8SDoug Rabsonexit 0
90