mirror of
				https://github.com/TeaOSLab/EdgeAdmin.git
				synced 2025-11-04 13:10:26 +08:00 
			
		
		
		
	IP名单支持IPv6范围
This commit is contained in:
		@@ -2,28 +2,12 @@ package utils
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"bytes"
 | 
						"bytes"
 | 
				
			||||||
	"encoding/binary"
 | 
					 | 
				
			||||||
	"errors"
 | 
						"errors"
 | 
				
			||||||
	"github.com/iwind/TeaGo/types"
 | 
						"github.com/iwind/TeaGo/types"
 | 
				
			||||||
	"net"
 | 
						"net"
 | 
				
			||||||
	"strings"
 | 
						"strings"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// IP2Long 将IP转换为整型
 | 
					 | 
				
			||||||
// 为临时过渡的函数
 | 
					 | 
				
			||||||
func IP2Long(ip string) uint64 {
 | 
					 | 
				
			||||||
	var i = net.ParseIP(ip)
 | 
					 | 
				
			||||||
	if len(i) == 0 {
 | 
					 | 
				
			||||||
		return 0
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	if i.To4() != nil {
 | 
					 | 
				
			||||||
		return uint64(binary.BigEndian.Uint32(i.To4()))
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	// TODO 支持IPv6
 | 
					 | 
				
			||||||
	return 0
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// ExtractIP 分解IP
 | 
					// ExtractIP 分解IP
 | 
				
			||||||
// 只支持D段掩码的CIDR
 | 
					// 只支持D段掩码的CIDR
 | 
				
			||||||
// 最多只记录255个值
 | 
					// 最多只记录255个值
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
package ipadmin
 | 
					package ipadmin
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (	"github.com/TeaOSLab/EdgeAdmin/internal/utils"
 | 
					import (
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
				
			||||||
@@ -72,29 +72,32 @@ func (this *UpdateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
			Require("请输入开始IP")
 | 
								Require("请输入开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom/ipTo)
 | 
							// 校验IP格式(ipFrom/ipTo)
 | 
				
			||||||
		var ipFromLong uint64
 | 
					 | 
				
			||||||
		if !iputils.IsIPv4(params.IpFrom) {
 | 
							if !iputils.IsIPv4(params.IpFrom) {
 | 
				
			||||||
			this.Fail("请输入正确的开始IP")
 | 
								this.FailField("ipFrom", "请输入正确的开始IP")
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipFromLong = utils.IP2Long(params.IpFrom)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		var ipToLong uint64
 | 
					 | 
				
			||||||
		if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
				
			||||||
			this.Fail("请输入正确的结束IP")
 | 
								this.FailField("ipTo", "请输入正确的结束IP")
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipToLong = utils.IP2Long(params.IpTo)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ipFromLong > 0 && ipToLong > 0 && ipFromLong > ipToLong {
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
			params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "ipv6":
 | 
						case "ipv6":
 | 
				
			||||||
		params.Must.
 | 
							params.Must.
 | 
				
			||||||
			Field("ipFrom", params.IpFrom).
 | 
								Field("ipFrom", params.IpFrom).
 | 
				
			||||||
			Require("请输入IP")
 | 
								Require("请输入正确的开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom)
 | 
					 | 
				
			||||||
		if !iputils.IsIPv6(params.IpFrom) {
 | 
							if !iputils.IsIPv6(params.IpFrom) {
 | 
				
			||||||
			this.Fail("请输入正确的IPv6地址")
 | 
								this.FailField("ipFrom", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv6(params.IpTo) {
 | 
				
			||||||
 | 
								this.FailField("ipTo", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "all":
 | 
						case "all":
 | 
				
			||||||
		params.IpFrom = "0.0.0.0"
 | 
							params.IpFrom = "0.0.0.0"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,8 @@
 | 
				
			|||||||
package ipadmin
 | 
					package ipadmin
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/utils"
 | 
					 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
				
			||||||
	"github.com/iwind/TeaGo/actions"
 | 
						"github.com/iwind/TeaGo/actions"
 | 
				
			||||||
@@ -71,29 +71,32 @@ func (this *UpdateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
			Require("请输入开始IP")
 | 
								Require("请输入开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom/ipTo)
 | 
							// 校验IP格式(ipFrom/ipTo)
 | 
				
			||||||
		var ipFromLong uint64
 | 
							if !iputils.IsIPv4(params.IpFrom) {
 | 
				
			||||||
		if !utils.IsIPv4(params.IpFrom) {
 | 
								this.FailField("ipFrom", "请输入正确的开始IP")
 | 
				
			||||||
			this.Fail("请输入正确的开始IP")
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipFromLong = utils.IP2Long(params.IpFrom)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		var ipToLong uint64
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
				
			||||||
		if len(params.IpTo) > 0 && !utils.IsIPv4(params.IpTo) {
 | 
								this.FailField("ipTo", "请输入正确的结束IP")
 | 
				
			||||||
			this.Fail("请输入正确的结束IP")
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipToLong = utils.IP2Long(params.IpTo)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ipFromLong > 0 && ipToLong > 0 && ipFromLong > ipToLong {
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
			params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "ipv6":
 | 
						case "ipv6":
 | 
				
			||||||
		params.Must.
 | 
							params.Must.
 | 
				
			||||||
			Field("ipFrom", params.IpFrom).
 | 
								Field("ipFrom", params.IpFrom).
 | 
				
			||||||
			Require("请输入IP")
 | 
								Require("请输入正确的开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom)
 | 
							if !iputils.IsIPv6(params.IpFrom) {
 | 
				
			||||||
		if !utils.IsIPv6(params.IpFrom) {
 | 
								this.FailField("ipFrom", "请输入正确的IPv6地址")
 | 
				
			||||||
			this.Fail("请输入正确的IPv6地址")
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv6(params.IpTo) {
 | 
				
			||||||
 | 
								this.FailField("ipTo", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "all":
 | 
						case "all":
 | 
				
			||||||
		params.IpFrom = "0.0.0.0"
 | 
							params.IpFrom = "0.0.0.0"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,7 +1,6 @@
 | 
				
			|||||||
package iplists
 | 
					package iplists
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/utils"
 | 
					 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
				
			||||||
@@ -90,19 +89,15 @@ func (this *CreateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
				Field("ipFrom", params.IpFrom).
 | 
									Field("ipFrom", params.IpFrom).
 | 
				
			||||||
				Require("请输入开始IP")
 | 
									Require("请输入开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			var ipFromLong uint64
 | 
					 | 
				
			||||||
			if !iputils.IsIPv4(params.IpFrom) {
 | 
								if !iputils.IsIPv4(params.IpFrom) {
 | 
				
			||||||
				this.Fail("请输入正确的开始IP")
 | 
									this.FailField("ipFrom", "请输入正确的开始IP")
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			ipFromLong = utils.IP2Long(params.IpFrom)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			var ipToLong uint64
 | 
					 | 
				
			||||||
			if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
								if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
				
			||||||
				this.Fail("请输入正确的结束IP")
 | 
									this.FailField("ipTo", "请输入正确的结束IP")
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			ipToLong = utils.IP2Long(params.IpTo)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if ipFromLong > 0 && ipToLong > 0 && ipFromLong > ipToLong {
 | 
								if len(params.IpTo) != 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
				params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
									params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		} else if params.Method == "batch" {
 | 
							} else if params.Method == "batch" {
 | 
				
			||||||
@@ -132,7 +127,7 @@ func (this *CreateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
					if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || strings.Contains(ipFrom, ":") || strings.Contains(ipTo, ":") {
 | 
										if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || strings.Contains(ipFrom, ":") || strings.Contains(ipTo, ":") {
 | 
				
			||||||
						this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
											this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					if utils.IP2Long(ipFrom) > utils.IP2Long(ipTo) {
 | 
										if len(ipTo) > 0 && iputils.CompareIP(ipFrom, ipTo) > 0 {
 | 
				
			||||||
						ipFrom, ipTo = ipTo, ipFrom
 | 
											ipFrom, ipTo = ipTo, ipFrom
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					batchIPs = append(batchIPs, &ipData{
 | 
										batchIPs = append(batchIPs, &ipData{
 | 
				
			||||||
@@ -147,7 +142,7 @@ func (this *CreateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
					if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || strings.Contains(ipFrom, ":") || strings.Contains(ipTo, ":") {
 | 
										if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || strings.Contains(ipFrom, ":") || strings.Contains(ipTo, ":") {
 | 
				
			||||||
						this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
											this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					if utils.IP2Long(ipFrom) > utils.IP2Long(ipTo) {
 | 
										if len(ipTo) > 0 && iputils.CompareIP(ipFrom, ipTo) > 0 {
 | 
				
			||||||
						ipFrom, ipTo = ipTo, ipFrom
 | 
											ipFrom, ipTo = ipTo, ipFrom
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					batchIPs = append(batchIPs, &ipData{
 | 
										batchIPs = append(batchIPs, &ipData{
 | 
				
			||||||
@@ -169,11 +164,18 @@ func (this *CreateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
		if params.Method == "single" {
 | 
							if params.Method == "single" {
 | 
				
			||||||
			params.Must.
 | 
								params.Must.
 | 
				
			||||||
				Field("ipFrom", params.IpFrom).
 | 
									Field("ipFrom", params.IpFrom).
 | 
				
			||||||
				Require("请输入IP")
 | 
									Require("请输入正确的开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			// 校验IP格式(ipFrom)
 | 
					 | 
				
			||||||
			if !iputils.IsIPv6(params.IpFrom) {
 | 
								if !iputils.IsIPv6(params.IpFrom) {
 | 
				
			||||||
				this.Fail("请输入正确的IPv6地址")
 | 
									this.FailField("ipFrom", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if len(params.IpTo) > 0 && !iputils.IsIPv6(params.IpTo) {
 | 
				
			||||||
 | 
									this.FailField("ipTo", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
 | 
									params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		} else if params.Method == "batch" {
 | 
							} else if params.Method == "batch" {
 | 
				
			||||||
			if len(params.IpData) == 0 {
 | 
								if len(params.IpData) == 0 {
 | 
				
			||||||
@@ -202,7 +204,7 @@ func (this *CreateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
					if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || !strings.Contains(ipFrom, ":") || !strings.Contains(ipTo, ":") {
 | 
										if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || !strings.Contains(ipFrom, ":") || !strings.Contains(ipTo, ":") {
 | 
				
			||||||
						this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
											this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					if utils.IP2Long(ipFrom) > utils.IP2Long(ipTo) {
 | 
										if len(ipTo) > 0 && iputils.CompareIP(ipFrom, ipTo) > 0 {
 | 
				
			||||||
						ipFrom, ipTo = ipTo, ipFrom
 | 
											ipFrom, ipTo = ipTo, ipFrom
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					batchIPs = append(batchIPs, &ipData{
 | 
										batchIPs = append(batchIPs, &ipData{
 | 
				
			||||||
@@ -217,7 +219,7 @@ func (this *CreateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
					if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || !strings.Contains(ipFrom, ":") || !strings.Contains(ipTo, ":") {
 | 
										if net.ParseIP(ipFrom) == nil || net.ParseIP(ipTo) == nil || !strings.Contains(ipFrom, ":") || !strings.Contains(ipTo, ":") {
 | 
				
			||||||
						this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
											this.FailField("ipData", "第"+types.String(index+1)+"行IP格式错误:"+line)
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					if utils.IP2Long(ipFrom) > utils.IP2Long(ipTo) {
 | 
										if len(ipTo) > 0 && iputils.CompareIP(ipFrom, ipTo) > 0 {
 | 
				
			||||||
						ipFrom, ipTo = ipTo, ipFrom
 | 
											ipFrom, ipTo = ipTo, ipFrom
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					batchIPs = append(batchIPs, &ipData{
 | 
										batchIPs = append(batchIPs, &ipData{
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
package iplists
 | 
					package iplists
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (	"github.com/TeaOSLab/EdgeAdmin/internal/utils"
 | 
					import (
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
				
			||||||
@@ -71,29 +71,32 @@ func (this *UpdateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
			Require("请输入开始IP")
 | 
								Require("请输入开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom/ipTo)
 | 
							// 校验IP格式(ipFrom/ipTo)
 | 
				
			||||||
		var ipFromLong uint64
 | 
					 | 
				
			||||||
		if !iputils.IsIPv4(params.IpFrom) {
 | 
							if !iputils.IsIPv4(params.IpFrom) {
 | 
				
			||||||
			this.Fail("请输入正确的开始IP")
 | 
								this.FailField("ipFrom", "请输入正确的开始IP")
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipFromLong = utils.IP2Long(params.IpFrom)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		var ipToLong uint64
 | 
					 | 
				
			||||||
		if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
				
			||||||
			this.Fail("请输入正确的结束IP")
 | 
								this.FailField("ipTo", "请输入正确的结束IP")
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipToLong = utils.IP2Long(params.IpTo)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ipFromLong > 0 && ipToLong > 0 && ipFromLong > ipToLong {
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
			params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "ipv6":
 | 
						case "ipv6":
 | 
				
			||||||
		params.Must.
 | 
							params.Must.
 | 
				
			||||||
			Field("ipFrom", params.IpFrom).
 | 
								Field("ipFrom", params.IpFrom).
 | 
				
			||||||
			Require("请输入IP")
 | 
								Require("请输入正确的开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom)
 | 
					 | 
				
			||||||
		if !iputils.IsIPv6(params.IpFrom) {
 | 
							if !iputils.IsIPv6(params.IpFrom) {
 | 
				
			||||||
			this.Fail("请输入正确的IPv6地址")
 | 
								this.FailField("ipFrom", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv6(params.IpTo) {
 | 
				
			||||||
 | 
								this.FailField("ipTo", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "all":
 | 
						case "all":
 | 
				
			||||||
		params.IpFrom = "0.0.0.0"
 | 
							params.IpFrom = "0.0.0.0"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -63,9 +63,9 @@ func (this *DenyListAction) RunGet(params struct {
 | 
				
			|||||||
		this.ErrorPage(err)
 | 
							this.ErrorPage(err)
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	itemMaps := []maps.Map{}
 | 
						var itemMaps = []maps.Map{}
 | 
				
			||||||
	for _, item := range itemsResp.IpItems {
 | 
						for _, item := range itemsResp.IpItems {
 | 
				
			||||||
		expiredTime := ""
 | 
							var expiredTime = ""
 | 
				
			||||||
		if item.ExpiredAt > 0 {
 | 
							if item.ExpiredAt > 0 {
 | 
				
			||||||
			expiredTime = timeutil.FormatTime("Y-m-d H:i:s", item.ExpiredAt)
 | 
								expiredTime = timeutil.FormatTime("Y-m-d H:i:s", item.ExpiredAt)
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
package ipadmin
 | 
					package ipadmin
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (	"github.com/TeaOSLab/EdgeAdmin/internal/utils"
 | 
					import (
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/iputils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
 | 
				
			||||||
@@ -71,29 +71,32 @@ func (this *UpdateIPPopupAction) RunPost(params struct {
 | 
				
			|||||||
			Require("请输入开始IP")
 | 
								Require("请输入开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom/ipTo)
 | 
							// 校验IP格式(ipFrom/ipTo)
 | 
				
			||||||
		var ipFromLong uint64
 | 
					 | 
				
			||||||
		if !iputils.IsIPv4(params.IpFrom) {
 | 
							if !iputils.IsIPv4(params.IpFrom) {
 | 
				
			||||||
			this.Fail("请输入正确的开始IP")
 | 
								this.FailField("ipFrom", "请输入正确的开始IP")
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipFromLong = utils.IP2Long(params.IpFrom)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		var ipToLong uint64
 | 
					 | 
				
			||||||
		if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv4(params.IpTo) {
 | 
				
			||||||
			this.Fail("请输入正确的结束IP")
 | 
								this.FailField("ipTo", "请输入正确的结束IP")
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		ipToLong = utils.IP2Long(params.IpTo)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ipFromLong > 0 && ipToLong > 0 && ipFromLong > ipToLong {
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
			params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "ipv6":
 | 
						case "ipv6":
 | 
				
			||||||
		params.Must.
 | 
							params.Must.
 | 
				
			||||||
			Field("ipFrom", params.IpFrom).
 | 
								Field("ipFrom", params.IpFrom).
 | 
				
			||||||
			Require("请输入IP")
 | 
								Require("请输入正确的开始IP")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 校验IP格式(ipFrom)
 | 
					 | 
				
			||||||
		if !iputils.IsIPv6(params.IpFrom) {
 | 
							if !iputils.IsIPv6(params.IpFrom) {
 | 
				
			||||||
			this.Fail("请输入正确的IPv6地址")
 | 
								this.FailField("ipFrom", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && !iputils.IsIPv6(params.IpTo) {
 | 
				
			||||||
 | 
								this.FailField("ipTo", "请输入正确的IPv6地址")
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if len(params.IpTo) > 0 && iputils.CompareIP(params.IpFrom, params.IpTo) > 0 {
 | 
				
			||||||
 | 
								params.IpTo, params.IpFrom = params.IpFrom, params.IpTo
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	case "all":
 | 
						case "all":
 | 
				
			||||||
		params.IpFrom = "0.0.0.0"
 | 
							params.IpFrom = "0.0.0.0"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -199,12 +199,12 @@ Vue.component("ip-list-table", {
 | 
				
			|||||||
				<td>
 | 
									<td>
 | 
				
			||||||
					<div v-if="item.expiredTime.length > 0">
 | 
										<div v-if="item.expiredTime.length > 0">
 | 
				
			||||||
						{{item.expiredTime}}
 | 
											{{item.expiredTime}}
 | 
				
			||||||
						<div v-if="item.isExpired" style="margin-top: 0.5em">
 | 
											<div v-if="item.isExpired && item.lifeSeconds == null" style="margin-top: 0.5em">
 | 
				
			||||||
							<span class="ui label tiny basic red">已过期</span>
 | 
												<span class="ui label tiny basic red">已过期</span>
 | 
				
			||||||
						</div>
 | 
											</div>
 | 
				
			||||||
						<div  v-if="item.lifeSeconds != null">
 | 
											<div  v-if="item.lifeSeconds != null">
 | 
				
			||||||
							<span class="small grey" v-if="item.lifeSeconds > 0">{{formatSeconds(item.lifeSeconds)}}</span>
 | 
												<span class="small grey" v-if="item.lifeSeconds > 0">{{formatSeconds(item.lifeSeconds)}}</span>
 | 
				
			||||||
							<span class="small red">已过期</span>
 | 
												<span class="small red" v-if="item.lifeSeconds < 0">已过期</span>
 | 
				
			||||||
						</div>
 | 
											</div>
 | 
				
			||||||
					</div>
 | 
										</div>
 | 
				
			||||||
					<span v-else class="disabled">不过期</span>
 | 
										<span v-else class="disabled">不过期</span>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,7 +34,7 @@
 | 
				
			|||||||
            <td>结束IP</td>
 | 
					            <td>结束IP</td>
 | 
				
			||||||
            <td>
 | 
					            <td>
 | 
				
			||||||
                <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
					                <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
				
			||||||
                <p class="comment">表示IP段的时候需要填写此项。</p>
 | 
					                <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
@@ -48,13 +48,20 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        <!-- IPv6 -->
 | 
					        <!-- IPv6 -->
 | 
				
			||||||
        <tbody v-if="type == 'ipv6'">
 | 
					        <tbody v-if="type == 'ipv6'">
 | 
				
			||||||
        <tr>
 | 
					            <tr>
 | 
				
			||||||
            <td>IP *</td>
 | 
					                <td>开始IP *</td>
 | 
				
			||||||
            <td>
 | 
					                <td>
 | 
				
			||||||
                <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
					                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
				
			||||||
                <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
					                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
				
			||||||
            </td>
 | 
					                </td>
 | 
				
			||||||
        </tr>
 | 
					            </tr>
 | 
				
			||||||
 | 
					            <tr>
 | 
				
			||||||
 | 
					                <td>结束IP</td>
 | 
				
			||||||
 | 
					                <td>
 | 
				
			||||||
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipTo"/>
 | 
				
			||||||
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
 | 
					                </td>
 | 
				
			||||||
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
		<tr>
 | 
							<tr>
 | 
				
			||||||
			<td colspan="2"><more-options-indicator></more-options-indicator></td>
 | 
								<td colspan="2"><more-options-indicator></more-options-indicator></td>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,7 +33,7 @@
 | 
				
			|||||||
                <td>结束IP</td>
 | 
					                <td>结束IP</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
				
			||||||
                    <p class="comment">表示IP段的时候需要填写此项。</p>
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
@@ -41,12 +41,19 @@
 | 
				
			|||||||
        <!-- IPv6 -->
 | 
					        <!-- IPv6 -->
 | 
				
			||||||
        <tbody v-if="type == 'ipv6'">
 | 
					        <tbody v-if="type == 'ipv6'">
 | 
				
			||||||
            <tr>
 | 
					            <tr>
 | 
				
			||||||
                <td>IP *</td>
 | 
					                <td>开始IP *</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
					                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
				
			||||||
                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
					                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
 | 
					            <tr>
 | 
				
			||||||
 | 
					                <td>结束IP</td>
 | 
				
			||||||
 | 
					                <td>
 | 
				
			||||||
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipTo"/>
 | 
				
			||||||
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
 | 
					                </td>
 | 
				
			||||||
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <tr>
 | 
					        <tr>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -42,7 +42,7 @@
 | 
				
			|||||||
                <td>结束IP</td>
 | 
					                <td>结束IP</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" style="width: 10em"/>
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" style="width: 10em"/>
 | 
				
			||||||
                    <p class="comment">表示IP段的时候需要填写此项。</p>
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
@@ -50,12 +50,19 @@
 | 
				
			|||||||
        <!-- IPv6 -->
 | 
					        <!-- IPv6 -->
 | 
				
			||||||
        <tbody v-if="method == 'single' && type == 'ipv6'">
 | 
					        <tbody v-if="method == 'single' && type == 'ipv6'">
 | 
				
			||||||
            <tr>
 | 
					            <tr>
 | 
				
			||||||
                <td>IP *</td>
 | 
					                <td>开始IP *</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" style="width: 20em"/>
 | 
					                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" style="width: 20em"/>
 | 
				
			||||||
                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
					                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
 | 
					            <tr>
 | 
				
			||||||
 | 
					                <td>结束IP</td>
 | 
				
			||||||
 | 
					                <td>
 | 
				
			||||||
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" style="width: 20em"/>
 | 
				
			||||||
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
 | 
					                </td>
 | 
				
			||||||
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <!-- 批量添加 -->
 | 
					        <!-- 批量添加 -->
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,7 +33,7 @@
 | 
				
			|||||||
            <td>结束IP</td>
 | 
					            <td>结束IP</td>
 | 
				
			||||||
            <td>
 | 
					            <td>
 | 
				
			||||||
                <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
					                <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
				
			||||||
                <p class="comment">表示IP段的时候需要填写此项。</p>
 | 
					                <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
@@ -47,13 +47,20 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        <!-- IPv6 -->
 | 
					        <!-- IPv6 -->
 | 
				
			||||||
        <tbody v-if="type == 'ipv6'">
 | 
					        <tbody v-if="type == 'ipv6'">
 | 
				
			||||||
        <tr>
 | 
					            <tr>
 | 
				
			||||||
            <td>IP *</td>
 | 
					                <td>开始IP *</td>
 | 
				
			||||||
            <td>
 | 
					                <td>
 | 
				
			||||||
                <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
					                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
				
			||||||
                <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
					                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
				
			||||||
            </td>
 | 
					                </td>
 | 
				
			||||||
        </tr>
 | 
					            </tr>
 | 
				
			||||||
 | 
					            <tr>
 | 
				
			||||||
 | 
					                <td>结束IP</td>
 | 
				
			||||||
 | 
					                <td>
 | 
				
			||||||
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipTo"/>
 | 
				
			||||||
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
 | 
					                </td>
 | 
				
			||||||
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <tr>
 | 
					        <tr>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,7 +33,7 @@
 | 
				
			|||||||
                <td>结束IP</td>
 | 
					                <td>结束IP</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x.x.x.x" v-model="item.ipTo"/>
 | 
				
			||||||
                    <p class="comment">表示IP段的时候需要填写此项。</p>
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
@@ -41,12 +41,19 @@
 | 
				
			|||||||
        <!-- IPv6 -->
 | 
					        <!-- IPv6 -->
 | 
				
			||||||
        <tbody v-if="type == 'ipv6'">
 | 
					        <tbody v-if="type == 'ipv6'">
 | 
				
			||||||
            <tr>
 | 
					            <tr>
 | 
				
			||||||
                <td>IP *</td>
 | 
					                <td>开始IP *</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
					                    <input type="text" name="ipFrom" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipFrom"/>
 | 
				
			||||||
                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
					                    <p class="comment">IPv6地址,比如 1406:3c00:0:2409:13:58:103:15</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
 | 
					            <tr>
 | 
				
			||||||
 | 
					                <td>结束IP</td>
 | 
				
			||||||
 | 
					                <td>
 | 
				
			||||||
 | 
					                    <input type="text" name="ipTo" maxlength="64" placeholder="x:x:x:x:x:x:x:x" ref="focus" v-model="item.ipTo"/>
 | 
				
			||||||
 | 
					                    <p class="comment">只有表示IP段的时候才需要填写此项。</p>
 | 
				
			||||||
 | 
					                </td>
 | 
				
			||||||
 | 
					            </tr>
 | 
				
			||||||
        </tbody>
 | 
					        </tbody>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <tr>
 | 
					        <tr>
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user