#
# 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'
}
