package net.deterlab.abac; import java.io.*; import java.math.*; import java.util.*; import java.security.*; import java.security.cert.*; import javax.security.auth.x500.*; import org.bouncycastle.asn1.*; import org.bouncycastle.asn1.x509.*; import org.bouncycastle.x509.*; import org.bouncycastle.x509.util.*; import org.bouncycastle.openssl.*; /** * An Internal Credential, used to represent extra arcs in the proof graph. It * should never be converted to a cert or output. * @author ISI ABAC team * @version 1.4 */ public class InternalCredential extends Credential { /** * Create an empty InternalCredential. */ public InternalCredential() { super(); } /** * Create a credential from a head and tail role. This credential has no * underlying certificate, and cannot be exported or used in real proofs. * @param head the Role at the head of the credential * @param tail the Role at the tail of the credential */ public InternalCredential(Role head, Role tail) {super(head, tail); } /** * Create a credential from an attribute cert in a file. This will always * fail for in InternalCredential. * @param filename a String containing the filename to read * @param ids a Collection of Identities to use in validating the cert * @throws CertInvalidException if the stream is unparsable * @throws MissingIssuerException if none of the Identities can validate the * certificate * @throws BadSignatureException if the signature check fails */ public InternalCredential(String filename, Collection ids) throws ABACException { this(); } /** * Create a credential from an attribute cert in a file. This will always * * fail for in InternalCredential. * @param file the File to read * @param ids a Collection of Identities to use in validating the cert * @throws CertInvalidException if the stream is unparsable * @throws MissingIssuerException if none of the Identities can validate the * certificate * @throws BadSignatureException if the signature check fails */ public InternalCredential(File file, Collection ids) throws ABACException { this(); } /** * Create a credential from an InputStream. This will always * fail for in InternalCredential. * @param ids a Collection of Identities to use in validating the cert * @throws CertInvalidException if the stream is unparsable * @throws MissingIssuerException if none of the Identities can validate the * certificate * @throws BadSignatureException if the signature check fails */ public InternalCredential(InputStream s, Collection ids) throws ABACException { this(); } /** * Create a certificate from this credential issued by the given identity. * This will always fail for an InternalCredential. * @param i the Identity that will issue the certificate * @throws ABACException for Credential-specific errors * @throws MissingIssuerException the identity is invalid * @throws BadSignatureException if the signature creation fails */ public void make_cert(Identity i) throws ABACException { throw new ABACException("Cannot create certificate for " + "an InternalCredential"); } /** * Output the DER formatted attribute certificate associated with this * Credential to the OutputStream. This will always fail for an * InternalCredential. * @param s the OutputStream on which to write * @throws IOException if there is an error writing. */ public void write(OutputStream s) throws IOException { throw new IOException("Cannot write certificate for " + "an InternalCredential"); } /** * Output the DER formatted attribute certificate associated with this * Credential to the filename given. This will always fail for an * InternalCredential. * @param fn a String containing the output filename * @throws IOException if there is an error writing. */ public void write(String fn) throws IOException, FileNotFoundException { write((OutputStream) null); } /** * Return true if this Credential has a certificate associated. A jabac * extension. Always false for an InternalCredential. * @return true if this Credential has a certificate associated. */ public boolean hasCertificate() { return false; } }