org.spongycastle.cms.RecipientInformationStore Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scprov-jdk15 Show documentation
Show all versions of scprov-jdk15 Show documentation
Spongy Castle is a package-rename (org.bouncycastle.* to org.spongycastle.*) of Bouncy Castle intended for Android.
Android ships with a stripped-down version of Bouncy Castle - this causes classloader collisions if you try to add
an alternative (updated/complete) Bouncy Castle jar.
This jar contains JCE provider and lightweight API for the Bouncy Castle Cryptography APIs for JDK 1.5.
package org.spongycastle.cms;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
public class RecipientInformationStore
{
private final List all; //ArrayList[RecipientInformation]
private final Map table = new HashMap(); // HashMap[RecipientID, ArrayList[RecipientInformation]]
public RecipientInformationStore(
Collection recipientInfos)
{
Iterator it = recipientInfos.iterator();
while (it.hasNext())
{
RecipientInformation recipientInformation = (RecipientInformation)it.next();
RecipientId rid = recipientInformation.getRID();
List list = (ArrayList)table.get(rid);
if (list == null)
{
list = new ArrayList(1);
table.put(rid, list);
}
list.add(recipientInformation);
}
this.all = new ArrayList(recipientInfos);
}
/**
* Return the first RecipientInformation object that matches the
* passed in selector. Null if there are no matches.
*
* @param selector to identify a recipient
* @return a single RecipientInformation object. Null if none matches.
*/
public RecipientInformation get(
RecipientId selector)
{
List list = (ArrayList)table.get(selector);
return list == null ? null : (RecipientInformation) list.get(0);
}
/**
* Return the number of recipients in the collection.
*
* @return number of recipients identified.
*/
public int size()
{
return all.size();
}
/**
* Return all recipients in the collection
*
* @return a collection of recipients.
*/
public Collection getRecipients()
{
return new ArrayList(all);
}
/**
* Return possible empty collection with recipients matching the passed in RecipientId
*
* @param selector a recipient id to select against.
* @return a collection of RecipientInformation objects.
*/
public Collection getRecipients(
RecipientId selector)
{
List list = (ArrayList)table.get(selector);
return list == null ? new ArrayList() : new ArrayList(list);
}
}