当前位置: 首页>>代码示例>>Java>>正文


Java KeyCertificate类代码示例

本文整理汇总了Java中com.subgraph.orchid.KeyCertificate的典型用法代码示例。如果您正苦于以下问题:Java KeyCertificate类的具体用法?Java KeyCertificate怎么用?Java KeyCertificate使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


KeyCertificate类属于com.subgraph.orchid包,在下文中一共展示了KeyCertificate类的13个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: verifySignatureForTrustedAuthority

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
private SignatureStatus verifySignatureForTrustedAuthority(DirectoryServer trustedAuthority, DirectorySignature signature) {
	final KeyCertificate certificate = trustedAuthority.getCertificateByFingerprint(signature.getSigningKeyDigest());
	if(certificate == null) {
		logger.fine("Missing certificate for signing key: "+ signature.getSigningKeyDigest());
		addRequiredCertificateForSignature(signature);
		return SignatureStatus.STATUS_NEED_CERTS;
	}
	if(certificate.isExpired()) {
		return SignatureStatus.STATUS_FAILED;
	}
	
	final TorPublicKey signingKey = certificate.getAuthoritySigningKey();
	final HexDigest d = (signature.useSha256()) ? signingHash256 : signingHash;
	if(!signingKey.verifySignature(signature.getSignature(), d)) {
		logger.warning("Signature failed on consensus for signing key: "+ signature.getSigningKeyDigest());
		return SignatureStatus.STATUS_FAILED;
	}
	return SignatureStatus.STATUS_VERIFIED;
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:20,代码来源:ConsensusDocumentImpl.java

示例2: loadCertificates

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
private void loadCertificates(ByteBuffer buffer) {
	final DocumentParser<KeyCertificate> parser = parserFactory.createKeyCertificateParser(buffer);
	final DocumentParsingResult<KeyCertificate> result = parser.parse();
	if(testResult(result, "certificates")) {
		for(KeyCertificate cert: result.getParsedDocuments()) {
			addCertificate(cert);
		}
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:10,代码来源:DirectoryImpl.java

示例3: addCertificate

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
public void addCertificate(KeyCertificate certificate) {
	synchronized(TrustedAuthorities.getInstance()) {
		final boolean wasRequired = removeRequiredCertificate(certificate);
		final DirectoryServer as = TrustedAuthorities.getInstance().getAuthorityServerByIdentity(certificate.getAuthorityFingerprint());
		if(as == null) {
			logger.warning("Certificate read for unknown directory authority with identity: "+ certificate.getAuthorityFingerprint());
			return;
		}
		as.addCertificate(certificate);
		
		if(consensusWaitingForCertificates != null && wasRequired) {
			
			switch(consensusWaitingForCertificates.verifySignatures()) {
			case STATUS_FAILED:
				consensusWaitingForCertificates = null;
				return;
				
			case STATUS_VERIFIED:
				addConsensusDocument(consensusWaitingForCertificates, false);
				consensusWaitingForCertificates = null;
				return;

			case STATUS_NEED_CERTS:
				requiredCertificates.addAll(consensusWaitingForCertificates.getRequiredCertificates());
				return;
			}
		}
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:30,代码来源:DirectoryImpl.java

示例4: removeRequiredCertificate

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
private boolean removeRequiredCertificate(KeyCertificate certificate) {
	final Iterator<RequiredCertificate> it = requiredCertificates.iterator();
	while(it.hasNext()) {
		RequiredCertificate r = it.next();
		if(r.getSigningKey().equals(certificate.getAuthoritySigningKey().getFingerprint())) {
			it.remove();
			return true;
		}
	}
	return false;
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:12,代码来源:DirectoryImpl.java

示例5: storeCertificates

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
public void storeCertificates() {
	synchronized(TrustedAuthorities.getInstance()) {
		final List<KeyCertificate> certs = new ArrayList<KeyCertificate>();
		for(DirectoryServer ds: TrustedAuthorities.getInstance().getAuthorityServers()) {
			certs.addAll(ds.getCertificates());
		}
		store.writeDocumentList(CacheFile.CERTIFICATES, certs);
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:10,代码来源:DirectoryImpl.java

示例6: parse

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
public boolean parse(DocumentParsingResultHandler<KeyCertificate> resultHandler) {
	this.resultHandler = resultHandler;
	startNewCertificate();
	try {
		fieldParser.processDocument();
		return true;
	} catch(TorParsingException e) {
		resultHandler.parsingError(e.getMessage());
		return false;
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:12,代码来源:KeyCertificateParser.java

示例7: getCertificateByFingerprint

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
public KeyCertificate getCertificateByFingerprint(HexDigest fingerprint) {
	for(KeyCertificate kc: getCertificates()) {
		if(kc.getAuthoritySigningKey().getFingerprint().equals(fingerprint)) {
			return kc;
		}
	}
	return null;
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:9,代码来源:DirectoryServerImpl.java

示例8: getCertificates

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
public List<KeyCertificate> getCertificates() {
	synchronized(certificates) {
		purgeExpiredCertificates();
		purgeOldCertificates();
		return new ArrayList<KeyCertificate>(certificates);
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:8,代码来源:DirectoryServerImpl.java

示例9: purgeExpiredCertificates

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
private void purgeExpiredCertificates() {
	Iterator<KeyCertificate> it = certificates.iterator();
	while(it.hasNext()) {
		KeyCertificate elem = it.next();
		if(elem.isExpired()) {
			it.remove();
		}
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:10,代码来源:DirectoryServerImpl.java

示例10: purgeOldCertificates

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
private void purgeOldCertificates() {
	if(certificates.size() < 2) {
		return;
	}
	final KeyCertificate newest = getNewestCertificate();
	final Iterator<KeyCertificate> it = certificates.iterator();
	while(it.hasNext()) {
		KeyCertificate elem = it.next();
		if(elem != newest && isMoreThan48HoursOlder(newest, elem)) {
			it.remove();
		}
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:14,代码来源:DirectoryServerImpl.java

示例11: getNewestCertificate

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
private KeyCertificate getNewestCertificate() {
	KeyCertificate newest = null;
	for(KeyCertificate kc : certificates) {
		if(newest == null || getPublishedMilliseconds(newest) > getPublishedMilliseconds(kc)) {
			newest = kc;
		}
	}
	return newest;
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:10,代码来源:DirectoryServerImpl.java

示例12: addCertificate

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
public void addCertificate(KeyCertificate certificate) {
	if(!certificate.getAuthorityFingerprint().equals(v3Ident)) {
		throw new IllegalArgumentException("This certificate does not appear to belong to this directory authority");
	}
	synchronized(certificates) {
		certificates.add(certificate);
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:9,代码来源:DirectoryServerImpl.java

示例13: run

import com.subgraph.orchid.KeyCertificate; //导入依赖的package包/类
public void run() {
	try {
		for(KeyCertificate c: downloader.downloadKeyCertificates(directory.getRequiredCertificates())) {
			directory.addCertificate(c);
		}
		directory.storeCertificates();
	} catch (DirectoryRequestFailedException e) {
		logger.warning("Failed to download key certificates: "+ e.getMessage());
	} finally {
		isDownloadingCertificates = false;
	}
}
 
开发者ID:HashEngineering,项目名称:namecoinj,代码行数:13,代码来源:DirectoryDownloadTask.java


注:本文中的com.subgraph.orchid.KeyCertificate类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。