2019-10-03 00:15:32 +02:00
|
|
|
/* $Id: commonrdr.h,v 1.11 2019/10/02 22:12:02 nanard Exp $ */
|
2011-09-28 21:13:20 +02:00
|
|
|
/* MiniUPnP project
|
2020-06-04 00:27:49 +02:00
|
|
|
* (c) 2006-2020 Thomas Bernard
|
|
|
|
* http://miniupnp.free.fr/ or https://miniupnp.tuxfamily.org/
|
2011-09-28 21:13:20 +02:00
|
|
|
* This software is subject to the conditions detailed
|
|
|
|
* in the LICENCE file provided within the distribution */
|
2012-09-20 17:52:51 -03:00
|
|
|
#ifndef COMMONRDR_H_INCLUDED
|
|
|
|
#define COMMONRDR_H_INCLUDED
|
2011-09-28 21:13:20 +02:00
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
/* init and shutdown functions */
|
2014-02-11 10:38:50 +01:00
|
|
|
/* init_redirect() return values :
|
|
|
|
* 0 : OK
|
|
|
|
* -1 : error */
|
2011-09-28 21:13:20 +02:00
|
|
|
int
|
|
|
|
init_redirect(void);
|
|
|
|
|
|
|
|
void
|
|
|
|
shutdown_redirect(void);
|
|
|
|
|
2020-06-04 00:27:49 +02:00
|
|
|
/* get_redirect_rule_count()
|
|
|
|
* return value : -1 for error or the number of redirection rules */
|
|
|
|
int
|
|
|
|
get_redirect_rule_count(const char * ifname);
|
|
|
|
|
2011-09-28 21:13:20 +02:00
|
|
|
/* get_redirect_rule() gets internal IP and port from
|
2014-02-11 10:38:50 +01:00
|
|
|
* interface, external port and protocol
|
|
|
|
* return value :
|
|
|
|
* 0 success (rule found)
|
|
|
|
* -1 error or rule not found
|
2011-09-28 21:13:20 +02:00
|
|
|
*/
|
|
|
|
int
|
|
|
|
get_redirect_rule(const char * ifname, unsigned short eport, int proto,
|
|
|
|
char * iaddr, int iaddrlen, unsigned short * iport,
|
|
|
|
char * desc, int desclen,
|
|
|
|
char * rhost, int rhostlen,
|
|
|
|
unsigned int * timestamp,
|
|
|
|
u_int64_t * packets, u_int64_t * bytes);
|
|
|
|
|
2014-02-11 10:38:50 +01:00
|
|
|
/* get_redirect_rule_by_index()
|
|
|
|
* return values :
|
|
|
|
* 0 success (rule found)
|
|
|
|
* -1 error or rule not found */
|
2011-09-28 21:13:20 +02:00
|
|
|
int
|
|
|
|
get_redirect_rule_by_index(int index,
|
|
|
|
char * ifname, unsigned short * eport,
|
|
|
|
char * iaddr, int iaddrlen, unsigned short * iport,
|
|
|
|
int * proto, char * desc, int desclen,
|
|
|
|
char * rhost, int rhostlen,
|
|
|
|
unsigned int * timestamp,
|
|
|
|
u_int64_t * packets, u_int64_t * bytes);
|
|
|
|
|
|
|
|
/* return an (malloc'ed) array of "external" port for which there is
|
|
|
|
* a port mapping. number is the size of the array */
|
|
|
|
unsigned short *
|
|
|
|
get_portmappings_in_range(unsigned short startport, unsigned short endport,
|
|
|
|
int proto, unsigned int * number);
|
|
|
|
|
2016-02-12 15:01:30 +01:00
|
|
|
/* update the port mapping internal port, decription and timestamp */
|
|
|
|
int
|
|
|
|
update_portmapping(const char * ifname, unsigned short eport, int proto,
|
|
|
|
unsigned short iport, const char * desc,
|
|
|
|
unsigned int timestamp);
|
2011-09-28 21:13:20 +02:00
|
|
|
|
2016-02-12 15:01:30 +01:00
|
|
|
/* update the port mapping decription and timestamp */
|
|
|
|
int
|
|
|
|
update_portmapping_desc_timestamp(const char * ifname,
|
|
|
|
unsigned short eport, int proto,
|
|
|
|
const char * desc, unsigned int timestamp);
|
|
|
|
|
2020-09-28 22:44:24 +02:00
|
|
|
#if defined(USE_NETFILTER)
|
2019-10-02 13:29:29 -07:00
|
|
|
/*
|
|
|
|
* only provided by nftables implementation at the moment.
|
|
|
|
* Should be implemented for iptables too, for consistency
|
|
|
|
*/
|
2019-09-30 00:12:08 -07:00
|
|
|
|
|
|
|
typedef enum {
|
2019-10-02 13:29:29 -07:00
|
|
|
RDR_TABLE_NAME,
|
|
|
|
RDR_NAT_PREROUTING_CHAIN_NAME,
|
|
|
|
RDR_NAT_POSTROUTING_CHAIN_NAME,
|
|
|
|
RDR_FORWARD_CHAIN_NAME,
|
2019-09-30 00:12:08 -07:00
|
|
|
} rdr_name_type;
|
|
|
|
|
2019-10-02 13:29:29 -07:00
|
|
|
/*
|
|
|
|
* used by the config file parsing in the core
|
|
|
|
* to set
|
|
|
|
*/
|
|
|
|
|
2019-09-30 00:12:08 -07:00
|
|
|
int set_rdr_name( rdr_name_type param, const char * string );
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2016-02-12 15:01:30 +01:00
|
|
|
#endif
|