re/include/re_natbd.h

129 lines
3.3 KiB
C
Raw Permalink Normal View History

2010-11-03 11:34:14 +00:00
/**
2011-03-01 11:11:08 +00:00
* @file re_natbd.h NAT Behavior Discovery Using STUN (RFC 5780)
2010-11-03 11:34:14 +00:00
*
* Copyright (C) 2010 Creytiv.com
*/
/** NAT Mapping/Filtering types - See RFC 4787 for definitions */
enum nat_type {
NAT_TYPE_UNKNOWN = 0, /**< Unknown type */
NAT_TYPE_ENDP_INDEP = 1, /**< Endpoint-Independent */
NAT_TYPE_ADDR_DEP = 2, /**< Address-Dependent */
NAT_TYPE_ADDR_PORT_DEP = 3 /**< Address and Port-Dependent */
};
/* Strings */
const char *nat_type_str(enum nat_type type);
/*
* Diagnosing NAT Hairpinning
*/
struct nat_hairpinning;
/**
* Defines the NAT Hairpinning handler
*/
typedef void (nat_hairpinning_h)(int err, bool supported, void *arg);
int nat_hairpinning_alloc(struct nat_hairpinning **nhp,
const struct sa *srv, int proto,
const struct stun_conf *conf,
nat_hairpinning_h *hph, void *arg);
int nat_hairpinning_start(struct nat_hairpinning *nh);
/*
* Determining NAT Mapping Behavior
*/
struct nat_mapping;
/**
* Defines the NAT Mapping handler
*
* @param err Errorcode
* @param type NAT Mapping type
* @param arg Handler argument
*/
typedef void (nat_mapping_h)(int err, enum nat_type map, void *arg);
int nat_mapping_alloc(struct nat_mapping **nmp, const struct sa *laddr,
const struct sa *srv, int proto,
const struct stun_conf *conf,
nat_mapping_h *mh, void *arg);
int nat_mapping_start(struct nat_mapping *nm);
/*
* Determining NAT Filtering Behavior
*/
struct nat_filtering;
/**
* Defines the NAT Filtering handler
*
* @param err Errorcode
* @param type NAT Filtering type
* @param arg Handler argument
*/
typedef void (nat_filtering_h)(int err, enum nat_type filt, void *arg);
int nat_filtering_alloc(struct nat_filtering **nfp, const struct sa *srv,
const struct stun_conf *conf,
nat_filtering_h *fh, void *arg);
int nat_filtering_start(struct nat_filtering *nf);
/*
* Binding Lifetime Discovery
*/
struct nat_lifetime;
2011-12-03 19:30:01 +00:00
/** Defines the NAT lifetime interval */
2010-11-03 11:34:14 +00:00
struct nat_lifetime_interval {
uint32_t min; /**< Minimum lifetime interval in [seconds] */
uint32_t cur; /**< Current lifetime interval in [seconds] */
uint32_t max; /**< Maximum lifetime interval in [seconds] */
};
/**
* Defines the NAT Lifetime handler
*
* @param err Errorcode
* @param i NAT Lifetime intervals
* @param arg Handler argument
*/
typedef void (nat_lifetime_h)(int err, const struct nat_lifetime_interval *i,
void *arg);
int nat_lifetime_alloc(struct nat_lifetime **nlp, const struct sa *srv,
uint32_t interval, const struct stun_conf *conf,
nat_lifetime_h *lh, void *arg);
int nat_lifetime_start(struct nat_lifetime *nl);
/*
* Detecting Generic ALGs
*/
struct nat_genalg;
/**
* Defines the NAT Generic ALG handler
*
* @param err Errorcode
* @param errcode STUN Error code (if set)
* @param status Generic ALG status (-1=not detected, 1=detected)
* @param map Mapped network address
* @param arg Handler argument
*/
typedef void (nat_genalg_h)(int err, uint16_t scode, const char *reason,
int status, const struct sa *map, void *arg);
int nat_genalg_alloc(struct nat_genalg **ngp, const struct sa *srv, int proto,
const struct stun_conf *conf,
nat_genalg_h *gh, void *arg);
int nat_genalg_start(struct nat_genalg *ng);