blob: f4292a7a7bae0deb12724331563cd60c0919e3b2 [file] [log] [blame]
/**
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 EXTENSIONS_COAP_NANOFI_COAP_SERVER_H
#define EXTENSIONS_COAP_NANOFI_COAP_SERVER_H
#ifdef __cplusplus
extern "C" {
#endif
#include <coap2/coap.h>
#include <stdint.h>
#include <stdio.h>
/**
* CoAP-2 in libcoap uses uint8_t * while the first version uses a different type, so we will have to cast
* the data. We have to keep this in mind with the API that we use.
*/
typedef struct {
struct coap_context_t* ctx;
coap_address_t src_addr;
coap_optlist_t *optlist;
} CoapServerContext;
typedef struct {
CoapServerContext *server;
coap_resource_t *resource;
} CoapEndpoint;
/**
* Create a new CoAPServer using the host name provide
* @param server_hostname hostname
* @param port port requested
* @param title title of base resource
* @return CoAPServer structure.
*/
CoapServerContext * const create_server(const char *const server_hostname, const char * const port);
/**
* Creates an endpoint for the provided service context
*/
CoapEndpoint * const create_endpoint(CoapServerContext * const, const char * const resource_path, uint8_t method, coap_method_handler_t handler);
/**
* Adds an endpoint to the provided CoapEndpoint structure
* @param endpoint endpoint we are adding the handler to
* @method method we're adding for CoAP messages
* @param handler handler we're using for the endpoint.
*/
int8_t add_endpoint(CoapEndpoint * const endpoint, uint8_t method, coap_method_handler_t handler);
/**
* Free the CoAP messages that are provided.
*/
void free_endpoint(CoapEndpoint * const);
/**
* Frees the CoAP Server context.
*/
void free_server(CoapServerContext * const);
#ifdef __cplusplus
}
#endif
#endif /* EXTENSIONS_COAP_NANOFI_COAP_SERVER_H */