blob: fcd9e8406d3a9e6a26482b4c452cf9664960991c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
#
# PRE: update
#
update control {
control !* ANY
}
update control {
Tmp-IP-Address-0 := 192.0.2.1
Tmp-IP-Address-0 += 192.0.2.2
}
if ("%{control:[#]}" != 2) {
update {
reply:Filter-Id += 'fail 0'
}
}
debug_control
if (("%{control:[0]}" != 192.0.2.1) || ("%{control:[1]}" != 192.0.2.2)) {
update {
reply:Filter-Id += 'fail 1'
}
}
if (("%{control:[n]}" != 192.0.2.2)) {
update {
reply:Filter-Id += 'fail 1a'
}
}
if ("%{control:[*]}" != '192.0.2.1,192.0.2.2') {
update {
reply:Filter-Id += 'fail 2'
}
}
# Try calling these xlats in mapping too, they may get optimised to VPTs which is a
# different code path.
update request {
Tmp-IP-Address-1 += "%{control:[1]}"
Tmp-IP-Address-1 += "%{control:[0]}"
Tmp-String-0 = "%{control:[*]}"
Tmp-Integer-0 = "%{control:[#]}"
}
if (Tmp-String-0 != '192.0.2.1,192.0.2.2') {
update {
reply:Filter-Id += 'fail 3'
}
}
if (Tmp-Integer-0 != 2) {
update {
reply:Filter-Id += 'fail 4'
}
}
# Boilerplate junk
update {
control:Cleartext-Password := 'hello'
reply:Filter-Id := 'filter'
}
|