2019-08-19 08:18:47 +00:00
|
|
|
|
#include <unistd.h>
|
2019-08-09 11:42:19 +00:00
|
|
|
|
#include "../include/parsefile.h"
|
|
|
|
|
#include "../include/configm.h"
|
|
|
|
|
#include "../../../netlink_uapi/libnetlinku.h"
|
2019-08-15 06:24:41 +00:00
|
|
|
|
#include "rpc.h"
|
2019-08-09 11:42:19 +00:00
|
|
|
|
#include "authfree.h"
|
2019-08-15 06:24:41 +00:00
|
|
|
|
#include "auth_parameters.h"
|
2019-08-09 11:42:19 +00:00
|
|
|
|
#include <cjson/cJSON.h>
|
2019-08-15 06:24:41 +00:00
|
|
|
|
#include "s2j/s2j.h"
|
|
|
|
|
#include "commuapinl.h"
|
|
|
|
|
#include "../Platform/common/database/database.h"
|
|
|
|
|
#include "include/user_authfree.h"
|
|
|
|
|
#include "config_manager.h"
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
/*定义结构体数组 存在免认证规则 */
|
|
|
|
|
freeauth_configure_t freeauth_array[RULE_MAX_NUM] = {0};
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
#define UNAMESIZE (127 + 1)
|
|
|
|
|
#define SPECHAR(element) (strpbrk((element), "~!@#$%^&*()_+{}|:\"<>?\\,./;\'[]-=`")) //校验特殊字符
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
#ifdef FREEAUTH_ACK_COOKIES
|
|
|
|
|
#define CFG_FREEAUTH_ACK_COOKIES
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* 判断IPv4格式是否正确*/
|
|
|
|
|
int isIpV4Addr(const char *ipAddr)
|
|
|
|
|
{
|
|
|
|
|
int ip_part_1 = 0;
|
|
|
|
|
int ip_part_2 = 0;
|
|
|
|
|
int ip_part_3 = 0;
|
|
|
|
|
int ip_part_4 = 0;
|
|
|
|
|
char end_char = 0;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if ((NULL == ipAddr) || (0 == strlen(ipAddr)))
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (4 == sscanf(ipAddr, "%d.%d.%d.%d%c", &ip_part_1, &ip_part_2, &ip_part_3, &ip_part_4, &end_char))
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if ((ip_part_1 >= 0) && (ip_part_1 <= 255) &&
|
|
|
|
|
(ip_part_2 >= 0) && (ip_part_2 <= 255) &&
|
|
|
|
|
(ip_part_3 >= 0) && (ip_part_3 <= 255) &&
|
|
|
|
|
(ip_part_4 >= 0) && (ip_part_4 <= 255))
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*下发配置到内核态 */
|
2019-08-09 11:42:19 +00:00
|
|
|
|
int set_freeauthcfg_waitack(freeauth_configure_t *struct_freeauth)
|
|
|
|
|
{
|
|
|
|
|
int freeauth_len = 0;
|
|
|
|
|
struct nlmsghdr *ack = NULL;
|
|
|
|
|
struct nlmsghdr **answer = &ack;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
|
|
|
|
struct
|
|
|
|
|
{
|
2019-08-09 11:42:19 +00:00
|
|
|
|
struct nlmsghdr n;
|
|
|
|
|
char buf[1024];
|
2019-08-15 06:24:41 +00:00
|
|
|
|
} req = {
|
2019-08-09 11:42:19 +00:00
|
|
|
|
.n.nlmsg_len = NLMSG_LENGTH(0),
|
|
|
|
|
#ifdef CFG_FREEAUTH_ACK_COOKIES
|
2019-08-15 06:24:41 +00:00
|
|
|
|
.n.nlmsg_flags = NLM_F_REQUEST | NLM_F_ACK, /*set NLM_F_ACK:use kernel auto ack*/
|
2019-08-09 11:42:19 +00:00
|
|
|
|
#else
|
|
|
|
|
.n.nlmsg_flags = NLM_F_REQUEST, /*not use kernel auto ack */
|
|
|
|
|
#endif
|
|
|
|
|
.n.nlmsg_type = FREEAUTH_CFG,
|
|
|
|
|
.n.nlmsg_pid = getpid(),
|
2019-08-15 06:24:41 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/*判断要发送的数据是否为NULL,不为NULL,打印出来 */
|
|
|
|
|
if (struct_freeauth == NULL)
|
|
|
|
|
{
|
|
|
|
|
printf("set_freeauthcfg_waitack is error: input struct_freeauth is NULL.\r\n");
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
char str[32];
|
|
|
|
|
memset(str, 0, 32);
|
|
|
|
|
inet_ntop(AF_INET, (void *)&struct_freeauth->sip, str, 32);
|
|
|
|
|
char *sip_addr = str;
|
|
|
|
|
char dtr[32];
|
|
|
|
|
memset(dtr, 0, 32);
|
|
|
|
|
inet_ntop(AF_INET, (void *)&struct_freeauth->dip, dtr, 32);
|
|
|
|
|
char *dip_addr = dtr;
|
|
|
|
|
printf("set_freeauthcfg_waitack :name %s sip %s dip %s dport %d\n",
|
|
|
|
|
struct_freeauth->name, sip_addr, dip_addr,
|
|
|
|
|
struct_freeauth->dport);
|
|
|
|
|
}
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
/*计算需要发送的数据的长度 */
|
|
|
|
|
freeauth_len = sizeof(freeauth_configure_t);
|
|
|
|
|
|
|
|
|
|
/*可选属性 */
|
|
|
|
|
commnl_addattr_l(&req.n, sizeof(req), 1, struct_freeauth, freeauth_len);
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
/*发送组装好的netlink消息 */
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (pdeliv_talk(1, &req.n, answer) < 0)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
printf("set_user_freeauth_waitack rcv ack msg faild.\r\n");
|
|
|
|
|
return -2;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
printf("set_user_freeauth_waitack rcv ack msg success.\r\n");
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
|
|
|
|
if (*answer != NULL)
|
|
|
|
|
{
|
|
|
|
|
printf("set_user_freeauth_waitack rcv answer.\r\n");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
printf("set_user_freeauth_waitack rcv answer error.\r\n");
|
|
|
|
|
return -3;
|
|
|
|
|
}
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
#ifdef CFG_FREEAUTH_ACK_COOKIES
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*recv answer*/
|
|
|
|
|
if ((*answer)->nlmsg_type == NLMSG_ERROR)
|
|
|
|
|
{
|
|
|
|
|
nl_debugfs_extack(*answer);
|
|
|
|
|
}
|
2019-08-09 11:42:19 +00:00
|
|
|
|
#else
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*recv answer*/
|
|
|
|
|
if ((*answer)->nlmsg_type == FREEAUTH_CFG)
|
|
|
|
|
{
|
|
|
|
|
nl_debugfs(*answer);
|
|
|
|
|
}
|
2019-08-09 11:42:19 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
return 0;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
|
|
|
|
/*获取json串类型*/
|
|
|
|
|
ret_code freeauth_config_json_type(pointer input, uint *conf_type)
|
|
|
|
|
{
|
|
|
|
|
char* pString = (char*)input;
|
|
|
|
|
ret_code ret = RET_OK;
|
|
|
|
|
cJSON *cjson, *type;
|
|
|
|
|
|
|
|
|
|
printf("json:[%s]\n", pString);
|
|
|
|
|
|
|
|
|
|
/*JSON字符串到JSON格式 */
|
|
|
|
|
cjson = cJSON_Parse(input);
|
|
|
|
|
if(!cjson)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
ASSERT_RET(ret);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*获取操作类型 add、mod、del */
|
|
|
|
|
type = cJSON_GetObjectItem(cjson, "type");
|
|
|
|
|
if(!type)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
*conf_type = type->valueint;
|
|
|
|
|
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return RET_OK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*json字符串转为结构体*/
|
|
|
|
|
/*iuput格式:{"type": 0, "data": {"rule_priority": 1, "name": "armink","sip": 1027824,"dip": 103427824,"dport": 24, "flag":0}}*/
|
2019-08-09 11:42:19 +00:00
|
|
|
|
ret_code freeauth_config_json_parse(pointer input, uint *conf_type, freeauth_configure_t *freeauth_buff)
|
|
|
|
|
{
|
2019-08-15 06:24:41 +00:00
|
|
|
|
char *pString = (char *)input;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
ret_code ret = RET_OK;
|
|
|
|
|
cJSON *cjson, *type, *data;
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
printf("json:[%s]\n", pString);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
/*JSON字符串到JSON格式 */
|
2019-08-15 06:24:41 +00:00
|
|
|
|
cjson = cJSON_Parse(pString);
|
|
|
|
|
if (!cjson)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
ASSERT_RET(ret);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
/*获取操作类型 add、mod、del */
|
|
|
|
|
type = cJSON_GetObjectItem(cjson, "type");
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (!type)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
*conf_type = type->valueint;
|
|
|
|
|
|
|
|
|
|
/*获取免认证规则的data部分 */
|
|
|
|
|
data = cJSON_GetObjectItem(cjson, "data");
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (!data)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*创建freeauth_configure_t结构体对象 */
|
|
|
|
|
s2j_create_struct_obj(struct_freeauth, freeauth_configure_t);
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (struct_freeauth == NULL)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*反序列化数据到freeauth_configure_t结构体对象 */
|
2019-08-19 08:18:47 +00:00
|
|
|
|
s2j_struct_get_basic_element(struct_freeauth, data, int, rule_priority);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
s2j_struct_get_basic_element(struct_freeauth, data, string, name);
|
|
|
|
|
s2j_struct_get_basic_element(struct_freeauth, data, int, sip);
|
|
|
|
|
s2j_struct_get_basic_element(struct_freeauth, data, int, dip);
|
|
|
|
|
s2j_struct_get_basic_element(struct_freeauth, data, int, dport);
|
2019-08-19 08:18:47 +00:00
|
|
|
|
s2j_struct_get_basic_element(struct_freeauth, data, int, flag);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
freeauth_buff->rule_priority = struct_freeauth->rule_priority;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
memcpy(freeauth_buff->name, struct_freeauth->name, sizeof(char) * 32);
|
|
|
|
|
freeauth_buff->sip = struct_freeauth->sip;
|
|
|
|
|
freeauth_buff->dip = struct_freeauth->dip;
|
|
|
|
|
freeauth_buff->dport = struct_freeauth->dport;
|
2019-08-19 08:18:47 +00:00
|
|
|
|
freeauth_buff->flag = struct_freeauth->flag;
|
|
|
|
|
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
|
|
|
|
|
return RET_OK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*iuput格式:
|
|
|
|
|
{
|
|
|
|
|
"type": 0,
|
|
|
|
|
"data": [
|
|
|
|
|
{"rule_priority": 1,"name": "cary","sip": 2323790,"dip": 13546465478,"dport": 120, "flag":0},
|
|
|
|
|
{"rule_priority": 2,"name": "nicole","sip": 2323790,"dip": 13546465478,"dport": 130, "flag":0},
|
|
|
|
|
{"rule_priority": 3,"name": "arwrgmink","sip": 2323790,"dip": 13546465478,"dport": 90, "flag":0}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
*/
|
|
|
|
|
ret_code authpara_config_json_parse_array(pointer input, uint *conf_type, freeauth_configure_t **fb, int *cnt)
|
|
|
|
|
{
|
|
|
|
|
ret_code ret = RET_OK;
|
|
|
|
|
cJSON *cjson, *type, *data, *rule_priority, *name, *sip, *dip, *dport, *flag;
|
|
|
|
|
cJSON* pArrayItem;
|
|
|
|
|
freeauth_configure_t* pbuf, *freeauth_buff = *fb;
|
|
|
|
|
int iCount = 0, i = 0;
|
|
|
|
|
|
|
|
|
|
/*JSON字符串到JSON格式 */
|
|
|
|
|
cjson = cJSON_Parse(input);
|
|
|
|
|
if(!cjson)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
ASSERT_RET(ret);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
rpc_log_info("json input:%s \n", cJSON_Print(cjson));
|
|
|
|
|
|
|
|
|
|
/*获取免认证规则的data部分 */
|
|
|
|
|
data = cJSON_GetObjectItem(cjson, "data");
|
|
|
|
|
if(!data)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*获取数组长度*/
|
|
|
|
|
iCount = cJSON_GetArraySize(data);
|
|
|
|
|
printf("iCount=[%d]\n",iCount);
|
|
|
|
|
|
|
|
|
|
freeauth_buff = (freeauth_configure_t*)malloc(sizeof(freeauth_configure_t) * iCount);
|
|
|
|
|
if(!freeauth_buff) {
|
|
|
|
|
ret = RET_NOMEM;
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
memset(freeauth_buff, 0, sizeof(freeauth_configure_t) * iCount);
|
|
|
|
|
*fb = freeauth_buff;
|
|
|
|
|
|
|
|
|
|
/*创建freeauth_configure_t结构体对象 */
|
|
|
|
|
s2j_create_struct_obj(struct_freeauth, freeauth_configure_t);
|
|
|
|
|
if (struct_freeauth == NULL)
|
|
|
|
|
{
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pbuf = freeauth_buff;
|
|
|
|
|
*cnt = 0;
|
|
|
|
|
for(i = 0; i < iCount; i++)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
pArrayItem = cJSON_GetArrayItem(data, i);
|
|
|
|
|
if(pArrayItem)
|
|
|
|
|
{
|
|
|
|
|
/*获取未认证权限优先级键值对*/
|
|
|
|
|
rule_priority = cJSON_GetObjectItem(pArrayItem, "rule_priority");
|
|
|
|
|
if(!rule_priority)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(data);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
freeauth_buff->rule_priority = rule_priority->valueint;
|
|
|
|
|
|
|
|
|
|
/*未认证权限名称*/
|
|
|
|
|
name = cJSON_GetObjectItem(pArrayItem, "name");
|
|
|
|
|
if(!name)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(data);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
char *rule_name = name->valuestring;
|
|
|
|
|
memcpy(freeauth_buff->name, rule_name, sizeof(char) * 32);
|
|
|
|
|
|
|
|
|
|
/*源IP地址*/
|
|
|
|
|
sip = cJSON_GetObjectItem(pArrayItem, "sip");
|
|
|
|
|
if(!sip)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(data);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
freeauth_buff->sip = sip->valueint;
|
|
|
|
|
|
|
|
|
|
/*目的IP地址*/
|
|
|
|
|
dip = cJSON_GetObjectItem(pArrayItem, "dip");
|
|
|
|
|
if(!sip)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(data);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
freeauth_buff->dip = dip->valueint;
|
|
|
|
|
|
|
|
|
|
/*目的端口号*/
|
|
|
|
|
dport = cJSON_GetObjectItem(pArrayItem, "dport");
|
|
|
|
|
if(!dport)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(data);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
freeauth_buff->dport = dport->valueint;
|
|
|
|
|
|
|
|
|
|
/*状态标志位*/
|
|
|
|
|
flag = cJSON_GetObjectItem(pArrayItem, "flag");
|
|
|
|
|
if(!flag)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(data);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
freeauth_buff->flag = flag->valueint;
|
|
|
|
|
|
|
|
|
|
printf("freeauth_buff->name = %p\n", &freeauth_buff->name);
|
|
|
|
|
|
|
|
|
|
for (int j = 0; j < iCount; j++)
|
|
|
|
|
{
|
|
|
|
|
printf("[%d %s %d %d %d %d]\n",pbuf[j].rule_priority, pbuf[j].name, pbuf[j].sip,
|
|
|
|
|
pbuf[j].dip, pbuf[j].dport, pbuf[j].flag);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
freeauth_buff++;
|
|
|
|
|
(*cnt)++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//s2j_delete_struct_obj(auth_parameters);
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
|
|
|
|
|
return RET_OK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ret_code authpara_config_json_parse_del_array(pointer input, uint *conf_type, freeauth_configure_t **fb, int *cnt)
|
|
|
|
|
{
|
|
|
|
|
ret_code ret = RET_OK;
|
|
|
|
|
cJSON *cjson, *type, *data, *name;
|
|
|
|
|
cJSON* pArrayItem;
|
|
|
|
|
freeauth_configure_t* pbuf, *freeauth_buff = *fb;
|
|
|
|
|
int iCount = 0, i = 0;
|
|
|
|
|
|
|
|
|
|
/*JSON字符串到JSON格式 */
|
|
|
|
|
cjson = cJSON_Parse(input);
|
|
|
|
|
if(!cjson)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
ASSERT_RET(ret);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
rpc_log_info("json input:%s \n", cJSON_Print(cjson));
|
|
|
|
|
|
|
|
|
|
/*获取免认证规则的data部分 */
|
|
|
|
|
data = cJSON_GetObjectItem(cjson, "data");
|
|
|
|
|
if(!data)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*获取数组长度*/
|
|
|
|
|
iCount = cJSON_GetArraySize(data);
|
|
|
|
|
printf("iCount=[%d]\n",iCount);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
freeauth_buff = (freeauth_configure_t*)malloc(sizeof(freeauth_configure_t) * iCount);
|
|
|
|
|
|
|
|
|
|
if(!freeauth_buff) {
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
memset(freeauth_buff, 0, sizeof(freeauth_configure_t) * iCount);
|
|
|
|
|
*fb = freeauth_buff;
|
|
|
|
|
|
|
|
|
|
/*创建freeauth_configure_t结构体对象 */
|
|
|
|
|
s2j_create_struct_obj(struct_freeauth, freeauth_configure_t);
|
|
|
|
|
if (struct_freeauth == NULL)
|
|
|
|
|
{
|
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pbuf = freeauth_buff;
|
|
|
|
|
*cnt = 0;
|
|
|
|
|
for(i = 0; i < iCount; i++)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
pArrayItem = cJSON_GetArrayItem(data, i);
|
|
|
|
|
if(pArrayItem)
|
|
|
|
|
{
|
|
|
|
|
name = cJSON_GetObjectItem(pArrayItem, "name");
|
|
|
|
|
if(!name)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
cJSON_Delete(data);
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
char *rule_name = name->valuestring;
|
|
|
|
|
memcpy(freeauth_buff->name, rule_name, sizeof(char) * 32);
|
|
|
|
|
printf("freeauth_buff->name = %p name = %s\n", &freeauth_buff->name, freeauth_buff->name);
|
|
|
|
|
|
|
|
|
|
printf("\n");
|
|
|
|
|
for (int j = 0; j < iCount; j++)
|
|
|
|
|
{
|
|
|
|
|
printf("[%s] %d\n",pbuf[j].name, j);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
freeauth_buff++;
|
|
|
|
|
(*cnt)++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//s2j_delete_struct_obj(auth_parameters);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
cJSON_Delete(cjson);
|
|
|
|
|
|
|
|
|
|
return RET_OK;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*chk data格式 */
|
|
|
|
|
ret_code freeauth_config_chk(uint source, uint *config_type,
|
|
|
|
|
pointer input, int *input_len,
|
|
|
|
|
pointer output, int *output_len)
|
|
|
|
|
{
|
|
|
|
|
ret_code ret = RET_OK;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ret_code freeauth_config_add_proc(uint source, uint config_type,
|
|
|
|
|
pointer input, int input_len,
|
|
|
|
|
pointer output, int *output_len)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret_code ret = RET_OK;
|
|
|
|
|
freeauth_configure_t *freeauth_configure;
|
2019-08-19 08:18:47 +00:00
|
|
|
|
uint conf_type = FREEAUTH_CONFIG_GET;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
char str[32] = {0};
|
|
|
|
|
char dtr[32] = {0};
|
2019-08-15 06:24:41 +00:00
|
|
|
|
cJSON *res;
|
|
|
|
|
char *ret_char = NULL;
|
|
|
|
|
unsigned int ret_int = 0;
|
|
|
|
|
authfree_result_t *authfree_result;
|
|
|
|
|
int i;
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
|
|
|
|
freeauth_configure = (freeauth_configure_t*)malloc(sizeof(freeauth_configure_t));
|
|
|
|
|
if(freeauth_configure == NULL)
|
|
|
|
|
{
|
|
|
|
|
return RET_NAMEINVAL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
freeauth_config_json_parse(input, &conf_type, freeauth_configure);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
if((input_len < sizeof(freeauth_configure_t)) || (input_len > sizeof(freeauth_configure_t)))
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
|
|
|
|
/*校验用户名长度 特殊字符等*/
|
|
|
|
|
if (NULL == freeauth_configure->name || (UNAMESIZE) < strlen(freeauth_configure->name) || 0 >= strlen(freeauth_configure->name))
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* 校验用户名中不含特殊字符 */
|
|
|
|
|
if (SPECHAR(freeauth_configure->name))
|
|
|
|
|
{
|
|
|
|
|
ret = RET_INPUTERR;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*校验源IP地址是否符合格式*/
|
2019-08-09 11:42:19 +00:00
|
|
|
|
memset(str, 0, 32);
|
|
|
|
|
inet_ntop(AF_INET, (void *)&freeauth_configure->sip, str, 32);
|
|
|
|
|
char *sip_addr = str;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (isIpV4Addr(sip_addr) < 0)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret = RET_IPINVALID;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*校验目的IP地址是否符合格式*/
|
2019-08-09 11:42:19 +00:00
|
|
|
|
memset(dtr, 0, 32);
|
|
|
|
|
inet_ntop(AF_INET, (void *)&freeauth_configure->dip, dtr, 32);
|
|
|
|
|
char *dip_addr = dtr;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (isIpV4Addr(dip_addr) < 0)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret = RET_IPINVALID;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if ((freeauth_configure->dport < DPORT_MIN_NUM) && (freeauth_configure->dport > DPORT_MAX_NUM))
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret = RET_IPINVALID; /*先用IPVAILD表示,后面加PORTVAILD */
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*查找要增加的未认证权限是否重名 该名字已存在 则退出程序 */
|
|
|
|
|
for (i = 0; i < RULE_MAX_NUM; i++)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*两个字符串相等 strcmp值为0*/
|
|
|
|
|
if (0 == strcmp(freeauth_array[i].name, freeauth_configure->name))
|
|
|
|
|
{
|
|
|
|
|
printf("%s(%d) freeauth_array[%d] = %p\n", __FUNCTION__, __LINE__, i, &freeauth_array[i]);
|
|
|
|
|
return RET_NOTFOUND;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
printf("%s(%d) freeauth_array[%d] = %p\n", __FUNCTION__, __LINE__, i, &freeauth_array[i]);
|
|
|
|
|
}
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
/*数据库修改 存入全局变量*/
|
|
|
|
|
authfree_result = (authfree_result_t *)malloc(sizeof(authfree_result_t));
|
|
|
|
|
if (NULL == authfree_result)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
2019-08-15 06:24:41 +00:00
|
|
|
|
return RET_NOMEM;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
add_authfree(freeauth_configure->rule_priority, freeauth_configure->name, freeauth_configure->sip, freeauth_configure->dip,
|
|
|
|
|
freeauth_configure->dport, freeauth_configure->flag, authfree_result);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
#if 0
|
2019-08-09 11:42:19 +00:00
|
|
|
|
/*用户态下发到内核态auth_hook */
|
|
|
|
|
int r = -1;
|
|
|
|
|
printf("cfgchannel main begin:\r\n");
|
|
|
|
|
|
|
|
|
|
/*创建通道 */
|
|
|
|
|
r = commcfgnl_open();
|
|
|
|
|
if(r < 0)
|
|
|
|
|
{
|
|
|
|
|
printf(" pdlivnl_open fail, exit.\r\n");
|
|
|
|
|
return RET_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*下发配置到内核态 */
|
|
|
|
|
r = set_freeauthcfg_waitack(freeauth_configure);
|
|
|
|
|
if(r < 0)
|
|
|
|
|
{
|
|
|
|
|
printf("set_cfg_debug_waitack failed.\r\n");
|
|
|
|
|
return RET_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*关闭netlink通道 */
|
|
|
|
|
commcfgnl_close();
|
|
|
|
|
printf("cfgchannel main exit!\r\n");
|
2019-08-15 06:24:41 +00:00
|
|
|
|
#endif
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
/*创建json对象 */
|
|
|
|
|
res = cJSON_CreateObject();
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (!res)
|
|
|
|
|
{
|
2019-08-09 11:42:19 +00:00
|
|
|
|
free(freeauth_configure);
|
|
|
|
|
ret = RET_ERR;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*将json对象转换成json字符串 返回处理结果*/
|
2019-08-15 06:24:41 +00:00
|
|
|
|
cJSON_AddNumberToObject(res, "resultcode", authfree_result->resultcode);
|
|
|
|
|
cJSON_AddStringToObject(res, "message", authfree_result->message);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
ret_char = cJSON_PrintUnformatted(res);
|
|
|
|
|
ret_int = strlen(ret_char);
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (output_len)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
*output_len = ret_int;
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
/*超出2k的内存,报错 */
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if (ret_int >= 1024 * 2)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
free(ret_char);
|
|
|
|
|
cJSON_Delete(res);
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
memcpy(output, ret_char, ret_int + 1);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
free(ret_char);
|
|
|
|
|
cJSON_Delete(res);
|
2019-08-15 06:24:41 +00:00
|
|
|
|
return RET_OK;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ret_code freeauth_config_mod_proc(uint source, uint config_type,
|
2019-08-15 06:24:41 +00:00
|
|
|
|
pointer input, int input_len,
|
|
|
|
|
pointer output, int *output_len)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
2019-08-19 08:18:47 +00:00
|
|
|
|
freeauth_configure_t* freeauth_configure = NULL;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
ret_code ret = RET_OK;
|
2019-08-19 08:18:47 +00:00
|
|
|
|
uint conf_type = FREEAUTH_CONFIG_GET;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
cJSON *res;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
char *ret_char = NULL;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
unsigned int ret_int = 0;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
int i;
|
2019-08-19 08:18:47 +00:00
|
|
|
|
int cnt;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
authfree_result_t *authfree_result;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
|
freeauth_configure = (freeauth_configure_t*)malloc(sizeof(freeauth_configure_t));
|
|
|
|
|
if(freeauth_configure == NULL)
|
|
|
|
|
{
|
|
|
|
|
return RET_NAMEINVAL;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
authpara_config_json_parse_array(input, &conf_type, &freeauth_configure, &cnt);
|
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
if ((input_len < sizeof(freeauth_configure_t)) || (input_len > sizeof(freeauth_configure_t)))
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
2019-08-15 06:24:41 +00:00
|
|
|
|
ret = RET_INPUTERR;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
return ret;
|
|
|
|
|
}
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
/**/
|
2019-08-15 06:24:41 +00:00
|
|
|
|
for (i = 0; i < RULE_MAX_NUM; i++)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
2019-08-19 08:18:47 +00:00
|
|
|
|
printf("%d %s %d %d %d %d %d\n",freeauth_array[i].rule_priority, freeauth_array[i].name, freeauth_array[i].sip,
|
|
|
|
|
freeauth_array[i].dip, freeauth_array[i].dport, freeauth_array[i].flag, i);
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
for (int j = 0; j < cnt; j++)
|
|
|
|
|
{
|
|
|
|
|
printf("%d %s %d %d %d %d %d\n",freeauth_configure[j].rule_priority, freeauth_configure[j].name, freeauth_configure[j].sip,
|
|
|
|
|
freeauth_configure[j].dip, freeauth_configure[j].dport, freeauth_configure[j].flag, j);
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
/*查找要修改的免认证规则名字,不存在则退出程序 */
|
|
|
|
|
for (i = 0; i < RULE_MAX_NUM; i++)
|
|
|
|
|
{
|
|
|
|
|
/*两个字符串相等 strcmp值为0*/
|
|
|
|
|
for(int j = 0; j < cnt; j++)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if (0 == strcmp(freeauth_array[i].name, freeauth_configure[j].name))
|
2019-08-15 06:24:41 +00:00
|
|
|
|
{
|
2019-08-19 08:18:47 +00:00
|
|
|
|
printf("%s %d\n", freeauth_array[i].name, i);
|
|
|
|
|
printf("%s %d\n", freeauth_configure[j].name, j);
|
|
|
|
|
printf("%s(%d) freeauth_array[%d] = %p\n", __FUNCTION__, __LINE__, i, &freeauth_array[j]);
|
|
|
|
|
/*数据库修改 存入全局变量*/
|
|
|
|
|
authfree_result = (authfree_result_t *)malloc(sizeof(authfree_result_t));
|
|
|
|
|
if (NULL == authfree_result)
|
|
|
|
|
{
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mod_authfree(freeauth_configure[j].rule_priority,freeauth_configure[j].name, freeauth_configure[j].sip, freeauth_configure[j].dip,
|
|
|
|
|
freeauth_configure[j].dport, freeauth_configure[j].flag, authfree_result);
|
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
|
/*用户态下发到内核态auth_hook */
|
|
|
|
|
int r = -1;
|
|
|
|
|
printf("cfgchannel main begin:\r\n");
|
|
|
|
|
|
|
|
|
|
/*创建通道 */
|
|
|
|
|
r = commcfgnl_open();
|
|
|
|
|
if(r < 0)
|
|
|
|
|
{
|
|
|
|
|
printf(" pdlivnl_open fail, exit.\r\n");
|
|
|
|
|
return RET_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*下发配置到内核态 */
|
|
|
|
|
r = set_freeauthcfg_waitack(freeauth_configure);
|
|
|
|
|
if(r < 0)
|
|
|
|
|
{
|
|
|
|
|
printf("set_cfg_debug_waitack failed.\r\n");
|
|
|
|
|
return RET_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*关闭netlink通道 */
|
|
|
|
|
commcfgnl_close();
|
|
|
|
|
printf("cfgchannel main exit!\r\n");
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/*创建json对象 */
|
|
|
|
|
res = cJSON_CreateObject();
|
|
|
|
|
if (!res)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_ERR;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*将json对象转换成json字符串 返回处理结果*/
|
|
|
|
|
cJSON_AddNumberToObject(res, "resultcode", authfree_result->resultcode);
|
|
|
|
|
cJSON_AddStringToObject(res, "message", authfree_result->message);
|
|
|
|
|
ret_char = cJSON_PrintUnformatted(res);
|
|
|
|
|
ret_int = strlen(ret_char);
|
|
|
|
|
if (output_len)
|
|
|
|
|
{
|
|
|
|
|
*output_len = ret_int;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*超出2k的内存,报错 */
|
|
|
|
|
if (ret_int >= 1024 * 2)
|
|
|
|
|
{
|
|
|
|
|
free(ret_char);
|
|
|
|
|
cJSON_Delete(res);
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
memcpy(output, ret_char, ret_int + 1);
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
|
|
|
|
free(ret_char);
|
|
|
|
|
cJSON_Delete(res);
|
|
|
|
|
}
|
2019-08-19 08:18:47 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
if(freeauth_configure) {
|
|
|
|
|
free(freeauth_configure);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
return RET_OK;
|
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
ret_code freeauth_config_del_proc(uint source, uint config_type,
|
2019-08-15 06:24:41 +00:00
|
|
|
|
pointer input, int input_len,
|
|
|
|
|
pointer output, int *output_len)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
2019-08-19 08:18:47 +00:00
|
|
|
|
freeauth_configure_t* freeauth_configure = NULL;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
ret_code ret = RET_OK;
|
2019-08-19 08:18:47 +00:00
|
|
|
|
uint conf_type = FREEAUTH_CONFIG_GET;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
cJSON *res;
|
|
|
|
|
char *ret_char = NULL;
|
|
|
|
|
unsigned int ret_int = 0;
|
|
|
|
|
int i;
|
2019-08-19 08:18:47 +00:00
|
|
|
|
int cnt;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
authfree_result_t *authfree_result;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
|
freeauth_configure = (freeauth_configure_t*)malloc(sizeof(freeauth_configure_t));
|
|
|
|
|
if(freeauth_configure == NULL)
|
|
|
|
|
{
|
|
|
|
|
return RET_NAMEINVAL;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
authpara_config_json_parse_del_array(input, &conf_type, &freeauth_configure, &cnt);
|
|
|
|
|
|
|
|
|
|
if ((input_len < sizeof(freeauth_configure_t)) || (input_len > sizeof(freeauth_configure_t)))
|
|
|
|
|
{
|
2019-08-15 06:24:41 +00:00
|
|
|
|
ret = RET_INPUTERR;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
return ret;
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
for (i = 0; i < RULE_MAX_NUM; i++)
|
|
|
|
|
{
|
|
|
|
|
printf("%d %s %d %d %d %d %d\n",freeauth_array[i].rule_priority, freeauth_array[i].name, freeauth_array[i].sip,
|
|
|
|
|
freeauth_array[i].dip, freeauth_array[i].dport, freeauth_array[i].flag, i);
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
for (int j = 0; j < cnt; j++)
|
|
|
|
|
{
|
|
|
|
|
printf("%d %s %d %d %d %d %d\n",freeauth_configure[j].rule_priority, freeauth_configure[j].name, freeauth_configure[j].sip,
|
|
|
|
|
freeauth_configure[j].dip, freeauth_configure[j].dport, freeauth_configure[j].flag, j);
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
/*查找要修改的免认证规则名字,不存在则退出程序 */
|
|
|
|
|
for (i = 0; i < RULE_MAX_NUM; i++)
|
|
|
|
|
{
|
|
|
|
|
/*两个字符串相等 strcmp值为0*/
|
|
|
|
|
for(int j = 0; j < cnt; j++)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if (0 == strcmp(freeauth_array[i].name, freeauth_configure[j].name))
|
2019-08-15 06:24:41 +00:00
|
|
|
|
{
|
2019-08-19 08:18:47 +00:00
|
|
|
|
printf("%s %d\n", freeauth_array[i].name, i);
|
|
|
|
|
printf("%s %d\n", freeauth_configure[j].name, j);
|
|
|
|
|
printf("%s(%d) freeauth_array[%d] = %p\n", __FUNCTION__, __LINE__, i, &freeauth_array[j]);
|
|
|
|
|
/*数据库修改 存入全局变量*/
|
|
|
|
|
authfree_result = (authfree_result_t *)malloc(sizeof(authfree_result_t));
|
|
|
|
|
if (NULL == authfree_result)
|
|
|
|
|
{
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
del_authfree(freeauth_configure[j].name, authfree_result);
|
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
|
/*用户态下发到内核态auth_hook */
|
|
|
|
|
int r = -1;
|
|
|
|
|
printf("cfgchannel main begin:\r\n");
|
|
|
|
|
|
|
|
|
|
/*创建通道 */
|
|
|
|
|
r = commcfgnl_open();
|
|
|
|
|
if(r < 0)
|
|
|
|
|
{
|
|
|
|
|
printf(" pdlivnl_open fail, exit.\r\n");
|
|
|
|
|
return RET_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*下发配置到内核态 */
|
|
|
|
|
r = set_freeauthcfg_waitack(freeauth_configure);
|
|
|
|
|
if(r < 0)
|
|
|
|
|
{
|
|
|
|
|
printf("set_cfg_debug_waitack failed.\r\n");
|
|
|
|
|
return RET_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*关闭netlink通道 */
|
|
|
|
|
commcfgnl_close();
|
|
|
|
|
printf("cfgchannel main exit!\r\n");
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/*创建json对象 */
|
|
|
|
|
res = cJSON_CreateObject();
|
|
|
|
|
if (!res)
|
|
|
|
|
{
|
|
|
|
|
ret = RET_ERR;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*将json对象转换成json字符串 返回处理结果*/
|
|
|
|
|
cJSON_AddNumberToObject(res, "resultcode", authfree_result->resultcode);
|
|
|
|
|
cJSON_AddStringToObject(res, "message", authfree_result->message);
|
|
|
|
|
ret_char = cJSON_PrintUnformatted(res);
|
|
|
|
|
ret_int = strlen(ret_char);
|
|
|
|
|
if (output_len)
|
|
|
|
|
{
|
|
|
|
|
*output_len = ret_int;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*超出2k的内存,报错 */
|
|
|
|
|
if (ret_int >= 1024 * 2)
|
|
|
|
|
{
|
|
|
|
|
free(ret_char);
|
|
|
|
|
cJSON_Delete(res);
|
|
|
|
|
return RET_NOMEM;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
memcpy(output, ret_char, ret_int + 1);
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
|
|
|
|
free(ret_char);
|
|
|
|
|
cJSON_Delete(res);
|
|
|
|
|
}
|
2019-08-19 08:18:47 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-08-15 06:24:41 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
if(freeauth_configure) {
|
|
|
|
|
free(freeauth_configure);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
|
|
|
|
return RET_OK;
|
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|
2019-08-09 11:42:19 +00:00
|
|
|
|
ret_code freeauth_config_proc(uint source, uint config_type,
|
2019-08-15 06:24:41 +00:00
|
|
|
|
pointer input, int input_len,
|
|
|
|
|
pointer output, int *output_len)
|
2019-08-09 11:42:19 +00:00
|
|
|
|
{
|
|
|
|
|
ret_code ret = RET_OK;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
freeauth_configure_t freeauth_configure = {0};
|
|
|
|
|
int config_len = sizeof(freeauth_configure_t);
|
|
|
|
|
uint conf_type = FREEAUTH_CONFIG_GET;
|
|
|
|
|
char *ret_char = NULL;
|
|
|
|
|
unsigned int ret_int = 0;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
int r = -1;
|
|
|
|
|
cJSON *res;
|
2019-08-15 06:24:41 +00:00
|
|
|
|
int code = 0;
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
freeauth_config_json_type(input, &conf_type);
|
|
|
|
|
rpc_log_info("config type is %d\n", conf_type);
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
switch (conf_type)
|
2019-08-15 06:24:41 +00:00
|
|
|
|
{
|
|
|
|
|
case FREEAUTH_CONFIG_ADD:
|
|
|
|
|
ret = freeauth_config_add_proc(source, conf_type,
|
2019-08-19 08:18:47 +00:00
|
|
|
|
input, input_len,
|
2019-08-15 06:24:41 +00:00
|
|
|
|
output, output_len);
|
|
|
|
|
break;
|
|
|
|
|
case FREEAUTH_CONFIG_MOD:
|
|
|
|
|
ret = freeauth_config_mod_proc(source, conf_type,
|
2019-08-19 08:18:47 +00:00
|
|
|
|
input, input_len,
|
2019-08-15 06:24:41 +00:00
|
|
|
|
output, output_len);
|
|
|
|
|
break;
|
|
|
|
|
case FREEAUTH_CONFIG_DEL:
|
|
|
|
|
ret = freeauth_config_del_proc(source, conf_type,
|
2019-08-19 08:18:47 +00:00
|
|
|
|
input, input_len,
|
2019-08-15 06:24:41 +00:00
|
|
|
|
output, output_len);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
ret = RET_NOTSUPPORT;
|
|
|
|
|
}
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
2019-08-15 06:24:41 +00:00
|
|
|
|
return RET_OK;
|
|
|
|
|
}
|
2019-08-09 11:42:19 +00:00
|
|
|
|
|
|
|
|
|
|
2019-08-19 08:18:47 +00:00
|
|
|
|
|