/******************************************************************************* * 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 * Gemalto M2M GmbH *******************************************************************************/ package org.eclipse.leshan.core.node.codec; import java.util.List; import org.eclipse.leshan.core.model.LwM2mModel; import org.eclipse.leshan.core.node.LwM2mNode; import org.eclipse.leshan.core.node.LwM2mPath; import org.eclipse.leshan.core.node.TimestampedLwM2mNode; import org.eclipse.leshan.core.node.codec.json.LwM2mNodeJsonEncoder; import org.eclipse.leshan.core.node.codec.opaque.LwM2mNodeOpaqueEncoder; import org.eclipse.leshan.core.node.codec.text.LwM2mNodeTextEncoder; import org.eclipse.leshan.core.node.codec.tlv.LwM2mNodeTlvEncoder; import org.eclipse.leshan.core.request.ContentFormat; import org.eclipse.leshan.util.Validate; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class DefaultLwM2mNodeEncoder implements LwM2mNodeEncoder { private static final Logger LOG = LoggerFactory.getLogger(DefaultLwM2mNodeEncoder.class); private LwM2mValueConverter converter; public DefaultLwM2mNodeEncoder() { this(new DefaultLwM2mValueConverter()); } public DefaultLwM2mNodeEncoder(LwM2mValueConverter converter) { this.converter = converter; } @Override public byte[] encode(LwM2mNode node, ContentFormat format, LwM2mPath path, LwM2mModel model) throws CodecException { Validate.notNull(node); if (format == null) { throw new CodecException("Content format is mandatory. [%s]", path); } LOG.debug("Encoding node {} for path {} and formatĀ {}", node, path, format); byte[] encoded; switch (format.getCode()) { case ContentFormat.TLV_CODE: case ContentFormat.OLD_TLV_CODE: encoded = LwM2mNodeTlvEncoder.encode(node, path, model, converter); break; case ContentFormat.TEXT_CODE: encoded = LwM2mNodeTextEncoder.encode(node, path, model, converter); break; case ContentFormat.OPAQUE_CODE: encoded = LwM2mNodeOpaqueEncoder.encode(node, path, model, converter); break; case ContentFormat.JSON_CODE: case ContentFormat.OLD_JSON_CODE: encoded = LwM2mNodeJsonEncoder.encode(node, path, model, converter); break; default: throw new CodecException("Cannot encode %s:%s with format %s.", path, node, format); } LOG.trace("Encoded node {}: {}", node, encoded); return encoded; } @Override public byte[] encodeTimestampedData(List<TimestampedLwM2mNode> timestampedNodes, ContentFormat format, LwM2mPath path, LwM2mModel model) throws CodecException { Validate.notEmpty(timestampedNodes); if (format == null) { throw new CodecException("Content format is mandatory. [%s]", path); } LOG.debug("Encoding time-stamped nodes for path {} and formatĀ {}", timestampedNodes, path, format); byte[] encoded; switch (format.getCode()) { case ContentFormat.JSON_CODE: encoded = LwM2mNodeJsonEncoder.encodeTimestampedData(timestampedNodes, path, model, converter); break; default: throw new CodecException("Cannot encode timestampedNode with format %s. [%s]", format, path); } LOG.trace("Encoded node timestampedNode: {}", timestampedNodes, encoded); return encoded; } @Override public boolean isSupported(ContentFormat format) { switch (format.getCode()) { case ContentFormat.TEXT_CODE: case ContentFormat.TLV_CODE: case ContentFormat.OLD_TLV_CODE: case ContentFormat.OPAQUE_CODE: case ContentFormat.JSON_CODE: case ContentFormat.OLD_JSON_CODE: return true; default: return false; } } }