org.eclipse.leshan.server.security.SecurityRegistry Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leshan-all Show documentation
Show all versions of leshan-all Show documentation
A LWM2M client and server based on Californium (CoAP) all in one.
/*******************************************************************************
* Copyright (c) 2013-2015 Sierra Wireless and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Eclipse Distribution License v1.0 which accompany this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.html.
*
* Contributors:
* Sierra Wireless - initial API and implementation
*******************************************************************************/
package org.eclipse.leshan.server.security;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.cert.Certificate;
import java.security.cert.X509Certificate;
import java.util.Collection;
public interface SecurityRegistry extends SecurityStore {
/**
* Returns the {@link SecurityInfo} for all end-points.
*
* @return an unmodifiable collection of {@link SecurityInfo}
*/
Collection getAll();
/**
* Registers new security information for a client end-point.
*
* @param info the new security information
* @return the {@link SecurityInfo} previously stored for the end-point or null
if there was no
* security information for the end-point.
* @throws NonUniqueSecurityInfoException if some identifiers (PSK identity, RPK public key...) are not unique among
* all end-points.
*/
SecurityInfo add(SecurityInfo info) throws NonUniqueSecurityInfoException;
/**
* Removes the security information for a given end-point.
*
* @param endpoint the client end-point
* @return the removed {@link SecurityInfo} or null
if no info for the end-point.
*/
SecurityInfo remove(String endpoint);
/**
* Returns the Server Public Key
*/
PublicKey getServerPublicKey();
/**
* Returns the Server Private Key
*/
PrivateKey getServerPrivateKey();
/**
* Returns the Server X509 Certificate Chain
*/
X509Certificate[] getServerX509CertChain();
/**
* Returns the trusted certificates
*/
Certificate[] getTrustedCertificates();
}