2018-06-13 17:26:48 +02:00
|
|
|
/*
|
|
|
|
* Copyright 2018 Paul Schaub.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2018-07-18 18:23:06 +02:00
|
|
|
package org.pgpainless.key.selection.key;
|
2018-06-07 18:12:13 +02:00
|
|
|
|
|
|
|
import java.util.HashSet;
|
|
|
|
import java.util.Iterator;
|
|
|
|
import java.util.Set;
|
|
|
|
|
|
|
|
import org.bouncycastle.openpgp.PGPSecretKey;
|
|
|
|
import org.bouncycastle.openpgp.PGPSecretKeyRing;
|
2018-07-18 18:23:06 +02:00
|
|
|
import org.pgpainless.util.MultiMap;
|
2018-06-07 18:12:13 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Key Selection Strategy which accepts {@link PGPSecretKey}s that are accepted by the abstract method
|
|
|
|
* {@link #accept(Object, Object)}.
|
|
|
|
*
|
|
|
|
* @param <O> Type that describes the owner of the key.
|
|
|
|
*/
|
|
|
|
public abstract class SecretKeySelectionStrategy<O> implements KeySelectionStrategy<PGPSecretKey, PGPSecretKeyRing, O> {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Set<PGPSecretKey> selectKeysFromKeyRing(O identifier, PGPSecretKeyRing ring) {
|
|
|
|
Set<PGPSecretKey> keys = new HashSet<>();
|
|
|
|
for (Iterator<PGPSecretKey> i = ring.getSecretKeys(); i.hasNext(); ) {
|
|
|
|
PGPSecretKey key = i.next();
|
|
|
|
if (accept(identifier, key)) keys.add(key);
|
|
|
|
}
|
|
|
|
return keys;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public MultiMap<O, PGPSecretKey> selectKeysFromKeyRings(MultiMap<O, PGPSecretKeyRing> keyRings) {
|
|
|
|
MultiMap<O, PGPSecretKey> keys = new MultiMap<>();
|
|
|
|
for (O identifier : keyRings.keySet()) {
|
|
|
|
for (PGPSecretKeyRing ring : keyRings.get(identifier)) {
|
|
|
|
keys.put(identifier, selectKeysFromKeyRing(identifier, ring));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return keys;
|
|
|
|
}
|
|
|
|
}
|