org.eclipse.leshan.server.impl.BootstrapSessionManagerImpl 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) 2016 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.impl;
import java.util.List;
import org.eclipse.leshan.core.request.DownlinkRequest;
import org.eclipse.leshan.core.request.Identity;
import org.eclipse.leshan.core.response.LwM2mResponse;
import org.eclipse.leshan.server.bootstrap.BootstrapSession;
import org.eclipse.leshan.server.bootstrap.BootstrapSessionManager;
import org.eclipse.leshan.server.security.BootstrapSecurityStore;
import org.eclipse.leshan.server.security.SecurityCheck;
import org.eclipse.leshan.server.security.SecurityInfo;
/**
* Implementation of a session manager.
*
* Starting a session only checks credentials from BootstrapSecurityStore.
*
* Nothing specific is done on session's end.
*
*/
public class BootstrapSessionManagerImpl implements BootstrapSessionManager {
private BootstrapSecurityStore bsSecurityStore;
public BootstrapSessionManagerImpl(BootstrapSecurityStore bsSecurityStore) {
this.bsSecurityStore = bsSecurityStore;
}
@Override
public BootstrapSession begin(String endpoint, Identity clientIdentity) {
List securityInfos = bsSecurityStore.getAllByEndpoint(endpoint);
boolean authorized = SecurityCheck.checkSecurityInfos(endpoint, clientIdentity, securityInfos);
if (authorized) {
return BootstrapSession.authorized(endpoint, clientIdentity);
} else {
return BootstrapSession.unauthorized();
}
}
@Override
public void end(BootstrapSession bsSession) {
}
@Override
public void failed(BootstrapSession bsSession, DownlinkRequest extends LwM2mResponse> request, Exception e) {
}
}