1f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project/*
2f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  Licensed to the Apache Software Foundation (ASF) under one or more
3f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  contributor license agreements.  See the NOTICE file distributed with
4f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  this work for additional information regarding copyright ownership.
5f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  The ASF licenses this file to You under the Apache License, Version 2.0
6f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  (the "License"); you may not use this file except in compliance with
7f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  the License.  You may obtain a copy of the License at
8f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
9f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *     http://www.apache.org/licenses/LICENSE-2.0
10f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
11f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  Unless required by applicable law or agreed to in writing, software
12f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  distributed under the License is distributed on an "AS IS" BASIS,
13f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  See the License for the specific language governing permissions and
15f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *  limitations under the License.
16f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
17f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
18f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpackage javax.net.ssl;
19f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
20f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport java.util.ArrayList;
21f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport java.util.Collections;
22f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport java.util.List;
23f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport java.security.KeyStore;
24f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
25f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project/**
26f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * The parameters for {@code KeyManager}s. The parameters are a list of
27f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * {@code KeyStore.Builder}s.
28a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson *
29a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson * @since 1.5
30a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson * @see KeyStore.Builder
31f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
32f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpublic class KeyStoreBuilderParameters implements ManagerFactoryParameters {
33f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
34a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson    private final List<KeyStore.Builder> ksbuilders;
35f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
36f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
37f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Creates a new {@code KeyStoreBuilderParameters} with the specified key
38f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * store builder.
39f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *
40f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * @param builder
41f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *            the key store builder.
42f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
43f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public KeyStoreBuilderParameters(KeyStore.Builder builder) {
44a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson        super();
45a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson        ksbuilders = Collections.singletonList(builder);
46f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
47f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
48f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
49f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Creates a new {@code KeyStoreBuilderParameters} with the specified list
50f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * of {@code KeyStore.Builder}s.
51f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *
52f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * @param parameters
53f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *            the list of key store builders
54f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * @throws IllegalArgumentException
55f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *             if the specified list is empty.
56f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
57a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson    @SuppressWarnings("unchecked")
58f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public KeyStoreBuilderParameters(List parameters) {
59a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson        super();
60f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (parameters == null) {
61f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            throw new NullPointerException("Builders list is null");
62f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
63f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (parameters.isEmpty()) {
64f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            throw new IllegalArgumentException("Builders list is empty");
65f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
66a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson        ksbuilders = Collections.unmodifiableList(new ArrayList<KeyStore.Builder>(parameters));
67f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
68f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
69f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
70f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Returns the unmodifiable list of {@code KeyStore.Builder}s associated
71f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * with this parameters instance.
72f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *
73f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * @return the unmodifiable list of {@code KeyStore.Builder}s.
74f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
75a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson    @SuppressWarnings("unchecked")
76f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public List getParameters() {
77a055db83f05034fcd5564ab5930e8d16d4ececfbJesse Wilson        return ksbuilders;
78f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
79f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project}
80