拆分为源端口Pattern,目的端口Pattern (2)show more修改,并移动刀ipRegion.js中 (3)IP复用未作修改 (4)删除部分废弃的导入模板以及废弃的导入方法
448 lines
22 KiB
Plaintext
448 lines
22 KiB
Plaintext
<%@ page contentType="text/html;charset=UTF-8"%>
|
|
<%@ include file="/WEB-INF/include/taglib.jsp"%>
|
|
<html>
|
|
<head>
|
|
<title><spring:message code="asn_ip_configuration"></spring:message></title>
|
|
<script type="text/javascript">
|
|
var defaultIpInfo;
|
|
$(function(){
|
|
//$("input[name$='destPort']").parents(".form-group").addClass("hidden");
|
|
//$("select[name$='portPattern']").parents(".form-group").addClass("hidden");
|
|
$("select[name$='protocol']").parents(".form-group").addClass("hidden");
|
|
$("select[name$='direction']").parents(".form-group").addClass("hidden");
|
|
defaultIpInfo=$(".ipInfo").clone();
|
|
$(".asnIpAdd").click();
|
|
$("#cfgFrom").validate({
|
|
errorPlacement: function(error,element){
|
|
$(element).parents(".form-group").find("div[for='"+element.attr("name")+"']").append(error);
|
|
},
|
|
submitHandler: function(form){
|
|
/* $("[name='country']").val($("[name='userRegion1'] option:selected").attr("country"));
|
|
$("[name='detail']").val($("[name='userRegion1'] option:selected").attr("detail"));
|
|
$("[name='asnIpGroup']").val($("[name='userRegion1'] option:selected").attr("asnIpGroup")); */
|
|
loading('onloading...');
|
|
form.submit();
|
|
},
|
|
errorContainer: "#messageBox",
|
|
});
|
|
/* $("#asnId").val($("select[name='asnIpGroup'] option:selected").attr("asnId"));
|
|
$("select[name='asnIpGroup']").on("change",function(){
|
|
var asnId=$(this).find("option[value='"+$(this).val()+"']").attr("asnId");
|
|
$("#asnId").val(asnId);
|
|
}); */
|
|
/* var organization=$("[name='organization']").val();
|
|
if(organization){
|
|
$.ajax({
|
|
type:'post',
|
|
url:'${ctx}/basics/asn/ajaxGetGroups',
|
|
data:{"org":organization},
|
|
async:false,
|
|
success:function(data,textStatus){//处理返回结果
|
|
if(data){
|
|
var html='';
|
|
for(var i in data){
|
|
html+="<option value='"+data[i].asnId+"' country='"+data[i].country+"' detail='"+data[i].detail+"' asnIpGroup='"+data[i].groupId+"' >"
|
|
+data[i].country+" AS"+data[i].asnId+" "+data[i].detail+"</option>"
|
|
}
|
|
$("[name='userRegion1']").empty().append(html);
|
|
$("[name='userRegion1']").selectpicker("refresh");
|
|
}
|
|
}
|
|
});
|
|
}
|
|
$("[name='organization']").on("change",function(){
|
|
$.ajax({
|
|
type:'post',
|
|
url:'${ctx}/basics/asn/ajaxGetGroups',
|
|
data:{"org":$(this).val()},
|
|
async:false,
|
|
success:function(data,textStatus){//处理返回结果
|
|
if(data){
|
|
var html='';
|
|
for(var i in data){
|
|
html+="<option value='"+data[i].asnId+"' country='"+data[i].country+"' detail='"+data[i].detail+"' asnIpGroup='"+data[i].groupId+"' >"
|
|
+data[i].country+" AS"+data[i].asnId+" "+data[i].detail+"</option>"
|
|
}
|
|
$("[name='userRegion1']").empty().append(html);
|
|
$("[name='userRegion1']").selectpicker("refresh");
|
|
|
|
}
|
|
}
|
|
});
|
|
}); */
|
|
});
|
|
//业务窗口打开
|
|
var addContent = function(obj, contentClassName) {
|
|
var showDiv = $(obj).parent().parent().siblings("."+contentClassName).last();
|
|
if(showDiv.hasClass("hidden")){
|
|
$(showDiv).removeClass("hidden").removeClass(
|
|
"disabled");
|
|
}else{
|
|
var additional=defaultIpInfo.clone();
|
|
additional.removeClass("hidden").removeClass(
|
|
"disabled");
|
|
showDiv.after(additional);
|
|
}
|
|
var index=0;
|
|
$("."+contentClassName).each(function(){
|
|
reSort($(this),index);
|
|
index++;
|
|
});
|
|
$(".selectpicker").selectpicker("render");
|
|
//$(obj).addClass("hidden");
|
|
$("select[name$='ipType']").on("change",function(){
|
|
switchIpInfo(this);
|
|
});
|
|
$("select[name$='IpPattern']").on("change",function(){
|
|
switchIpInfo(this);
|
|
});
|
|
}
|
|
|
|
//业务窗口关闭
|
|
var delContent = function(obj,contentClassName) {
|
|
if($("."+contentClassName).length==1){
|
|
top.$.jBox.tip("<spring:message code='one_more'/>");
|
|
return;
|
|
}
|
|
$(obj).parents("."+contentClassName).remove();
|
|
var index=0;
|
|
$("."+contentClassName).each(function(){
|
|
reSort($(this),index);
|
|
index++;
|
|
});
|
|
}
|
|
var reSort=function(obj,index){
|
|
$(obj).find("input,select").each(function(){
|
|
var name=$(this).attr("name");
|
|
if(name.indexOf("asnIpCfgs[")>-1){
|
|
var namePrefix="asnIpCfgs[";
|
|
var nameSubfix=name.substring(name.indexOf("]"));
|
|
var nameNew=namePrefix+index+nameSubfix;
|
|
if(nameNew!=name){
|
|
$(this).attr("name",nameNew);
|
|
$(this).parents(".form-group").find("div[for='"+name+"']").attr("for",nameNew);
|
|
}
|
|
}
|
|
})
|
|
}
|
|
</script>
|
|
</head>
|
|
<body>
|
|
|
|
<div class="page-content">
|
|
|
|
<h3 class="page-title">
|
|
<spring:message code="asn_ip_configuration"></spring:message>
|
|
</h3>
|
|
|
|
<div class="row">
|
|
<div class="col-md-12">
|
|
<div class="portlet box blue">
|
|
<div class="portlet-title">
|
|
<div class="caption">
|
|
<i class="fa fa-gift"></i>
|
|
<spring:message code="add"></spring:message>
|
|
</div>
|
|
</div>
|
|
<div class="portlet-body form">
|
|
<!-- BEGIN FORM-->
|
|
<form id="cfgFrom" action="${ctx}/basics/asn/save" method="post" class="form-horizontal">
|
|
<input type="hidden" name="functionId" value="${_cfg.functionId}">
|
|
<input type="hidden" id="isAreaEffective" name="isAreaEffective" value="0">
|
|
<input type="hidden" id="compileId" name="compileId" value="0">
|
|
<input type="hidden" id="requestId" name="requestId" value="0">
|
|
<input type="hidden" id="asnIpGroup" name="asnIpGroup" value="0">
|
|
<c:forEach items="${serviceList}" var="service">
|
|
<input type="hidden" id="serviceId" name="serviceId" value="${service.serviceId}">
|
|
<input type="hidden" id="action" name="action" value="${service.action}">
|
|
</c:forEach>
|
|
<!-- 配置域类型 -->
|
|
<c:forEach items="${regionList}" var="region">
|
|
<c:if test="${_cfg.functionId eq region.functionId}">
|
|
<input type="hidden" name="cfgType" value="${region.configRegionValue}">
|
|
<input type="hidden" name="cfgRegionCode"
|
|
isMaat="${region.isMaat}"
|
|
serviceType="${region.configServiceType}"
|
|
ipPortShow="${region.configIpPortShow}"
|
|
ipType="${region.configIpType}"
|
|
srcIpPattern="${fn:split(region.configIpPattern,';')[0]}"
|
|
destIpPattern="${fn:split(region.configIpPattern,';')[1]}"
|
|
srcPortPattern="${fn:split(region.configPortPattern,';')[0]}"
|
|
destPortPattern="${fn:split(region.configPortPattern,';')[1]}"
|
|
direction="${region.configDirection}"
|
|
protocol="${region.configProtocol}"
|
|
regionType="${region.regionType}"
|
|
value="${region.configRegionCode}">
|
|
</c:if>
|
|
</c:forEach>
|
|
<div class="form-body">
|
|
<!-- desc and action -->
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<div class="form-group">
|
|
<label class="control-label col-md-3"><spring:message code="config_describe"/></label>
|
|
<div class="col-md-6">
|
|
<input class="form-control" type="text" name="cfgDesc" value="${_cfg.cfgDesc}">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<%-- <div class="col-md-6">
|
|
<input type="hidden" id="asnId" name="userRegion1" value="${_cfg.userRegion1}">
|
|
<div class="form-group">
|
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="group"/></label>
|
|
<div class="col-md-6">
|
|
<select name="asnIpGroup" class="selectpicker show-tick form-control required" data-live-search="true" data-live-search-placeholder="search">
|
|
<option value="0" ><spring:message code="default_group"/></option>
|
|
<c:forEach items="${policyGroups }" var="policyGroup">
|
|
<option asnId="${policyGroup.asnNo}" value="${policyGroup.serviceGroupId}" <c:if test="${_cfg.asnIpGroup==policyGroup.serviceGroupId }">selected</c:if>><spring:message code="${policyGroup.groupName}"/></option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpGroup"></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="organization"/></label>
|
|
<div class="col-md-6">
|
|
<select name="organization" class="selectpicker show-tick form-control required" data-live-search="true" data-live-search-placeholder="search">
|
|
<c:forEach items="${policyGroups }" var="policyGroup">
|
|
<option value="${policyGroup.groupName}" <c:if test="${_cfg.organization eq policyGroup.groupName }">selected</c:if>>${policyGroup.groupName}</option>
|
|
</c:forEach>
|
|
</select>
|
|
<input class="form-control required" type="text" name="organization" value="${_cfg.organization}">
|
|
</div>
|
|
<div for="organization"></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="ASN"/></label>
|
|
<div class="col-md-6">
|
|
<%-- <select name="userRegion1" class="selectpicker show-tick form-control required" data-live-search="true" data-live-search-placeholder="search">
|
|
</select> --%>
|
|
<input class="form-control required digits asnMustExists" type="text" name="userRegion1" value="${_cfg.userRegion1}" ctx="${ctx}">
|
|
</div>
|
|
<div for="userRegion1"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<%-- <div class="row">
|
|
<div class="col-md-6 hidden">
|
|
<div class="form-group">
|
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="country"/></label>
|
|
<div class="col-md-6">
|
|
<input class="form-control required" type="hidden" name="country" value="${_cfg.country}">
|
|
</div>
|
|
<div for="country"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-md-6 hidden">
|
|
<div class="form-group">
|
|
<label class="control-label col-md-3"><font color="red">*</font><spring:message code="detail"/></label>
|
|
<div class="col-md-6">
|
|
<input class="form-control required" type="hidden" name="detail" value="${_cfg.detail}">
|
|
</div>
|
|
<div for="detail"></div>
|
|
</div>
|
|
</div>
|
|
</div> --%>
|
|
<!-- desc and action -->
|
|
<h4 class="form-section">
|
|
<spring:message code="asn_ip_configuration" />
|
|
<small> <span
|
|
class="glyphicon glyphicon-plus asnIpAdd"
|
|
onClick="addContent(this,'ipInfo')" title="add"></span></small>
|
|
</h4>
|
|
<div class="row ipInfo boxSolid asnIp hidden disabled">
|
|
<input type="hidden" name="asnIpCfgs[0].protocolId" value="0">
|
|
<div class="row">
|
|
<div class="pull-right">
|
|
<span class="glyphicon glyphicon-remove pull-right" title="remove"
|
|
onClick="delContent(this,'ipInfo');" />
|
|
</div>
|
|
</div>
|
|
<div class="row protocol">
|
|
<div class="col-md-6">
|
|
<div class="form-group ">
|
|
<label class="control-label col-md-3"><font color="red">*</font>
|
|
<spring:message code="protocol" /></label>
|
|
<div class="col-md-6">
|
|
<select name="asnIpCfgs[0].protocol"
|
|
class="selectpicker show-tick form-control required">
|
|
<c:forEach items="${fns:getDictList('PROTOCOL')}" var="protocolC">
|
|
<option value="${protocolC.itemCode}" <c:if test="${_cfg.asnIpCfgs[0].protocol==protocolC.itemCode || (_cfg.asnIpCfgs[0].protocol==null && protocolC.itemCode==0)}">selected</c:if>><spring:message code="${protocolC.itemValue}"/></option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpCfgs[0].protocol"></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="asnIpCfgs[0].direction"
|
|
class="selectpicker show-tick form-control required">
|
|
<c:forEach items="${fns:getDictList('DIRECTION')}" var="directionC">
|
|
<option value="${directionC.itemCode}" <c:if test="${_cfg.asnIpCfgs[0].direction==directionC.itemCode || (_cfg.asnIpCfgs[0].direction==null && directionC.itemCode==0)}">selected</c:if>><spring:message code="${directionC.itemValue}"/></option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpCfgs[0].direction"></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="ip_type"/></label>
|
|
<div class="col-md-6">
|
|
<select name="asnIpCfgs[0].ipType" class="selectpicker show-tick form-control required">
|
|
<c:forEach items="${fns:getDictList('IP_TYPE')}" var="ipTypeC">
|
|
<option value="${ipTypeC.itemCode}"
|
|
<c:if test="${_cfg.asnIpCfgs[0].ipType==ipTypeC.itemCode
|
|
|| (_cfg.asnIpCfgs[0].ipType==null && ipTypeC.itemCode==4)}">
|
|
selected
|
|
</c:if>
|
|
>
|
|
<spring:message code="${ipTypeC.itemValue}"/>
|
|
</option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpCfgs[0].ipType"></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="src_ip_pattern"/></label>
|
|
<div class="col-md-6">
|
|
<select name="asnIpCfgs[0].srcIpPattern" class="selectpicker show-tick form-control required">
|
|
<c:forEach items="${fns:getDictList('IP_PATTERN')}" var="ipPatternC">
|
|
<option value="${ipPatternC.itemCode}" <c:if test="${_cfg.asnIpCfgs[0].srcIpPattern==ipPatternC.itemCode || (_cfg.asnIpCfgs[0].srcIpPattern==null && ipPatternC.itemCode==3)}">selected</c:if>><spring:message code="${ipPatternC.itemValue}"/></option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpCfgs[0].srcIpPattern"></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="client_ip"/></label>
|
|
<div class="col-md-6">
|
|
<input class="form-control required ipCheck" type="text" name="asnIpCfgs[0].srcIpAddress" value="${_cfg.asnIpCfgs[0].srcIpAddress}">
|
|
</div>
|
|
<div for="asnIpCfgs[0].srcIpAddress"></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="src_port_pattern"/></label>
|
|
<div class="col-md-6">
|
|
<select name="asnIpCfgs[0].srcPortPattern" class="selectpicker show-tick form-control required">
|
|
<c:forEach items="${fns:getDictList('PORT_PATTERN')}" var="portPatternC">
|
|
<option value="${portPatternC.itemCode}" <c:if test="${_cfg.asnIpCfgs[0].srcPortPattern==portPatternC.itemCode || (_cfg.asnIpCfgs[0].srcPortPattern==null && portPatternC.itemCode==1)}">selected</c:if>><spring:message code="${portPatternC.itemValue}"/></option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpCfgs[0].srcPortPattern"></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="client_port"/></label>
|
|
<div class="col-md-6">
|
|
<input class="form-control required portCheck" type="text" name="asnIpCfgs[0].srcPort" value="${_cfg.asnIpCfgs[0].srcPort}">
|
|
</div>
|
|
<div for="asnIpCfgs[0].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="ip_pattern"/></label>
|
|
<div class="col-md-6">
|
|
<select name="asnIpCfgs[0].destIpPattern" class="selectpicker show-tick form-control required">
|
|
<c:forEach items="${fns:getDictList('IP_PATTERN')}" var="ipPatternC">
|
|
<option value="${ipPatternC.itemCode}" <c:if test="${_cfg.asnIpCfgs[0].destIpPattern==ipPatternC.itemCode || (_cfg.asnIpCfgs[0].destIpPattern==null && ipPatternC.itemCode==3)}">selected</c:if>><spring:message code="${ipPatternC.itemValue}"/></option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpCfgs[0].destIpPattern"></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_ip"/></label>
|
|
<div class="col-md-6">
|
|
<input class="form-control required ipCheck" type="text" name="asnIpCfgs[0].destIpAddress" value="${_cfg.asnIpCfgs[0].destIpAddress}">
|
|
</div>
|
|
<div for="asnIpCfgs[0].destIpAddress"></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="dest_port_pattern"/></label>
|
|
<div class="col-md-6">
|
|
<select name="asnIpCfgs[0].destPortPattern" class="selectpicker show-tick form-control required">
|
|
<c:forEach items="${fns:getDictList('PORT_PATTERN')}" var="portPatternC">
|
|
<option value="${portPatternC.itemCode}" <c:if test="${_cfg.asnIpCfgs[0].destPortPattern==portPatternC.itemCode || (_cfg.asnIpCfgs[0].destPortPattern==null && portPatternC.itemCode==1)}">selected</c:if>><spring:message code="${portPatternC.itemValue}"/></option>
|
|
</c:forEach>
|
|
</select>
|
|
</div>
|
|
<div for="asnIpCfgs[0].destPortPattern"></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>
|
|
<div class="col-md-6">
|
|
<input class="form-control required portCheck" type="text" name="asnIpCfgs[0].destPort" value="${_cfg.asnIpCfgs[0].destPort}">
|
|
</div>
|
|
<div for="asnIpCfgs[0].destPort"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<%-- <div class="row">
|
|
<button type="button" class="btn btn-red-hollow center-block"
|
|
onClick="more(this);" data-click-times="0">
|
|
<spring:message code="show_more" />
|
|
</button>
|
|
</div> --%>
|
|
</div>
|
|
</div>
|
|
<div class="form-actions">
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<div class="row">
|
|
<div class="col-md-offset-3 col-md-8">
|
|
<button id="save" type="submit" class="btn green"><spring:message code="submit"/></button>
|
|
<button id="cancel" type="button" class="btn default"><spring:message code="cancel"/></button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-6"> </div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
<!-- END FORM-->
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html> |