mirror of
https://github.com/SoftEtherVPN/SoftEtherVPN.git
synced 2024-11-22 17:39:53 +03:00
Merge PR #1489: Fix policy dialog and memory overrun
This commit is contained in:
commit
d7be057ae0
@ -21,47 +21,47 @@
|
|||||||
// Policy items
|
// Policy items
|
||||||
POLICY_ITEM policy_item[] =
|
POLICY_ITEM policy_item[] =
|
||||||
{
|
{
|
||||||
// ID, Value, Omittable, Min, Max, Default, Unit name
|
// ID, Value, Omittable, Min, Max, Default, Unit name, Offset
|
||||||
// Ver 2.0
|
// Ver 2.0
|
||||||
{0, false, false, 0, 0, 0, NULL}, // Access
|
{0, false, false, 0, 0, 0, NULL, offsetof(POLICY, Access)}, // Access
|
||||||
{1, false, false, 0, 0, 0, NULL}, // DHCPFilter
|
{1, false, false, 0, 0, 0, NULL, offsetof(POLICY, DHCPFilter)}, // DHCPFilter
|
||||||
{2, false, false, 0, 0, 0, NULL}, // DHCPNoServer
|
{2, false, false, 0, 0, 0, NULL, offsetof(POLICY, DHCPNoServer)}, // DHCPNoServer
|
||||||
{3, false, false, 0, 0, 0, NULL}, // DHCPForce
|
{3, false, false, 0, 0, 0, NULL, offsetof(POLICY, DHCPForce)}, // DHCPForce
|
||||||
{4, false, false, 0, 0, 0, NULL}, // NoBridge
|
{4, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoBridge)}, // NoBridge
|
||||||
{5, false, false, 0, 0, 0, NULL}, // NoRouting
|
{5, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoRouting)}, // NoRouting
|
||||||
{6, false, false, 0, 0, 0, NULL}, // CheckMac
|
{6, false, false, 0, 0, 0, NULL, offsetof(POLICY, CheckMac)}, // CheckMac
|
||||||
{7, false, false, 0, 0, 0, NULL}, // CheckIP
|
{7, false, false, 0, 0, 0, NULL, offsetof(POLICY, CheckIP)}, // CheckIP
|
||||||
{8, false, false, 0, 0, 0, NULL}, // ArpDhcpOnly
|
{8, false, false, 0, 0, 0, NULL, offsetof(POLICY, ArpDhcpOnly)}, // ArpDhcpOnly
|
||||||
{9, false, false, 0, 0, 0, NULL}, // PrivacyFilter
|
{9, false, false, 0, 0, 0, NULL, offsetof(POLICY, PrivacyFilter)}, // PrivacyFilter
|
||||||
{10, false, false, 0, 0, 0, NULL}, // NoServer
|
{10, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoServer)}, // NoServer
|
||||||
{11, false, false, 0, 0, 0, NULL}, // NoBroadcastLimiter
|
{11, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoBroadcastLimiter)}, // NoBroadcastLimiter
|
||||||
{12, false, false, 0, 0, 0, NULL}, // MonitorPort
|
{12, false, false, 0, 0, 0, NULL, offsetof(POLICY, MonitorPort)}, // MonitorPort
|
||||||
{13, true, false, 1, 32, 32, "POL_INT_COUNT"}, // MaxConnection
|
{13, true, false, 1, 32, 32, "POL_INT_COUNT", offsetof(POLICY, MaxConnection)}, // MaxConnection
|
||||||
{14, true, false, 5, 60, 20, "POL_INT_SEC"}, // TimeOut
|
{14, true, false, 5, 60, 20, "POL_INT_SEC", offsetof(POLICY, TimeOut)}, // TimeOut
|
||||||
{15, true, true, 1, 65535, 0, "POL_INT_COUNT"}, // MaxMac
|
{15, true, true, 1, 65535, 0, "POL_INT_COUNT", offsetof(POLICY, MaxMac)}, // MaxMac
|
||||||
{16, true, true, 1, 65535, 0, "POL_INT_COUNT"}, // MaxIP
|
{16, true, true, 1, 65535, 0, "POL_INT_COUNT", offsetof(POLICY, MaxIP)}, // MaxIP
|
||||||
{17, true, true, 1, 4294967295UL, 0, "POL_INT_BPS"}, // MaxUpload
|
{17, true, true, 1, 4294967295UL, 0, "POL_INT_BPS", offsetof(POLICY, MaxUpload)}, // MaxUpload
|
||||||
{18, true, true, 1, 4294967295UL, 0, "POL_INT_BPS"}, // MaxDownload
|
{18, true, true, 1, 4294967295UL, 0, "POL_INT_BPS", offsetof(POLICY, MaxDownload)}, // MaxDownload
|
||||||
{19, false, false, 0, 0, 0, NULL}, // FixPassword
|
{19, false, false, 0, 0, 0, NULL, offsetof(POLICY, FixPassword)}, // FixPassword
|
||||||
{20, true, true, 1, 65535, 0, "POL_INT_COUNT"}, // MultiLogins
|
{20, true, true, 1, 65535, 0, "POL_INT_COUNT", offsetof(POLICY, MultiLogins)}, // MultiLogins
|
||||||
{21, false, false, 0, 0, 0, NULL}, // NoQoS
|
{21, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoQoS)}, // NoQoS
|
||||||
// Ver 3.0
|
// Ver 3.0
|
||||||
{22, false, false, 0, 0, 0, NULL}, // RSandRAFilter
|
{22, false, false, 0, 0, 0, NULL, offsetof(POLICY, RSandRAFilter)}, // RSandRAFilter
|
||||||
{23, false, false, 0, 0, 0, NULL}, // RAFilter
|
{23, false, false, 0, 0, 0, NULL, offsetof(POLICY, RAFilter)}, // RAFilter
|
||||||
{24, false, false, 0, 0, 0, NULL}, // DHCPv6Filter
|
{24, false, false, 0, 0, 0, NULL, offsetof(POLICY, DHCPv6Filter)}, // DHCPv6Filter
|
||||||
{25, false, false, 0, 0, 0, NULL}, // DHCPv6NoServer
|
{25, false, false, 0, 0, 0, NULL, offsetof(POLICY, DHCPv6NoServer)}, // DHCPv6NoServer
|
||||||
{26, false, false, 0, 0, 0, NULL}, // NoRoutingV6
|
{26, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoRoutingV6)}, // NoRoutingV6
|
||||||
{27, false, false, 0, 0, 0, NULL}, // CheckIPv6
|
{27, false, false, 0, 0, 0, NULL, offsetof(POLICY, CheckIPv6)}, // CheckIPv6
|
||||||
{28, false, false, 0, 0, 0, NULL}, // NoServerV6
|
{28, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoServerV6)}, // NoServerV6
|
||||||
{29, true, true, 1, 65535, 0, "POL_INT_COUNT"}, // MaxIPv6
|
{29, true, true, 1, 65535, 0, "POL_INT_COUNT", offsetof(POLICY, MaxIPv6)}, // MaxIPv6
|
||||||
{30, false, false, 0, 0, 0, NULL}, // NoSavePassword
|
{30, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoSavePassword)}, // NoSavePassword
|
||||||
{31, true, true, 1, 4294967295UL, 0, "POL_INT_SEC"}, // AutoDisconnect
|
{31, true, true, 1, 4294967295UL, 0, "POL_INT_SEC", offsetof(POLICY, AutoDisconnect)}, // AutoDisconnect
|
||||||
{32, false, false, 0, 0, 0, NULL}, // FilterIPv4
|
{32, false, false, 0, 0, 0, NULL, offsetof(POLICY, FilterIPv4)}, // FilterIPv4
|
||||||
{33, false, false, 0, 0, 0, NULL}, // FilterIPv6
|
{33, false, false, 0, 0, 0, NULL, offsetof(POLICY, FilterIPv6)}, // FilterIPv6
|
||||||
{34, false, false, 0, 0, 0, NULL}, // FilterNonIP
|
{34, false, false, 0, 0, 0, NULL, offsetof(POLICY, FilterNonIP)}, // FilterNonIP
|
||||||
{35, false, false, 0, 0, 0, NULL}, // NoIPv6DefaultRouterInRA
|
{35, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoIPv6DefaultRouterInRA)}, // NoIPv6DefaultRouterInRA
|
||||||
{36, false, false, 0, 0, 0, NULL}, // NoIPv6DefaultRouterInRAWhenIPv6
|
{36, false, false, 0, 0, 0, NULL, offsetof(POLICY, NoIPv6DefaultRouterInRAWhenIPv6)}, // NoIPv6DefaultRouterInRAWhenIPv6
|
||||||
{37, true, true, 1, 4095, 0, "POL_INT_VLAN"}, // VLanId
|
{37, true, true, 1, 4095, 0, "POL_INT_VLAN", offsetof(POLICY, VLanId)}, // VLanId
|
||||||
};
|
};
|
||||||
|
|
||||||
// Format policy value
|
// Format policy value
|
||||||
@ -390,7 +390,7 @@ void OverwritePolicy(POLICY **target, POLICY *p)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Copy(*target, p, NUM_POLICY_ITEM_FOR_VER2 * sizeof(UINT));
|
Copy(*target, p, policy_item[NUM_POLICY_ITEM_FOR_VER2].Offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,7 @@ struct POLICY_ITEM
|
|||||||
UINT MaxValue;
|
UINT MaxValue;
|
||||||
UINT DefaultValue;
|
UINT DefaultValue;
|
||||||
char *FormatStr;
|
char *FormatStr;
|
||||||
|
UINT Offset;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Policy
|
// Policy
|
||||||
@ -144,17 +145,17 @@ struct AUTHNT
|
|||||||
|
|
||||||
// Macro
|
// Macro
|
||||||
#define POLICY_CURRENT_VERSION 3
|
#define POLICY_CURRENT_VERSION 3
|
||||||
#define NUM_POLICY_ITEM ((sizeof(POLICY) / sizeof(UINT)) - 1)
|
|
||||||
#define NUM_POLICY_ITEM_FOR_VER2 22
|
#define NUM_POLICY_ITEM_FOR_VER2 22
|
||||||
#define NUM_POLICY_ITEM_FOR_VER3 38
|
#define NUM_POLICY_ITEM_FOR_VER3 38
|
||||||
|
#define NUM_POLICY_ITEM NUM_POLICY_ITEM_FOR_VER3
|
||||||
|
|
||||||
#define IS_POLICY_FOR_VER2(index) (((index) >= 0) && ((index) < NUM_POLICY_ITEM_FOR_VER2))
|
#define IS_POLICY_FOR_VER2(index) (((index) >= 0) && ((index) < NUM_POLICY_ITEM_FOR_VER2))
|
||||||
#define IS_POLICY_FOR_VER3(index) (((index) >= 0) && ((index) < NUM_POLICY_ITEM_FOR_VER3))
|
#define IS_POLICY_FOR_VER3(index) (((index) >= 0) && ((index) < NUM_POLICY_ITEM_FOR_VER3))
|
||||||
|
|
||||||
#define IS_POLICY_FOR_CURRENT_VER(index, ver) ((ver) >= 3 ? IS_POLICY_FOR_VER3(index) : IS_POLICY_FOR_VER2(index))
|
#define IS_POLICY_FOR_CURRENT_VER(index, ver) ((ver) >= 3 ? IS_POLICY_FOR_VER3(index) : IS_POLICY_FOR_VER2(index))
|
||||||
|
|
||||||
#define POLICY_BOOL(p, i) (((bool *)(p))[(i)])
|
#define POLICY_BOOL(p, i) (*(bool *)((char *)p + policy_item[i].Offset))
|
||||||
#define POLICY_INT(p, i) (((UINT *)(p))[(i)])
|
#define POLICY_INT(p, i) (*(UINT *)((char *)p + policy_item[i].Offset))
|
||||||
|
|
||||||
extern POLICY_ITEM policy_item[];
|
extern POLICY_ITEM policy_item[];
|
||||||
|
|
||||||
|
@ -7454,7 +7454,7 @@ UINT StSetLink(ADMIN *a, RPC_CREATE_LINK *t)
|
|||||||
|
|
||||||
if (t->Policy.Ver3 == false)
|
if (t->Policy.Ver3 == false)
|
||||||
{
|
{
|
||||||
Copy(k->Policy, &t->Policy, sizeof(UINT) * NUM_POLICY_ITEM_FOR_VER2);
|
Copy(k->Policy, &t->Policy, policy_item[NUM_POLICY_ITEM_FOR_VER2].Offset);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user