mirror of
https://gitee.com/acl-dev/acl.git
synced 2024-12-14 00:40:55 +08:00
167 lines
6.3 KiB
C
167 lines
6.3 KiB
C
#ifndef ACL_VSTREAM_NET_INCLUDE_H
|
||
#define ACL_VSTREAM_NET_INCLUDE_H
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
#include "../stdlib/acl_define.h"
|
||
#include "../stdlib/acl_vstream.h"
|
||
|
||
/**
|
||
* 监听某个地址(对于UNIX,还可以监听域套接字)
|
||
* @param addr {const char*} 监听地址,
|
||
* 如:127.0.0.1:80 或域套接字(UNIX平台) 如:/tmp/test.sock,在 Linux 平台下,
|
||
* 如果 addr 的首字母为 '@',则当作 astract unix domain path.
|
||
* @param qlen {int} 监听队列的长度
|
||
* @param flag {unsigned} 监听标志位,参见:ACL_INET_FLAG_XXX
|
||
* @param io_bufsize {int} 接收的新的客户端套接字的IO缓冲区大小
|
||
* @param rw_timeout {int} 接收的新的客户端套接字的IO读写超时时间,单位为秒
|
||
* @return {ACL_VSTREAM*} 监听流指针
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_listen_ex(const char *addr, int qlen,
|
||
unsigned flag, int io_bufsize, int rw_timeout);
|
||
|
||
/**
|
||
* 监听某个地址(对于UNIX,还可以监听域套接字)
|
||
* @param addr {const char*} 监听地址
|
||
* 如:127.0.0.1:80, 或域套接字, 如:/tmp/test.sock,当地址为 ip:0 时则监听
|
||
* 端口号由操作系统自动分配
|
||
* @param qlen {int} 监听队列的长度
|
||
* @return {ACL_VSTREAM*} 监听流指针
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_listen(const char *addr, int qlen);
|
||
|
||
/**
|
||
* 从监听流中接收一个客户端连接流
|
||
* @param listen_stream {ACL_VSTREAM*} 监听流
|
||
* @param client_stream {ACL_VSTREAM*} 可重复利用的 ACL_VSTREAM 结构,
|
||
* 如果为空则内部产生一个新的 ACL_VSTREAM 流,否则复用该结构空间
|
||
* @param ipbuf {char*} 如果不为空则用来存储客户端的IP地址
|
||
* @param bsize {int} 如果 ipbuf 不为空,则表示 ipbuf 的空间大小
|
||
* @return {ACL_VSTREAM*} 如果不为空则表示新接收的客户端流
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_accept_ex(ACL_VSTREAM *listen_stream,
|
||
ACL_VSTREAM *client_stream, char *ipbuf, int bsize);
|
||
|
||
/**
|
||
* 从监听流中接收一个客户端连接流
|
||
* @param listen_stream {ACL_VSTREAM*} 监听流
|
||
* @param ipbuf {char*} 如果不为空则用来存储客户端的IP地址
|
||
* @param bsize {int} 如果 ipbuf 不为空,则表示 ipbuf 的空间大小
|
||
* @return {ACL_VSTREAM*} 如果不为空则表示新接收的客户端流
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_accept(ACL_VSTREAM *listen_stream,
|
||
char *ipbuf, int bsize);
|
||
|
||
/**
|
||
* 远程连接服务器
|
||
* @param addr {const char*} 服务器地址, 如果连接一个域套接口服务器(仅UNIX平台),
|
||
* 域套接地址:/tmp/test.sock,对于 Linux 平台,如果首字母为 '@' 则表示连接本
|
||
* 地的抽象UNIX域套接口(Linux abstract unix domain socket);
|
||
* 如果连接一个TCP服务器,则地址格式为:
|
||
* remote_addr[@local_ip]|[#interface], 如:
|
||
* 1. www.sina.com|80@60.28.250.199, 意思是绑定本网卡地址为:
|
||
* 60.28.250.199, 远程连接 www.sina.com 的 80 端口;
|
||
* 2. 211.150.111.12|80@192.168.1.1,表示仅绑定本地地址;
|
||
* 3. 211.150.111.12|80#eth0,表示绑定本地指定网卡;
|
||
* 4. 如果由OS 自动绑定本地 IP 地址,则可以写为:www.sina.com|80;
|
||
* @param block_mode {int} 阻塞连接还是非阻塞连接,ACL_BLOCKING, ACL_NON_BLOCKING
|
||
* @param conn_timeout {int} 连接超时时间(秒)
|
||
* @param rw_timeout {int} 连接流成功后的读写超时时间,单位为秒
|
||
* @param bufsize {int} 连接流成功后的缓冲区大小
|
||
* @param flags {unsigned*} 非空时用来存放连接失败的错误信息或连接的其它标记位
|
||
* @return {ACL_VSTREAM*} 如果不为空,则表示连接成功后的数据流
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_connect2(const char *addr, int block_mode,
|
||
int conn_timeout, int rw_timeout, int bufsize, unsigned *flags);
|
||
#define acl_vstream_connect_ex acl_vstream_connect2
|
||
|
||
/**
|
||
* 远程连接服务器
|
||
* @param addr {const char*} 服务器地址,含义同上
|
||
* @param block_mode {int} 阻塞连接还是非阻塞连接,ACL_BLOCKING, ACL_NON_BLOCKING
|
||
* @param connect_timeout {int} 连接超时时间(秒)
|
||
* @param rw_timeout {int} 连接流成功后的读写超时时间,单位为秒
|
||
* @param rw_bufsize {int} 连接流成功后的缓冲区大小
|
||
* @return {ACL_VSTREAM*} 如果不为空,则表示连接成功后的数据流
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_connect(const char *addr, int block_mode,
|
||
int connect_timeout, int rw_timeout, int rw_bufsize);
|
||
|
||
/**
|
||
* 远程连接服务器
|
||
* @param addr {const char*} 服务器地址,含义同上
|
||
* @param block_mode {int} 阻塞连接还是非阻塞连接,ACL_BLOCKING, ACL_NON_BLOCKING
|
||
* @param connect_timeout {int} 连接超时时间(毫秒)
|
||
* @param rw_timeout {int} 连接流成功后的读写超时时间,单位为毫秒
|
||
* @param rw_bufsize {int} 连接流成功后的缓冲区大小
|
||
* @param flags {unsigned*} 非空时用来存放连接失败的错误信息或连接的其它标记位
|
||
* @return {ACL_VSTREAM*} 如果不为空,则表示连接成功后的数据流
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_timed_connect(const char *addr, int block_mode,
|
||
int connect_timeout, int rw_timeout, int rw_bufsize, unsigned *flags);
|
||
|
||
/**
|
||
* 针对 UDP 通信,该函数用来绑定本地 UDP 地址,如果绑定成功,则创建
|
||
* ACL_VSTREAM 对象, 用户可以象调用 ACL_VSTREAM 对象的读写接口
|
||
* @param addr {const char*} 本地 UDP 地址,格式:ip:port,可以输入地址 ip:0
|
||
* 来让操作系统自动分配本地端口号,此外还支持在 UNIX 平台下绑定 UNIX 域套接口,
|
||
* UNIX 域套接口的地址格式为:{path}@udp,其中 {path} 为域套接口路径,@udp 为
|
||
* UDP 后缀
|
||
* @param rw_timeout {int} 读写超时时间(秒)
|
||
* @param flag {unsigned} 标志位
|
||
* @return {ACL_VSTREAM*} 返回 NULL 表示绑定失败
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_bind(const char *addr, int rw_timeout, unsigned flag);
|
||
|
||
/**
|
||
* 将网络流对象设置为 UDP IO 模式
|
||
* @param stream {ACL_VSTREAM*}
|
||
*/
|
||
ACL_API void acl_vstream_set_udp_io(ACL_VSTREAM *stream);
|
||
|
||
/**
|
||
* 创建组播对象
|
||
* @param addr {const char*} 组播IP地址
|
||
* @param iface {const char*} 本机收发数据包的 IP 地址
|
||
* @param port {int} 本机收发数据包的 Port
|
||
* @param timeout {int} IO 超时时间(秒)
|
||
* @param flag {unsigned} 标志位
|
||
* @return {ACL_VSTREAM*} 返回 NULL 表示绑定失败
|
||
*/
|
||
ACL_API ACL_VSTREAM *acl_vstream_bind_multicast(const char *addr,
|
||
const char *iface, int port, int timeout, unsigned flag);
|
||
|
||
/**
|
||
* 设置组播的 TTL 选项 (1--255)
|
||
* @param sock {ACL_SOCKET}
|
||
* @param ttl {int}
|
||
* @return {int} 返回 -1 表示出错,0 表示成功
|
||
*/
|
||
ACL_API int acl_multicast_set_ttl(ACL_SOCKET sock, int ttl);
|
||
|
||
/**
|
||
* 设置组播绑定的本地地址
|
||
* @param sock {ACL_SOCKET}
|
||
* @param addr {const char*}
|
||
* @return {int} 返回 0 表示成功,-1 表示失败
|
||
*/
|
||
ACL_API int acl_multicast_set_if(ACL_SOCKET sock, const char *addr);
|
||
|
||
/**
|
||
* 离开组播,调用此 API 成功后将不再接收组播数据包
|
||
* @param sock {ACL_SOCKET}
|
||
* @param addr {const char*} 组播 IP
|
||
* @param iface {const char*} 本机绑定的接收 IP
|
||
* @return {int} 返回 0 表示成功,-1 表示失败
|
||
*/
|
||
ACL_API int acl_multicast_drop(ACL_SOCKET sock, const char *addr, const char *iface);
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif
|
||
|
||
#endif
|
||
|