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!

Revision:
13:9edad7677211
Child:
14:d9ce4e56684e
diff -r d0e61bac8c27 -r 9edad7677211 mbed-connector-interface/DeviceManagementResponder.h
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mbed-connector-interface/DeviceManagementResponder.h	Wed Jun 08 22:32:08 2016 +0000
@@ -0,0 +1,149 @@
+/**
+ * @file    DeviceManagementResponder.h
+ * @brief   mbed CoAP Endpoint Device Management Responder class
+ * @author  Doug Anson
+ * @version 1.0
+ * @see
+ *
+ * Copyright (c) 2016
+ *
+ * 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 __DEVICE_MANAGEMENT_RESPONDER_H__
+#define __DEVICE_MANAGEMENT_RESPONDER_H__
+
+// Logger
+#include "mbed-connector-interface/Logger.h"
+
+// Authenticator Support
+#include "mbed-connector-interface/Authenticator.h"
+
+// invocation handler signature
+typedef bool (*responder_fn)(const void *ep,const void *logger,const void *data); 
+
+class DeviceManagementResponder {
+    public:
+        /**
+        Default constructor
+        @param logger input logger instance
+        @param authenticator input authentication instance
+        */
+        DeviceManagementResponder(const Logger *logger,const Authenticator *authenticator);
+        
+        /**
+        Copy constructor
+        @param resource input the DeviceManagementResponder that is to be deep copied
+        */
+        DeviceManagementResponder(const DeviceManagementResponder &manager);
+    
+        /**
+        Destructor
+        */
+        virtual ~DeviceManagementResponder();
+        
+        /**
+        Set the Endpoint instance
+        @param ep input the endpoint instance pointer
+        */
+        void setEndpoint(const void *ep);
+        
+        /** 
+        Set our Reboot Responder handler function
+        @param reboot_responder_fn input the device reboot responder function pointer
+        */
+        void setRebootResponderHandler(responder_fn reboot_responder_fn);
+        
+        /** 
+        Set our Reset Responder handler function
+        @param reset_responder_fn input the device reset responder function pointer
+        */
+        void setResetResponderHandler(responder_fn reset_responder_fn);
+        
+        /** 
+        Set our FOTA invocation handler function
+        @param fota_invocation_fn input the FOTA invocation handler function pointer
+        */
+        void setFOTAInvocationHandler(responder_fn fota_invocation_fn);
+        
+        /**
+        Set our FOTA manifest
+        @param fota_manifest input the input FOTA manifest
+        */
+        virtual void setFOTAManifest(const char *fota_manifest);
+        
+        /**
+        ACTION: Deregister device
+        @param challenge input the input authentication challenge
+        */
+        virtual void deregisterDevice(const void *challenge);
+        
+        /**
+        ACTION: Reboot device
+        @param challenge input the input authentication challenge
+        */
+        virtual void rebootDevice(const void *challenge);
+        
+        /**
+        ACTION: Reset device 
+        @param challenge input the input authentication challenge
+        */
+        virtual void resetDevice(const void *challenge);
+        
+        /**
+        ACTION: Invoke FOTA (default: empty action)
+        @param challenge input the input authentication challenge
+        */
+        virtual void invokeFOTA(const void *challenge);
+        
+        /**
+        Set the State Resource
+        @param state_resource input the state resource instance
+        */
+        void setStateResource(const void *state_resource);
+        
+        /**
+        Set the Result Resource
+        @param result_resource input the result resource instance
+        */
+        void setResultResource(const void *result_resource);
+        
+        /**
+        Get the State Resource
+        @return the state resource or NULL
+        */
+        void *getStateResource();
+        
+        /** 
+        Get the Result Resource
+        @return the result resource or NULL
+        */
+        void *getResultResource();
+    
+    private:
+        Logger                      *m_logger;
+        Authenticator               *m_authenticator;
+        void                        *m_endpoint;
+        char                        *m_fota_manifest;
+        
+        responder_fn                 m_reboot_responder_fn;
+        responder_fn                 m_reset_responder_fn;
+        responder_fn                 m_fota_invocation_fn;
+        
+        bool                         authenticate(const void *challenge);
+        
+        void                        *m_state_resource;
+        void                        *m_result_resource;
+};
+
+#endif // __DEVICE_MANAGEMENT_RESPONDER_H__
\ No newline at end of file