/*
 * airkiss.h
 *
 *  Created on: 2015-1-26
 *      Author: peterfan
 */

#ifndef AIRKISS_H_
#define AIRKISS_H_

#ifdef __cplusplus
extern "C" {
#endif


typedef void* (*airkiss_memset_fn) (void* ptr, int value, unsigned int num);
typedef void* (*airkiss_memcpy_fn) (void* dst, const void* src, unsigned int num);
typedef int (*airkiss_memcmp_fn) (const void* ptr1, const void* ptr2, unsigned int num);
typedef int (*airkiss_printf_fn) (const char* format, ...);



typedef struct
{
	airkiss_memset_fn memset;
	airkiss_memcpy_fn memcpy;
	airkiss_memcmp_fn memcmp;
	airkiss_printf_fn printf;

} airkiss_config_t;

/**
  * @brief     Get airkiss lib version.
  *
  * @attention The lenth of version is unknown
  *
  * @param     null.
  *
  * @return    const char*
  */

const char* airkiss_version(void);


typedef enum
{
	/* the length of the data buffer is lack*/
	AIRKISS_LAN_ERR_OVERFLOW = -5,

	/* Do not support the type of instruction */
	AIRKISS_LAN_ERR_CMD = -4,

	/* Error reading data package */
	AIRKISS_LAN_ERR_PAKE = -3,

	/* Error function passing parameters */
	AIRKISS_LAN_ERR_PARA = -2,

	/* Packet data error */
	AIRKISS_LAN_ERR_PKG = -1,

	/* Message format is correct */
	AIRKISS_LAN_CONTINUE = 0,

	/* Find equipment request packet is received */
	AIRKISS_LAN_SSDP_REQ = 1,

	/* Packet packaging complete */
	AIRKISS_LAN_PAKE_READY = 2


} airkiss_lan_ret_t;


typedef enum
{
	AIRKISS_LAN_SSDP_REQ_CMD = 0x1,
	AIRKISS_LAN_SSDP_RESP_CMD = 0x1001,
	AIRKISS_LAN_SSDP_NOTIFY_CMD = 0x1002
} airkiss_lan_cmdid_t;

/**
  * @brief     Receive UDP packet and input this API for analyzing.
  *
  * @attention null.
  *
  * @param     const void* body : The start of the UDP message body data pointer.
  * @param     unsigned short length : the effective length of data.
  * @param     const airkiss_config_t* config : input struct airkiss_config_t
  *
  * @return    >=0 : succeed (reference airkiss_lan_ret_t)
  * @return    <0  : error code (reference airkiss_lan_ret_t)
  */

int airkiss_lan_recv(const void* body, unsigned short length, const airkiss_config_t* config);


/**
  * @brief     Packaging the UDP packet to send.
  *
  * @attention null.
  *
  * @param     airkiss_lan_cmdid_t ak_lan_cmdid : The packet type.
  * @param     void* appid : Vendor's Wechat public number id.
  * @param     void* deviceid : device model id.
  * @param     void* _datain : the data to be sent.
  * @param     unsigned short inlength : the lenth of data to be sent.
  * @param     void* _dataout : Data buffer addr.
  * @param     unsigned short* outlength : the size of data buffer.
  * @param     const airkiss_config_t* config : input struct airkiss_config_t
  *
  * @return    >=0 : succeed (reference airkiss_lan_ret_t)
  * @return    <0  : error code (reference airkiss_lan_ret_t)
  */

int airkiss_lan_pack(airkiss_lan_cmdid_t ak_lan_cmdid, void* appid, void* deviceid, void* _datain, unsigned short inlength, void* _dataout, unsigned short* outlength, const airkiss_config_t* config);

#ifdef __cplusplus
}
#endif

#endif /* AIRKISS_H_ */