(1)app ip 界面IP属性使用function_region_dict控制
(2)app ip IP复用策略提交
This commit is contained in:
@@ -1,7 +1,6 @@
|
|||||||
package com.nis.web.controller.configuration;
|
package com.nis.web.controller.configuration;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.security.cert.X509Certificate;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@@ -10,7 +9,6 @@ import java.util.Map;
|
|||||||
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import javax.ws.rs.POST;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
||||||
@@ -41,13 +39,11 @@ import com.nis.domain.configuration.AppTopicDomainCfg;
|
|||||||
import com.nis.domain.configuration.IpPortCfg;
|
import com.nis.domain.configuration.IpPortCfg;
|
||||||
import com.nis.domain.configuration.NtcSubscribeIdCfg;
|
import com.nis.domain.configuration.NtcSubscribeIdCfg;
|
||||||
import com.nis.domain.configuration.WebsiteDomainTopic;
|
import com.nis.domain.configuration.WebsiteDomainTopic;
|
||||||
import com.nis.domain.configuration.AppBuiltInFeatureFile;
|
|
||||||
import com.nis.domain.maat.ToMaatResult;
|
import com.nis.domain.maat.ToMaatResult;
|
||||||
import com.nis.domain.maat.ToMaatResult.ResponseData;
|
import com.nis.domain.maat.ToMaatResult.ResponseData;
|
||||||
import com.nis.domain.specific.SpecificServiceCfg;
|
import com.nis.domain.specific.SpecificServiceCfg;
|
||||||
import com.nis.exceptions.CallExternalProceduresException;
|
import com.nis.exceptions.CallExternalProceduresException;
|
||||||
import com.nis.exceptions.MaatConvertException;
|
import com.nis.exceptions.MaatConvertException;
|
||||||
import com.nis.util.CodeDicUtils;
|
|
||||||
import com.nis.util.ConfigServiceUtil;
|
import com.nis.util.ConfigServiceUtil;
|
||||||
import com.nis.util.Constants;
|
import com.nis.util.Constants;
|
||||||
import com.nis.util.DictUtils;
|
import com.nis.util.DictUtils;
|
||||||
@@ -55,8 +51,6 @@ import com.nis.util.FileUtils;
|
|||||||
import com.nis.util.JsonMapper;
|
import com.nis.util.JsonMapper;
|
||||||
import com.nis.util.StringUtil;
|
import com.nis.util.StringUtil;
|
||||||
import com.nis.web.controller.BaseController;
|
import com.nis.web.controller.BaseController;
|
||||||
import com.nis.web.dao.configuration.AppBuiltInFeatureDao;
|
|
||||||
import com.nis.web.dao.dashboard.codedic.CodeResult;
|
|
||||||
import com.nis.web.security.UserUtils;
|
import com.nis.web.security.UserUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -313,6 +307,8 @@ public class AppCfgController extends BaseController {
|
|||||||
public String auditAppIpCfg(Integer isAudit,Integer isValid,String ids,Integer functionId, RedirectAttributes redirectAttributes) {
|
public String auditAppIpCfg(Integer isAudit,Integer isValid,String ids,Integer functionId, RedirectAttributes redirectAttributes) {
|
||||||
AppIpCfg entity = new AppIpCfg();
|
AppIpCfg entity = new AppIpCfg();
|
||||||
String[] idArray = ids.split(",");
|
String[] idArray = ids.split(",");
|
||||||
|
//同一编译IP的分组
|
||||||
|
Map<Integer,List<AppIpCfg>> dataMap=new HashMap<>();
|
||||||
for(String id :idArray){
|
for(String id :idArray){
|
||||||
entity = appCfgService.getAppIpCfg(Long.parseLong(id));
|
entity = appCfgService.getAppIpCfg(Long.parseLong(id));
|
||||||
entity.setIsAudit(isAudit);
|
entity.setIsAudit(isAudit);
|
||||||
@@ -320,14 +316,25 @@ public class AppCfgController extends BaseController {
|
|||||||
entity.setAuditorId(UserUtils.getUser().getId());
|
entity.setAuditorId(UserUtils.getUser().getId());
|
||||||
entity.setAuditTime(new Date());
|
entity.setAuditTime(new Date());
|
||||||
entity.setFunctionId(functionId);
|
entity.setFunctionId(functionId);
|
||||||
|
entity.setTableName(AppIpCfg.getTablename());
|
||||||
|
if(dataMap.containsKey(entity.getCompileId())) {
|
||||||
|
dataMap.get(entity.getCompileId()).add(entity);
|
||||||
|
}else {
|
||||||
|
List<AppIpCfg> ipList=new ArrayList<>();
|
||||||
|
ipList.add(entity);
|
||||||
|
dataMap.put(entity.getCompileId(), ipList);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for(List<AppIpCfg> entitys:dataMap.values()) {
|
||||||
try {
|
try {
|
||||||
appCfgService.auditAppIpCfg(entity,isAudit);
|
appCfgService.auditAppIpCfg(entitys,isAudit);
|
||||||
} catch (MaatConvertException e) {
|
} catch (MaatConvertException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
logger.info("app协议IP配置下发失败:"+e.getMessage());
|
logger.info("app协议IP配置下发失败:"+e.getMessage());
|
||||||
addMessage(redirectAttributes, e.getMessage());
|
addMessage(redirectAttributes, e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return "redirect:" + adminPath +"/app/ipCfgList?functionId="+functionId;
|
return "redirect:" + adminPath +"/app/ipCfgList?functionId="+functionId;
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -98,4 +98,5 @@ public interface AppCfgDao {
|
|||||||
//域名关联表操作
|
//域名关联表操作
|
||||||
public List<WebsiteDomainTopic> getDomainDict(WebsiteDomainTopic websiteDomainTopic);
|
public List<WebsiteDomainTopic> getDomainDict(WebsiteDomainTopic websiteDomainTopic);
|
||||||
public void saveDomainDict(WebsiteDomainTopic websiteDomainTopic);
|
public void saveDomainDict(WebsiteDomainTopic websiteDomainTopic);
|
||||||
|
public List<AppIpCfg> getAppIpCfgBySpecServiceId(Integer specServiceId);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -394,7 +394,7 @@
|
|||||||
r.SERVICE_ID,r.REQUEST_ID,r.COMPILE_ID,r.IS_AREA_EFFECTIVE,r.CLASSIFY,
|
r.SERVICE_ID,r.REQUEST_ID,r.COMPILE_ID,r.IS_AREA_EFFECTIVE,r.CLASSIFY,
|
||||||
r.ATTRIBUTE,r.LABLE,AREA_EFFECTIVE_IDS,r.RATELIMIT,r.FUNCTION_ID,r.CFG_TYPE,r.CFG_REGION_CODE,
|
r.ATTRIBUTE,r.LABLE,AREA_EFFECTIVE_IDS,r.RATELIMIT,r.FUNCTION_ID,r.CFG_TYPE,r.CFG_REGION_CODE,
|
||||||
r.IP_TYPE, r.IP_PATTERN, r.SRC_IP_ADDRESS,r.DEST_IP_ADDRESS, r.PORT_PATTERN,r.SRC_PORT,DEST_PORT,
|
r.IP_TYPE, r.IP_PATTERN, r.SRC_IP_ADDRESS,r.DEST_IP_ADDRESS, r.PORT_PATTERN,r.SRC_PORT,DEST_PORT,
|
||||||
r.DIRECTION,r.PROTOCOL,r.DO_LOG
|
r.DIRECTION,r.PROTOCOL,r.DO_LOG,r.USER_REGION1,r.USER_REGION2,r.USER_REGION3,r.USER_REGION4,r.USER_REGION5
|
||||||
</sql>
|
</sql>
|
||||||
|
|
||||||
<sql id="AppHttpCfg_Column" >
|
<sql id="AppHttpCfg_Column" >
|
||||||
@@ -526,6 +526,12 @@
|
|||||||
FROM app_ip_cfg r
|
FROM app_ip_cfg r
|
||||||
WHERE CFG_ID = #{cfgId,jdbcType=BIGINT}
|
WHERE CFG_ID = #{cfgId,jdbcType=BIGINT}
|
||||||
</select>
|
</select>
|
||||||
|
<select id="getAppIpCfgBySpecServiceId" resultMap="AppIpCfgMap" parameterType="java.lang.Integer" >
|
||||||
|
SELECT
|
||||||
|
<include refid="AppIpCfg_Column" />
|
||||||
|
FROM app_ip_cfg r
|
||||||
|
WHERE r.spec_service_id = #{specServiceId,jdbcType=INTEGER} and r.is_valid !=-1 order by r.compile_id desc limit 1
|
||||||
|
</select>
|
||||||
<select id="getAppHttpCfg" resultMap="AppHttpCfgMap" parameterType="java.lang.Long" >
|
<select id="getAppHttpCfg" resultMap="AppHttpCfgMap" parameterType="java.lang.Long" >
|
||||||
SELECT
|
SELECT
|
||||||
<include refid="AppHttpCfg_Column" />
|
<include refid="AppHttpCfg_Column" />
|
||||||
@@ -1694,12 +1700,13 @@
|
|||||||
SERVICE_ID,REQUEST_ID,COMPILE_ID,IS_AREA_EFFECTIVE,CLASSIFY,
|
SERVICE_ID,REQUEST_ID,COMPILE_ID,IS_AREA_EFFECTIVE,CLASSIFY,
|
||||||
ATTRIBUTE,LABLE,AREA_EFFECTIVE_IDS,RATELIMIT,FUNCTION_ID,CFG_TYPE,CFG_REGION_CODE,
|
ATTRIBUTE,LABLE,AREA_EFFECTIVE_IDS,RATELIMIT,FUNCTION_ID,CFG_TYPE,CFG_REGION_CODE,
|
||||||
IP_TYPE, IP_PATTERN, SRC_IP_ADDRESS,DEST_IP_ADDRESS, PORT_PATTERN,SRC_PORT,DEST_PORT,
|
IP_TYPE, IP_PATTERN, SRC_IP_ADDRESS,DEST_IP_ADDRESS, PORT_PATTERN,SRC_PORT,DEST_PORT,
|
||||||
DIRECTION,PROTOCOL,DO_LOG
|
DIRECTION,PROTOCOL,DO_LOG,user_region1,user_region2,user_region3,user_region4,user_region5
|
||||||
)values (
|
)values (
|
||||||
<include refid="AppCommonCfg_Value_List" />,
|
<include refid="AppCommonCfg_Value_List" />,
|
||||||
#{ipType,jdbcType=INTEGER}, #{ipPattern,jdbcType=INTEGER},#{srcIpAddress,jdbcType=VARCHAR},#{destIpAddress,jdbcType=VARCHAR},
|
#{ipType,jdbcType=INTEGER}, #{ipPattern,jdbcType=INTEGER},#{srcIpAddress,jdbcType=VARCHAR},#{destIpAddress,jdbcType=VARCHAR},
|
||||||
#{portPattern,jdbcType=INTEGER},#{srcPort,jdbcType=VARCHAR},#{destPort,jdbcType=VARCHAR},#{direction,jdbcType=INTEGER},
|
#{portPattern,jdbcType=INTEGER},#{srcPort,jdbcType=VARCHAR},#{destPort,jdbcType=VARCHAR},#{direction,jdbcType=INTEGER},
|
||||||
#{protocol,jdbcType=INTEGER},#{doLog,jdbcType=INTEGER}
|
#{protocol,jdbcType=INTEGER},#{doLog,jdbcType=INTEGER},#{userRegion1,jdbcType=VARCHAR},#{userRegion2,jdbcType=VARCHAR}
|
||||||
|
,#{userRegion3,jdbcType=VARCHAR},#{userRegion4,jdbcType=VARCHAR},#{userRegion5,jdbcType=VARCHAR}
|
||||||
)
|
)
|
||||||
</insert>
|
</insert>
|
||||||
<insert id="insertAppHttpCfg" parameterType="com.nis.domain.configuration.AppHttpCfg" >
|
<insert id="insertAppHttpCfg" parameterType="com.nis.domain.configuration.AppHttpCfg" >
|
||||||
|
|||||||
@@ -32,6 +32,7 @@ import com.nis.domain.basics.AsnIpCfg;
|
|||||||
import com.nis.domain.callback.InlineIp;
|
import com.nis.domain.callback.InlineIp;
|
||||||
import com.nis.domain.callback.NtcDnsResStrategy;
|
import com.nis.domain.callback.NtcDnsResStrategy;
|
||||||
import com.nis.domain.callback.ProxyObjKeyring;
|
import com.nis.domain.callback.ProxyObjKeyring;
|
||||||
|
import com.nis.domain.configuration.AppIpCfg;
|
||||||
import com.nis.domain.configuration.AreaBean;
|
import com.nis.domain.configuration.AreaBean;
|
||||||
import com.nis.domain.configuration.AreaIpCfg;
|
import com.nis.domain.configuration.AreaIpCfg;
|
||||||
import com.nis.domain.configuration.BaseCfg;
|
import com.nis.domain.configuration.BaseCfg;
|
||||||
@@ -738,16 +739,25 @@ public abstract class BaseService {
|
|||||||
return replaceContent;
|
return replaceContent;
|
||||||
}
|
}
|
||||||
//asn IP 复用转换
|
//asn IP 复用转换
|
||||||
public List<IpCfg> groupReuseCfgAddRemoveConvert(List<AsnIpCfg> ipCfgList,Integer isValid) {
|
public List<IpCfg> groupReuseCfgAddRemoveConvert(List<? extends BaseCfg<?>> ipCfgList,Integer isValid,Integer groupId) {
|
||||||
Date opTime=new Date();
|
Date opTime=new Date();
|
||||||
List<IpCfg> maatIpList=new ArrayList<>();
|
List<IpCfg> maatIpList=new ArrayList<>();
|
||||||
for(AsnIpCfg asnIpCfg:ipCfgList) {
|
for(BaseCfg<?> _cfg:ipCfgList) {
|
||||||
BaseIpCfg baseIpCfg = new BaseIpCfg();
|
|
||||||
BeanUtils.copyProperties(asnIpCfg, baseIpCfg);
|
|
||||||
IpCfg cfg = new IpCfg();
|
IpCfg cfg = new IpCfg();
|
||||||
BeanUtils.copyProperties(baseIpCfg, cfg);
|
BaseIpCfg baseIpCfg = new BaseIpCfg();
|
||||||
cfg.setGroupId(asnIpCfg.getAsnIpGroup());
|
if(_cfg instanceof AsnIpCfg) {
|
||||||
cfg.setRegionId(asnIpCfg.getRegionId());
|
AsnIpCfg asnIpCfg=(AsnIpCfg)_cfg;
|
||||||
|
BeanUtils.copyProperties(asnIpCfg, baseIpCfg);
|
||||||
|
BeanUtils.copyProperties(baseIpCfg, cfg);
|
||||||
|
cfg.setGroupId(asnIpCfg.getAsnIpGroup());
|
||||||
|
cfg.setRegionId(asnIpCfg.getRegionId());
|
||||||
|
}else if(_cfg instanceof AppIpCfg) {
|
||||||
|
AppIpCfg appIpCfg=(AppIpCfg)_cfg;
|
||||||
|
BeanUtils.copyProperties(appIpCfg, baseIpCfg);
|
||||||
|
BeanUtils.copyProperties(baseIpCfg, cfg);
|
||||||
|
cfg.setGroupId(groupId);
|
||||||
|
cfg.setRegionId(Integer.parseInt(appIpCfg.getUserRegion1()));
|
||||||
|
}
|
||||||
cfg.setIsValid(isValid);
|
cfg.setIsValid(isValid);
|
||||||
cfg = ipConvert(cfg,baseIpCfg);
|
cfg = ipConvert(cfg,baseIpCfg);
|
||||||
cfg.setAuditTime(opTime);
|
cfg.setAuditTime(opTime);
|
||||||
|
|||||||
@@ -91,7 +91,7 @@ public class AsnIpCfgService extends CrudService<CrudDao<AsnIpCfg>, AsnIpCfg> {
|
|||||||
GroupReuseAddBean maatBean = new GroupReuseAddBean();
|
GroupReuseAddBean maatBean = new GroupReuseAddBean();
|
||||||
List<GroupReuseCfg> groupReuseList=new ArrayList<>();
|
List<GroupReuseCfg> groupReuseList=new ArrayList<>();
|
||||||
GroupReuseCfg groupReuseCfg=new GroupReuseCfg();
|
GroupReuseCfg groupReuseCfg=new GroupReuseCfg();
|
||||||
List<IpCfg> ipRegionList = groupReuseCfgAddRemoveConvert(entity.getAsnIpCfgs(),Constants.VALID_YES);
|
List<IpCfg> ipRegionList = groupReuseCfgAddRemoveConvert(entity.getAsnIpCfgs(),Constants.VALID_YES,null);
|
||||||
List<StringCfg> strRegionList = new ArrayList<>();
|
List<StringCfg> strRegionList = new ArrayList<>();
|
||||||
List<NumBoundaryCfg> numRegionList = new ArrayList<>();
|
List<NumBoundaryCfg> numRegionList = new ArrayList<>();
|
||||||
groupReuseCfg.setIpRegionList(ipRegionList);
|
groupReuseCfg.setIpRegionList(ipRegionList);
|
||||||
@@ -146,7 +146,7 @@ public class AsnIpCfgService extends CrudService<CrudDao<AsnIpCfg>, AsnIpCfg> {
|
|||||||
GroupReuseAddBean maatBean = new GroupReuseAddBean();
|
GroupReuseAddBean maatBean = new GroupReuseAddBean();
|
||||||
List<GroupReuseCfg> groupReuseList=new ArrayList<>();
|
List<GroupReuseCfg> groupReuseList=new ArrayList<>();
|
||||||
GroupReuseCfg groupReuseCfg=new GroupReuseCfg();
|
GroupReuseCfg groupReuseCfg=new GroupReuseCfg();
|
||||||
List<IpCfg> ipRegionList = groupReuseCfgAddRemoveConvert(issuedList,Constants.VALID_NO);
|
List<IpCfg> ipRegionList = groupReuseCfgAddRemoveConvert(issuedList,Constants.VALID_NO,null);
|
||||||
List<StringCfg> strRegionList = new ArrayList<>();
|
List<StringCfg> strRegionList = new ArrayList<>();
|
||||||
List<NumBoundaryCfg> numRegionList = new ArrayList<>();
|
List<NumBoundaryCfg> numRegionList = new ArrayList<>();
|
||||||
groupReuseCfg.setIpRegionList(ipRegionList);
|
groupReuseCfg.setIpRegionList(ipRegionList);
|
||||||
|
|||||||
@@ -5,6 +5,9 @@ import java.util.Date;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.ibatis.session.ExecutorType;
|
||||||
|
import org.apache.ibatis.session.SqlSession;
|
||||||
|
import org.apache.ibatis.session.SqlSessionFactory;
|
||||||
import org.springframework.beans.BeanUtils;
|
import org.springframework.beans.BeanUtils;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
@@ -24,6 +27,8 @@ import com.nis.domain.configuration.AreaIpCfg;
|
|||||||
import com.nis.domain.configuration.IpPortCfg;
|
import com.nis.domain.configuration.IpPortCfg;
|
||||||
import com.nis.domain.configuration.NtcSubscribeIdCfg;
|
import com.nis.domain.configuration.NtcSubscribeIdCfg;
|
||||||
import com.nis.domain.configuration.WebsiteDomainTopic;
|
import com.nis.domain.configuration.WebsiteDomainTopic;
|
||||||
|
import com.nis.domain.maat.GroupReuseAddBean;
|
||||||
|
import com.nis.domain.maat.GroupReuseCfg;
|
||||||
import com.nis.domain.maat.MaatCfg;
|
import com.nis.domain.maat.MaatCfg;
|
||||||
import com.nis.domain.maat.MaatCfg.DigestCfg;
|
import com.nis.domain.maat.MaatCfg.DigestCfg;
|
||||||
import com.nis.domain.maat.MaatCfg.GroupCfg;
|
import com.nis.domain.maat.MaatCfg.GroupCfg;
|
||||||
@@ -32,6 +37,8 @@ import com.nis.domain.maat.MaatCfg.NumBoundaryCfg;
|
|||||||
import com.nis.domain.maat.MaatCfg.StringCfg;
|
import com.nis.domain.maat.MaatCfg.StringCfg;
|
||||||
import com.nis.domain.maat.ToMaatBean;
|
import com.nis.domain.maat.ToMaatBean;
|
||||||
import com.nis.domain.maat.ToMaatResult;
|
import com.nis.domain.maat.ToMaatResult;
|
||||||
|
import com.nis.domain.specific.ConfigGroupInfo;
|
||||||
|
import com.nis.domain.specific.SpecificServiceCfg;
|
||||||
import com.nis.exceptions.MaatConvertException;
|
import com.nis.exceptions.MaatConvertException;
|
||||||
import com.nis.util.ConfigServiceUtil;
|
import com.nis.util.ConfigServiceUtil;
|
||||||
import com.nis.util.Constants;
|
import com.nis.util.Constants;
|
||||||
@@ -41,8 +48,10 @@ import com.nis.util.StringUtils;
|
|||||||
import com.nis.web.dao.configuration.AppCfgDao;
|
import com.nis.web.dao.configuration.AppCfgDao;
|
||||||
import com.nis.web.dao.configuration.AreaIpCfgDao;
|
import com.nis.web.dao.configuration.AreaIpCfgDao;
|
||||||
import com.nis.web.dao.configuration.StringCfgDao;
|
import com.nis.web.dao.configuration.StringCfgDao;
|
||||||
|
import com.nis.web.dao.specific.SpecificServiceCfgDao;
|
||||||
import com.nis.web.security.UserUtils;
|
import com.nis.web.security.UserUtils;
|
||||||
import com.nis.web.service.BaseService;
|
import com.nis.web.service.BaseService;
|
||||||
|
import com.nis.web.service.SpringContextHolder;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 特定协议相关配置事务类
|
* 特定协议相关配置事务类
|
||||||
@@ -58,6 +67,8 @@ public class AppCfgService extends BaseService {
|
|||||||
protected AreaIpCfgDao areaIpCfgDao;
|
protected AreaIpCfgDao areaIpCfgDao;
|
||||||
@Autowired
|
@Autowired
|
||||||
protected StringCfgDao stringcfgDao;
|
protected StringCfgDao stringcfgDao;
|
||||||
|
@Autowired
|
||||||
|
protected SpecificServiceCfgDao specificServiceCfgDao;
|
||||||
|
|
||||||
public Page<AppPolicyCfg> findAppPolicyList(Page<AppPolicyCfg> page, AppPolicyCfg entity) {
|
public Page<AppPolicyCfg> findAppPolicyList(Page<AppPolicyCfg> page, AppPolicyCfg entity) {
|
||||||
entity.getSqlMap().put("dsf", configScopeFilter(entity.getCurrentUser(), "r"));
|
entity.getSqlMap().put("dsf", configScopeFilter(entity.getCurrentUser(), "r"));
|
||||||
@@ -289,34 +300,66 @@ public class AppCfgService extends BaseService {
|
|||||||
setAreaEffectiveIds(entity);
|
setAreaEffectiveIds(entity);
|
||||||
|
|
||||||
if (entity.getCfgId() == null) {
|
if (entity.getCfgId() == null) {
|
||||||
|
|
||||||
|
SpecificServiceCfg specificServiceCfg=specificServiceCfgDao.getBySpecServiceId(entity.getSpecServiceId());
|
||||||
|
ConfigGroupInfo configGroupInfo=specificServiceCfgDao.getConfigGroupInfoByGroupId(specificServiceCfg.getGroupId());
|
||||||
|
if(configGroupInfo==null) {//一般特定服务的组号是新增之后就有的,不会进入这一步。
|
||||||
|
Integer groupId = ConfigServiceUtil.getId(2, 1).get(0);
|
||||||
|
specificServiceCfg.setGroupId(groupId);
|
||||||
|
configGroupInfo = new ConfigGroupInfo();
|
||||||
|
configGroupInfo.setGroupId(specificServiceCfg.getGroupId());
|
||||||
|
configGroupInfo.setGroupName(specificServiceCfg.getSpecServiceName());
|
||||||
|
configGroupInfo.setIsIssued(0);
|
||||||
|
configGroupInfo.setGroupType(1);
|
||||||
|
specificServiceCfgDao.insertConfigGroupInfo(configGroupInfo);
|
||||||
|
//更新group_id
|
||||||
|
specificServiceCfg.setOpTime(new Date());
|
||||||
|
specificServiceCfgDao.update(specificServiceCfg);
|
||||||
|
}
|
||||||
Integer compileId = 0;
|
Integer compileId = 0;
|
||||||
try {
|
if(configGroupInfo.getIsIssued().intValue()==0) {//没有下发过
|
||||||
List<Integer> idList = ConfigServiceUtil.getId(1, 1);
|
//查询AppIpCfg对应 的未下发IP的编译ID
|
||||||
if (idList != null && idList.size() > 0) {
|
List<AppIpCfg> beforeCfg=appCfgDao.getAppIpCfgBySpecServiceId(entity.getSpecServiceId());
|
||||||
compileId = idList.get(0);
|
if(beforeCfg==null||beforeCfg.size()==0) {//第一条,获取编译id
|
||||||
}
|
try {
|
||||||
entity.setCompileId(compileId);
|
List<Integer> idList = ConfigServiceUtil.getId(1, 1);
|
||||||
entity.setCreateTime(new Date());
|
if (idList != null && idList.size() > 0) {
|
||||||
entity.setCreatorId(entity.getCurrentUser().getId());
|
compileId = idList.get(0);
|
||||||
entity.setIsValid(0);
|
}
|
||||||
entity.setIsAudit(0);
|
} catch (Exception e) {
|
||||||
appCfgDao.insertAppIpCfg(entity);
|
e.printStackTrace();
|
||||||
|
logger.info("获取编译ID出错");
|
||||||
// 保存区域IP信息
|
throw new MaatConvertException(e.getMessage());
|
||||||
if (entity.getAreaCfg() != null) {
|
|
||||||
for (AreaIpCfg cfg : entity.getAreaCfg()) {
|
|
||||||
cfg.initDefaultValue();
|
|
||||||
BeanUtils.copyProperties(entity, cfg,
|
|
||||||
new String[] { "cfgRegionCode", "cfgType", "ipType", "isAreaEffective",
|
|
||||||
"areaEffectiveIds", "protocol", "portPattern", "srcPort", "destPort",
|
|
||||||
"direction", "destIpAddress", "srcIpAddress", "ipPattern" });
|
|
||||||
areaIpCfgDao.saveAreaIpCfg(cfg);
|
|
||||||
}
|
}
|
||||||
|
}else {
|
||||||
|
compileId=beforeCfg.get(0).getCompileId();
|
||||||
|
}
|
||||||
|
}else if(configGroupInfo.getIsIssued().intValue()==1){//下发过了
|
||||||
|
List<AppIpCfg> beforeCfg=appCfgDao.getAppIpCfgBySpecServiceId(entity.getSpecServiceId());
|
||||||
|
if(beforeCfg==null||beforeCfg.size()==0) {
|
||||||
|
throw new RuntimeException("Can't get compileId, there is not app ip in an issued group");
|
||||||
|
}
|
||||||
|
compileId=beforeCfg.get(0).getCompileId();
|
||||||
|
}else {
|
||||||
|
throw new RuntimeException("Unknown configGroupInfo isIssued value");
|
||||||
|
}
|
||||||
|
entity.setUserRegion1(String.valueOf(ConfigServiceUtil.getId(3, 1).get(0)));
|
||||||
|
entity.setCompileId(compileId);
|
||||||
|
entity.setCreateTime(new Date());
|
||||||
|
entity.setCreatorId(entity.getCurrentUser().getId());
|
||||||
|
entity.setIsValid(0);
|
||||||
|
entity.setIsAudit(0);
|
||||||
|
appCfgDao.insertAppIpCfg(entity);
|
||||||
|
// 保存区域IP信息
|
||||||
|
if (entity.getAreaCfg() != null) {
|
||||||
|
for (AreaIpCfg cfg : entity.getAreaCfg()) {
|
||||||
|
cfg.initDefaultValue();
|
||||||
|
BeanUtils.copyProperties(entity, cfg,
|
||||||
|
new String[] { "cfgRegionCode", "cfgType", "ipType", "isAreaEffective",
|
||||||
|
"areaEffectiveIds", "protocol", "portPattern", "srcPort", "destPort",
|
||||||
|
"direction", "destIpAddress", "srcIpAddress", "ipPattern" });
|
||||||
|
areaIpCfgDao.saveAreaIpCfg(cfg);
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
logger.info("获取编译ID出错");
|
|
||||||
throw new MaatConvertException(e.getMessage());
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
entity.setEditorId(entity.getCurrentUser().getId());
|
entity.setEditorId(entity.getCurrentUser().getId());
|
||||||
@@ -1003,6 +1046,157 @@ public class AppCfgService extends BaseService {
|
|||||||
logger.info("app协议IP配置取消配置响应信息:" + result.getMsg());
|
logger.info("app协议IP配置取消配置响应信息:" + result.getMsg());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
|
* ip复用批量审核
|
||||||
|
* @param data
|
||||||
|
*/
|
||||||
|
public void auditAppIpCfg(List<AppIpCfg> data) {
|
||||||
|
SqlSessionFactory sqlSessionFactory=SpringContextHolder.getBean(SqlSessionFactory.class);
|
||||||
|
SqlSession batchSqlSession = null;
|
||||||
|
try{
|
||||||
|
batchSqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH, false);
|
||||||
|
for(int index = 0; index < data.size();index++){
|
||||||
|
AppIpCfg t = data.get(index);
|
||||||
|
((AppCfgDao) batchSqlSession.getMapper(AppCfgDao.class)).auditCfg(t);
|
||||||
|
}
|
||||||
|
batchSqlSession.commit();
|
||||||
|
}finally {
|
||||||
|
if(batchSqlSession != null){
|
||||||
|
batchSqlSession.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void auditAppIpCfg(List<AppIpCfg> entitys, Integer isAudit) {
|
||||||
|
MaatCfg maatCfg = new MaatCfg();
|
||||||
|
List<MaatCfg> configCompileList = new ArrayList();
|
||||||
|
List<GroupCfg> groupRelationList = new ArrayList();
|
||||||
|
List<IpCfg> ipRegionList = new ArrayList();
|
||||||
|
List<StringCfg> strRegionList = new ArrayList();
|
||||||
|
List<NumBoundaryCfg> numRegionList = new ArrayList();
|
||||||
|
List<DigestCfg> digestRegionList = new ArrayList();
|
||||||
|
List<IpCfg> areaIpRegionList = new ArrayList();
|
||||||
|
this.auditAppIpCfg(entitys);
|
||||||
|
// for(AppIpCfg entity:entitys) {
|
||||||
|
// // 保存区域IP信息
|
||||||
|
// List<AreaIpCfg> areaIpCfgList = areaIpCfgDao.getByCompileId(entitys.get(0).getCompileId());
|
||||||
|
// if (!StringUtil.isEmpty(areaIpCfgList)) {
|
||||||
|
// AreaIpCfg cfg = new AreaIpCfg();
|
||||||
|
// BeanUtils.copyProperties(entity, cfg, new String[] { "cfgId" });
|
||||||
|
// cfg.setTableName(AreaIpCfg.getTablename());
|
||||||
|
// appCfgDao.auditCfg(cfg);
|
||||||
|
// if (isAudit == 1) {
|
||||||
|
// Map<String, List> map = cfgConvert(areaIpRegionList, areaIpCfgList, 1, entity, groupRelationList);
|
||||||
|
// groupRelationList = map.get("groupList");
|
||||||
|
// areaIpRegionList = map.get("dstList");
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
Integer specServiceId= entitys.get(0).getSpecServiceId();
|
||||||
|
SpecificServiceCfg specificServiceCfg=specificServiceCfgDao.getBySpecServiceId(specServiceId);
|
||||||
|
//String businessType=specificServiceCfg.getBusinessType();
|
||||||
|
ConfigGroupInfo configGroupInfo=specificServiceCfgDao.getConfigGroupInfoByGroupId(specificServiceCfg.getGroupId());
|
||||||
|
if(configGroupInfo==null) {
|
||||||
|
Integer groupId = ConfigServiceUtil.getId(2, 1).get(0);
|
||||||
|
specificServiceCfg.setGroupId(groupId);
|
||||||
|
configGroupInfo = new ConfigGroupInfo();
|
||||||
|
configGroupInfo.setGroupId(specificServiceCfg.getGroupId());
|
||||||
|
configGroupInfo.setGroupName(specificServiceCfg.getSpecServiceName());
|
||||||
|
configGroupInfo.setIsIssued(0);
|
||||||
|
configGroupInfo.setGroupType(1);
|
||||||
|
specificServiceCfgDao.insertConfigGroupInfo(configGroupInfo);
|
||||||
|
//更新group_id
|
||||||
|
specificServiceCfg.setOpTime(new Date());
|
||||||
|
specificServiceCfgDao.update(specificServiceCfg);
|
||||||
|
}
|
||||||
|
Integer groupId=configGroupInfo.getGroupId();
|
||||||
|
// 构造提交综合服务参数格式,一条配置提交一次综合服务
|
||||||
|
if (isAudit == 1) {
|
||||||
|
if(configGroupInfo.getIsIssued()==0) {//未下发,下发region compile,group.
|
||||||
|
ToMaatBean maatBean = new ToMaatBean();
|
||||||
|
maatCfg.initDefaultValue();
|
||||||
|
//group
|
||||||
|
GroupCfg groupCfg=new GroupCfg();
|
||||||
|
groupCfg.setCompileId(entitys.get(0).getCompileId());
|
||||||
|
groupCfg.setGroupId(groupId);
|
||||||
|
groupCfg.setIsValid(Constants.VALID_YES);
|
||||||
|
groupCfg.setAuditTime(entitys.get(0).getAuditTime());
|
||||||
|
groupRelationList.add(groupCfg);
|
||||||
|
BeanUtils.copyProperties(entitys.get(0), maatCfg);
|
||||||
|
ipRegionList.addAll(groupReuseCfgAddRemoveConvert(entitys,Constants.VALID_YES,groupId));
|
||||||
|
maatCfg.setAction(entitys.get(0).getAction());
|
||||||
|
maatCfg.setAuditTime(entitys.get(0).getAuditTime());
|
||||||
|
maatCfg.setIpRegionList(ipRegionList);
|
||||||
|
maatCfg.setStrRegionList(strRegionList);
|
||||||
|
maatCfg.setNumRegionList(numRegionList);
|
||||||
|
maatCfg.setDigestRegionList(digestRegionList);
|
||||||
|
maatCfg.setGroupRelationList(groupRelationList);
|
||||||
|
maatCfg.setGroupNum(groupRelationList.size());
|
||||||
|
maatCfg.setAreaIpRegionList(areaIpRegionList);
|
||||||
|
maatCfg.setIsValid(entitys.get(0).getIsValid());
|
||||||
|
// 设置APP自定义域
|
||||||
|
String userRegion = "APP_ID=" + entitys.get(0).getAppCode()/*+Constants.USER_REGION_SPLIT+"ASEV_ID="+businessType*/;
|
||||||
|
maatCfg.setUserRegion(userRegion);
|
||||||
|
configCompileList.add(maatCfg);
|
||||||
|
maatBean.setConfigCompileList(configCompileList);
|
||||||
|
maatBean.setAuditTime(entitys.get(0).getAuditTime());
|
||||||
|
maatBean.setCreatorName(entitys.get(0).getCurrentUser().getName());
|
||||||
|
maatBean.setVersion(Constants.MAAT_VERSION);
|
||||||
|
maatBean.setOpAction(Constants.INSERT_ACTION);
|
||||||
|
// 调用服务接口下发配置数据
|
||||||
|
String json = gsonToJson(maatBean);
|
||||||
|
logger.info("app协议IP配置下发配置参数:" + json);
|
||||||
|
// 调用服务接口下发配置
|
||||||
|
ToMaatResult result = ConfigServiceUtil.postMaatCfg(json);
|
||||||
|
logger.info("app协议IP配置下发响应信息:" + result.getMsg());
|
||||||
|
configGroupInfo.setIsIssued(1);
|
||||||
|
configGroupInfo.setUpdateTime(new Date());
|
||||||
|
specificServiceCfgDao.updateConfigGroupInfobyGroupId(configGroupInfo);
|
||||||
|
}else if(configGroupInfo.getIsIssued()==1) {//已经下发,分组复用下发
|
||||||
|
GroupReuseAddBean maatBean = new GroupReuseAddBean();
|
||||||
|
List<GroupReuseCfg> groupReuseList=new ArrayList<>();
|
||||||
|
GroupReuseCfg groupReuseCfg=new GroupReuseCfg();
|
||||||
|
ipRegionList.addAll(groupReuseCfgAddRemoveConvert(entitys,Constants.VALID_YES,groupId));
|
||||||
|
groupReuseCfg.setIpRegionList(ipRegionList);
|
||||||
|
groupReuseCfg.setStrRegionList(strRegionList);
|
||||||
|
groupReuseCfg.setNumRegionList(numRegionList);
|
||||||
|
groupReuseList.add(groupReuseCfg);
|
||||||
|
maatBean.setGroupReuseCfgList(groupReuseList);
|
||||||
|
maatBean.setAuditTime(entitys.get(0).getAuditTime());
|
||||||
|
maatBean.setCreatorName(entitys.get(0).getCurrentUser().getName());
|
||||||
|
maatBean.setVersion(Constants.MAAT_VERSION);
|
||||||
|
maatBean.setOpAction(Constants.INSERT_ACTION);
|
||||||
|
//调用服务接口下发配置数据
|
||||||
|
String json=gsonToJson(maatBean);
|
||||||
|
logger.info("app协议IP域新增配置下发配置参数:"+json);
|
||||||
|
//调用服务接口下发配置
|
||||||
|
ToMaatResult result = ConfigServiceUtil.postGroupReuseSources(json);
|
||||||
|
logger.info("app协议IP域新增配置响应信息:"+result.getMsg());
|
||||||
|
}else {
|
||||||
|
throw new RuntimeException("Unknown configGroupInfo isIssued value");
|
||||||
|
}
|
||||||
|
} else if (isAudit == 3) {
|
||||||
|
//已经下发过的,调用分组复用配置删除接口
|
||||||
|
GroupReuseAddBean maatBean = new GroupReuseAddBean();
|
||||||
|
List<GroupReuseCfg> groupReuseList=new ArrayList<>();
|
||||||
|
GroupReuseCfg groupReuseCfg=new GroupReuseCfg();
|
||||||
|
ipRegionList.addAll(groupReuseCfgAddRemoveConvert(entitys,Constants.VALID_NO,groupId));
|
||||||
|
groupReuseCfg.setIpRegionList(ipRegionList);
|
||||||
|
groupReuseCfg.setStrRegionList(strRegionList);
|
||||||
|
groupReuseCfg.setNumRegionList(numRegionList);
|
||||||
|
groupReuseList.add(groupReuseCfg);
|
||||||
|
maatBean.setGroupReuseCfgList(groupReuseList);
|
||||||
|
maatBean.setAuditTime(entitys.get(0).getAuditTime());
|
||||||
|
maatBean.setCreatorName(entitys.get(0).getCurrentUser().getName());
|
||||||
|
maatBean.setVersion(Constants.MAAT_VERSION);
|
||||||
|
maatBean.setOpAction(Constants.UPDATE_ACTION);
|
||||||
|
//调用服务接口下发配置数据
|
||||||
|
String json=gsonToJson(maatBean);
|
||||||
|
logger.info("app协议IP域删除配置下发配置参数:"+json);
|
||||||
|
//调用服务接口下发配置
|
||||||
|
ToMaatResult result = ConfigServiceUtil.put(json,3);
|
||||||
|
logger.info("app协议IP域删除配置响应信息:"+result.getMsg());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void auditAppHttpCfg(AppHttpCfg entity, Integer isAudit) {
|
public void auditAppHttpCfg(AppHttpCfg entity, Integer isAudit) {
|
||||||
ToMaatBean maatBean = new ToMaatBean();
|
ToMaatBean maatBean = new ToMaatBean();
|
||||||
|
|||||||
@@ -171,7 +171,7 @@ public class AsnPolicyCfgService extends BaseService {
|
|||||||
AsnIpCfg asnIpCfg=new AsnIpCfg();
|
AsnIpCfg asnIpCfg=new AsnIpCfg();
|
||||||
asnIpCfg.setAsnIpGroup(Integer.parseInt(entity.getUserRegion1()));
|
asnIpCfg.setAsnIpGroup(Integer.parseInt(entity.getUserRegion1()));
|
||||||
List<AsnIpCfg> allAsnIpCfgs=asnIpCfgDao.findAllList(asnIpCfg);
|
List<AsnIpCfg> allAsnIpCfgs=asnIpCfgDao.findAllList(asnIpCfg);
|
||||||
ipRegionList.addAll(groupReuseCfgAddRemoveConvert(allAsnIpCfgs,Constants.VALID_YES));
|
ipRegionList.addAll(groupReuseCfgAddRemoveConvert(allAsnIpCfgs,Constants.VALID_YES,null));
|
||||||
maatCfg.setIpRegionList(ipRegionList);
|
maatCfg.setIpRegionList(ipRegionList);
|
||||||
configCompileList.add(maatCfg);
|
configCompileList.add(maatCfg);
|
||||||
maatBean.setConfigCompileList(configCompileList);
|
maatBean.setConfigCompileList(configCompileList);
|
||||||
|
|||||||
@@ -2,9 +2,10 @@
|
|||||||
<%@ include file="/WEB-INF/include/taglib.jsp"%>
|
<%@ include file="/WEB-INF/include/taglib.jsp"%>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title><spring:message code="${cfgName}"></spring:message></title>
|
<title><spring:message code="app_ip_config"></spring:message></title>
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
$(function(){
|
$(function(){
|
||||||
|
$("select[name='direction']").parents(".form-group").addClass("hidden");
|
||||||
//initCommIpVal();
|
//initCommIpVal();
|
||||||
$(".action").on("change", function() {
|
$(".action").on("change", function() {
|
||||||
$("#serviceId").val($(this).attr("serviceId"));
|
$("#serviceId").val($(this).attr("serviceId"));
|
||||||
@@ -100,7 +101,7 @@ $(function(){
|
|||||||
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="ip_type"/></label>
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="ip_type"/></label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<select name="ipType" class="selectpicker show-tick form-control required">
|
<select name="ipType" class="selectpicker show-tick form-control required">
|
||||||
<c:forEach items="${fns:getDictList('SPEC_IP_TYPE')}" var="ipTypeC">
|
<c:forEach items="${fns:getDictList('IP_TYPE')}" var="ipTypeC">
|
||||||
<option value="${ipTypeC.itemCode}"
|
<option value="${ipTypeC.itemCode}"
|
||||||
<c:if test="${_cfg.ipType==ipTypeC.itemCode
|
<c:if test="${_cfg.ipType==ipTypeC.itemCode
|
||||||
|| (_cfg.ipType==null && ipTypeC.itemCode==4)}">
|
|| (_cfg.ipType==null && ipTypeC.itemCode==4)}">
|
||||||
@@ -130,17 +131,7 @@ $(function(){
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<div class="form-group ">
|
|
||||||
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="server_ip"/></label>
|
|
||||||
<div class="col-md-6">
|
|
||||||
<input class="form-control required ipCheck" type="text" name="destIpAddress" value="${_cfg.destIpAddress}">
|
|
||||||
<input class="required" type="hidden" name="srcIpAddress" value="${_cfg.srcIpAddress}">
|
|
||||||
</div>
|
|
||||||
<div for="destIpAddress"></div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="col-md-6">
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="port_pattern"/></label>
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="port_pattern"/></label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
@@ -155,17 +146,47 @@ $(function(){
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="form-group ">
|
||||||
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="client_ip"/></label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<input class="form-control required ipCheck" type="text" name="srcIpAddress" value="${_cfg.srcIpAddress}">
|
||||||
|
</div>
|
||||||
|
<div for="srcIpAddress"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<div class="form-group ">
|
<div class="form-group ">
|
||||||
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="client_port"/></label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<input class="form-control required portCheck" type="text" name="srcPort" value="${_cfg.srcPort}">
|
||||||
|
</div>
|
||||||
|
<div for="srcPort"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="form-group ">
|
||||||
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="server_ip"/></label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<input class="form-control required ipCheck" type="text" name="destIpAddress" value="${_cfg.destIpAddress}">
|
||||||
|
</div>
|
||||||
|
<div for="destIpAddress"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="form-group ">
|
||||||
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="server_port"/></label>
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="server_port"/></label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
<input class="form-control required portCheck" type="text" name="destPort" value="${_cfg.destPort}">
|
<input class="form-control required portCheck" type="text" name="destPort" value="${_cfg.destPort}">
|
||||||
<input type="hidden" class="portCheck" name="srcPort" value="${_cfg.srcPort}">
|
|
||||||
</div>
|
</div>
|
||||||
<div for="destPort"></div>
|
<div for="destPort"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-6">
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-6">
|
||||||
<div class="form-group ">
|
<div class="form-group ">
|
||||||
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="protocol"/></label>
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="protocol"/></label>
|
||||||
<div class="col-md-6">
|
<div class="col-md-6">
|
||||||
@@ -178,6 +199,19 @@ $(function(){
|
|||||||
</div>
|
</div>
|
||||||
<div for="protocol"></div>
|
<div for="protocol"></div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="form-group ">
|
||||||
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="direction"/></label>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<select name="direction" class="selectpicker show-tick form-control required">
|
||||||
|
<c:forEach items="${fns:getDictList('DIRECTION')}" var="directionC">
|
||||||
|
<option value="${directionC.itemCode}" <c:if test="${_cfg.direction==directionC.itemCode || (_cfg.direction==null && directionC.itemCode==0)}">selected</c:if>><spring:message code="${directionC.itemValue}"/></option>
|
||||||
|
</c:forEach>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div for="direction"></div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user