mbed Connector Interface simplification API on top of mbed-client

Fork of mbedConnectorInterfaceV3 by Doug Anson

NOTE:

This repo has been replaced with https://github.com/ARMmbed/mbedConnectorInterface. No further updates will occur with this repo. Please use the github repo instead. Thanks!

mbed-connector-interface/DataWrapper.h

Committer:
ansond
Date:
2016-06-14
Revision:
33:1d0b855df5a5
Parent:
0:1f1f55e73248

File content as of revision 33:1d0b855df5a5:

/**
 * @file    DataWrapper.h
 * @brief   mbed CoAP Endpoint Data Wrapper class (header)
 * @author  Doug Anson
 * @version 1.0
 * @see
 *
 * Copyright (c) 2014
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef __DATA_WRAPPER_H__
#define __DATA_WRAPPER_H__

// mbedConnectorInterface configuration
#include "mbed-connector-interface/mbedConnectorInterface.h"

// mbed support
#if defined(MCI_USE_YOTTA)
    // mbed support
    #include "mbed-drivers/mbed.h"
#else
    // mbed support
    #include "mbed.h"
#endif

class DataWrapper {
    public:
        /**
        Default constructor
        @param data input the buffer to use for operations
        @param data_length input the data length
        */
        DataWrapper(uint8_t *data,int data_length);
        
        /**
        Default constructor (alloc)
        @param data_length input the data length (alloc)
        */
        DataWrapper(int data_length);
        
        /**
        Default copy constructor
        @param data input the DataWrapper to copy
        */
        DataWrapper(const DataWrapper &data);
        
        /**
        Destructor
        */
        virtual ~DataWrapper();
        
        /**
        Wrap the data (trivial in base class)
        @param data input the data to wrap
        @param data_length input the length of the data to wrap
        */
        virtual void wrap(uint8_t *data,int data_length);
        
        /**
        Unwrap the data (trivial in base class)
        @param data input the data to unwrap
        @param data_length input the length of the data to unwrap
        */
        virtual void unwrap(uint8_t *data,int data_length);
        
        /**
        Get the wrap/unwrap result
        @return pointer to the data buffer of DataWrapper containing the wrap/unwrap result
        */
        uint8_t *get() { return this->m_data; }
        
        /**
        Get the wrap/unwrap result length
        @return length of the wrap/unwrap data result
        */
        int length() { return this->m_data_length; }
        
        /**
        Reset the wrapper
        */
        void reset();
        
        /**
        Set the new application key
        @param appkey input the new appkey (encrypted) to set
        @param appkey_length input the new appkey (encrypted) length
        */
        virtual void setAppKey(uint8_t *appkey,int appkey_length);
        
    protected:
        uint8_t *m_data;
        
    private:
        bool     m_alloced;
        int      m_data_length;
        int      m_data_length_max;
};

#endif // __DATA_WRAPPER_H__