miniupnp/miniupnpc/include/miniupnpc.h

157 lines
5.2 KiB
C
Raw Normal View History

/* $Id: miniupnpc.h,v 1.64 2024/03/19 23:26:06 nanard Exp $ */
2018-01-16 02:06:46 +01:00
/* vim: tabstop=4 shiftwidth=4 noexpandtab
* Project: miniupnp
2022-10-21 22:47:21 +02:00
* http://miniupnp.free.fr/ or https://miniupnp.tuxfamily.org/
2011-09-27 22:25:35 +02:00
* Author: Thomas Bernard
* Copyright (c) 2005-2024 Thomas Bernard
2011-09-27 22:25:35 +02:00
* This software is subjects to the conditions detailed
* in the LICENCE file provided within this distribution */
#ifndef MINIUPNPC_H_INCLUDED
#define MINIUPNPC_H_INCLUDED
2011-09-27 22:25:35 +02:00
#include "miniupnpc_declspec.h"
2011-09-27 22:25:35 +02:00
#include "igd_desc_parse.h"
#include "upnpdev.h"
2011-09-27 22:25:35 +02:00
/* error codes : */
#define UPNPDISCOVER_SUCCESS (0)
#define UPNPDISCOVER_UNKNOWN_ERROR (-1)
#define UPNPDISCOVER_SOCKET_ERROR (-101)
#define UPNPDISCOVER_MEMORY_ERROR (-102)
/* versions : */
#define MINIUPNPC_VERSION "2.2.7"
#define MINIUPNPC_API_VERSION 18
/* Source port:
2018-01-09 09:32:39 +08:00
Using "1" as an alias for 1900 for backwards compatibility
(presuming one would have used that for the "sameport" parameter) */
#define UPNP_LOCAL_PORT_ANY 0
#define UPNP_LOCAL_PORT_SAME 1
2011-09-27 22:25:35 +02:00
#ifdef __cplusplus
extern "C" {
#endif
/* Structures definitions : */
struct UPNParg { const char * elt; const char * val; };
char *
simpleUPnPcommand(int, const char *, const char *,
const char *, struct UPNParg *,
int *);
/* upnpDiscover()
* discover UPnP devices on the network.
* The discovered devices are returned as a chained list.
* It is up to the caller to free the list with freeUPNPDevlist().
* delay (in millisecond) is the maximum time for waiting any device
* response.
* If available, device list will be obtained from MiniSSDPd.
* Default path for minissdpd socket will be used if minissdpdsock argument
* is NULL.
* If multicastif is not NULL, it will be used instead of the default
* multicast interface for sending SSDP discover packets.
* If localport is set to UPNP_LOCAL_PORT_SAME(1) SSDP packets will be sent
2015-10-08 17:48:04 +02:00
* from the source port 1900 (same as destination port), if set to
* UPNP_LOCAL_PORT_ANY(0) system assign a source port, any other value will
* be attempted as the source port.
* "searchalltypes" parameter is useful when searching several types,
* if 0, the discovery will stop with the first type returning results.
* TTL should default to 2. */
MINIUPNP_LIBSPEC struct UPNPDev *
2011-09-27 22:25:35 +02:00
upnpDiscover(int delay, const char * multicastif,
const char * minissdpdsock, int localport,
int ipv6, unsigned char ttl,
2011-09-27 22:25:35 +02:00
int * error);
MINIUPNP_LIBSPEC struct UPNPDev *
upnpDiscoverAll(int delay, const char * multicastif,
const char * minissdpdsock, int localport,
int ipv6, unsigned char ttl,
int * error);
MINIUPNP_LIBSPEC struct UPNPDev *
upnpDiscoverDevice(const char * device, int delay, const char * multicastif,
const char * minissdpdsock, int localport,
int ipv6, unsigned char ttl,
int * error);
MINIUPNP_LIBSPEC struct UPNPDev *
upnpDiscoverDevices(const char * const deviceTypes[],
int delay, const char * multicastif,
const char * minissdpdsock, int localport,
int ipv6, unsigned char ttl,
int * error,
int searchalltypes);
2011-09-27 22:25:35 +02:00
/* parserootdesc() :
* parse root XML description of a UPnP device and fill the IGDdatas
* structure. */
MINIUPNP_LIBSPEC void parserootdesc(const char *, int, struct IGDdatas *);
2011-09-27 22:25:35 +02:00
/* structure used to get fast access to urls
* controlURL: controlURL of the WANIPConnection
* ipcondescURL: url of the description of the WANIPConnection
* controlURL_CIF: controlURL of the WANCommonInterfaceConfig
* controlURL_6FC: controlURL of the WANIPv6FirewallControl
*/
struct UPNPUrls {
char * controlURL;
char * ipcondescURL;
char * controlURL_CIF;
char * controlURL_6FC;
char * rootdescURL;
};
/* UPNP_GetValidIGD() :
* return values :
* 0 = NO IGD found
* 1 = A valid connected IGD has been found
* 2 = A valid connected IGD has been found but its
* IP address is reserved (non routable)
* 3 = A valid IGD has been found but it reported as
2011-09-27 22:25:35 +02:00
* not connected
* 4 = an UPnP device has been found but was not recognized as an IGD
2011-09-27 22:25:35 +02:00
*
* In any non zero return case, the urls and data structures
* passed as parameters are set. Donc forget to call FreeUPNPUrls(urls) to
* free allocated memory.
*/
MINIUPNP_LIBSPEC int
2011-09-27 22:25:35 +02:00
UPNP_GetValidIGD(struct UPNPDev * devlist,
struct UPNPUrls * urls,
struct IGDdatas * data,
char * lanaddr, int lanaddrlen,
char * wanaddr, int wanaddrlen);
2011-09-27 22:25:35 +02:00
/* UPNP_GetIGDFromUrl()
* Used when skipping the discovery process.
2015-01-01 19:39:47 +01:00
* When succeding, urls, data, and lanaddr arguments are set.
2011-09-27 22:25:35 +02:00
* return value :
* 0 - Not ok
* 1 - OK */
MINIUPNP_LIBSPEC int
2011-09-27 22:25:35 +02:00
UPNP_GetIGDFromUrl(const char * rootdescurl,
struct UPNPUrls * urls,
struct IGDdatas * data,
char * lanaddr, int lanaddrlen);
MINIUPNP_LIBSPEC void
GetUPNPUrls(struct UPNPUrls *, struct IGDdatas *,
const char *, unsigned int);
2011-09-27 22:25:35 +02:00
MINIUPNP_LIBSPEC void
FreeUPNPUrls(struct UPNPUrls *);
2011-09-27 22:25:35 +02:00
/* return 0 or 1 */
MINIUPNP_LIBSPEC int UPNPIGD_IsConnected(struct UPNPUrls *, struct IGDdatas *);
2011-09-27 22:25:35 +02:00
#ifdef __cplusplus
}
#endif
#endif