mbed Connector Interface simplification API on top of mbed-client
Fork of mbedConnectorInterfaceV3 by
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/OptionsBuilder.h
- Committer:
- ansond
- Date:
- 2016-06-23
- Revision:
- 49:c603a22495bb
- Parent:
- 27:b8aaf7dc7023
- Child:
- 54:dfee8691c83a
File content as of revision 49:c603a22495bb:
/** * @file OptionsBuilder.h * @brief mbed CoAP OptionsBuilder class header * @author Doug Anson/Chris Paola * @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 __OPTIONS_BUILDER_H__ #define __OPTIONS_BUILDER_H__ // base class support #include "mbed-connector-interface/Options.h" // Connector namespace namespace Connector { /** OptionsBuilder class */ class OptionsBuilder : Options { public: /** Default Constructor */ OptionsBuilder(); /** Copy Constructor @param ob input options builder instance to deep copy */ OptionsBuilder(const OptionsBuilder &ob); /** Destructor */ virtual ~OptionsBuilder(); /** Set the NSDL Endpoint Lifetime @param lifetime input the NSDL endpoint lifetime (seconds) @return instance to ourself */ OptionsBuilder &setLifetime(int lifetime); /** Set the NSDL Domain @param domain input the NSDL domain to set @return instance to ourself */ OptionsBuilder &setDomain(const char *domain); /** Set the Endpoint Node Name @param node_name input the node endpoint name @return instance to ourself */ OptionsBuilder &setEndpointNodename(const char *node_name); /** Set the NSDL Endpoint Type @param endpoint_type input the NSDL endpoint type @return instance to ourself */ OptionsBuilder &setEndpointType(const char *endpoint_type); /** Set the mbed Registration Update Period @param rd_update_period_ms input the NSDL read update period (in ms) @return instance to ourself */ OptionsBuilder &setRegUpdatePeriod(const int reg_update_period_ms); /** Set the Connector URL @param url input the Connector URL @return instance to ourself */ OptionsBuilder &setConnectorURL(const char *connector_url); /** Set the LWM2M Device Resource Object Instance @param device_resources_object input the LWM2M device resource object instance @return instance to ourself */ OptionsBuilder &setDeviceResourcesObject(const void *device_resources_object); /** Set the LWM2M Firmware Resource Object Instance @param firmware_resources_object input the LWM2M firmware resource object instance @return instance to ourself */ OptionsBuilder &setFirmwareResourcesObject(const void *firmware_resources_object); /** Add a NSDL endpoint resource (static) @param static_resource input the NSDL static resource @return instance to ourself */ OptionsBuilder &addResource(const StaticResource *static_resource); /** Add a NSDL endpoint resource (dynamic) @param dynamic_resource input the NSDL dynamic resource @return instance to ourself */ OptionsBuilder &addResource(const DynamicResource *dynamic_resource); /** Add a NSDL endpoint resource (dynamic) @param dynamic_resource input the NSDL dynamic resource @param use_observer input if true, use an appropriate ResourceObserver to observer. if false, the underlying resource will handle it @return instance to ourself */ OptionsBuilder &addResource(const DynamicResource *dynamic_resource,const bool use_observer); /** Add a NSDL endpoint resource (dynamic) @param dynamic_resource input the NSDL dynamic resource @param sleep_time input the observation sleep time in milliseconds (for observable resource only) @return instance to ourself */ OptionsBuilder &addResource(const DynamicResource *dynamic_resource,const int sleep_time); /** Add a NSDL endpoint resource (dynamic) @param dynamic_resource input the NSDL dynamic resource @param sleep_time input the observation sleep time in milliseconds (for observable resource only) @param use_observer input if true, use an appropriate ResourceObserver to observer. if false, the underlying resource will handle it @return instance to ourself */ OptionsBuilder &addResource(const DynamicResource *dynamic_resource,const int sleep_time,const bool use_observer); /** Set the WiFi SSID @param ssid input the WiFi SSID */ OptionsBuilder &setWiFiSSID(char *ssid); /** Set the WiFi AuthType @param auth_type input the WiFi AuthType */ OptionsBuilder &setWiFiAuthType(WiFiAuthTypes auth_type); /** Set the WiFi AuthKey @param auth_key input the WiFi AuthKey */ OptionsBuilder &setWiFiAuthKey(char *auth_key); /** Set the 802.15.4 Pre Shared Key @param psk input the 802.15.4 mesh pre shared key */ OptionsBuilder &setPreSharedKey(unsigned char psk[16]); /** Set the 802.15.4 Pre Shared Key Identity @param psk_identity input the 802.15.4 mesh pre shared key Identity */ OptionsBuilder &setPreSharedKeyIdentity(unsigned char psk_identity[2]); /** Set the 802.15.4 Mesh Type @param mesh_type input the 802.15.4 mesh type */ OptionsBuilder &setMeshType(MeshTypes mesh_type); /** Set the CoAP Connection Type @param coap_connection_type input the CoAP Connection type */ OptionsBuilder &setCoAPConnectionType(CoAPConnectionTypes coap_connection_type); /** Set the IP Address Type @param ip_address_type input the IP Address type */ OptionsBuilder &setIPAddressType(IPAddressTypes ip_address_type); /** Enable/Disable immediate observationing @param enable input enable immediate observationing without GET */ OptionsBuilder &setImmedateObservationEnabled(bool enable); /** Enable/Disable GET-based control of observations @param enable input enable GET-based observation enable/disable control */ OptionsBuilder &setEnableGETObservationControl(bool enable); /** Set the Server Certificate @param cert input the server certificate @param cert_size input the length of the server certificate */ OptionsBuilder &setServerCertificate(uint8_t *cert,int cert_size); /** Set the Client Certificate @param cert input the client certificate @param cert_size input the length of the client certificate */ OptionsBuilder &setClientCertificate(uint8_t *cert,int cert_size); /** Set the Client Key @param key input the client key @param key_size input the length of the client key */ OptionsBuilder &setClientKey(uint8_t *key,int key_size); /** Build our our immutable self */ Options *build(); /** Set our Endpoint instance */ void setEndpoint(void *endpoint); }; } // namespace Connector #endif // __OPTIONS_BUILDER_H__