AFleX Scripting Language Reference
AFleX Scripting Language Reference
0-P1
aFleX Scripting Language Reference
April, 2023
© 2023 A10 Networks, Inc. All rights reserved.
Information in this document is subject to change without notice.
PATENT PROTECTION
A10 Networks, Inc. products are protected by patents in the U.S. and elsewhere. The following website is provided
to satisfy the virtual patent marking provisions of various jurisdictions including the virtual patent marking
provisions of the America Invents Act. A10 Networks, Inc. products, including all Thunder Series products, are
protected by one or more of U.S. patents and patents pending listed at:
a10-virtual-patent-marking.
TRADEMARKS
A10 Networks, Inc. trademarks are listed at: a10-trademarks
CONFIDENTIALITY
This document contains confidential materials proprietary to A10 Networks, Inc. This document and information
and ideas herein may not be disclosed, copied, reproduced or distributed to anyone outside A10 Networks, Inc.
without prior written consent of A10 Networks, Inc.
DISCLAIMER
This document does not create any express or implied warranty about A10 Networks, Inc. or about its products or
services, including but not limited to fitness for a particular use and non-infringement. A10 Networks, Inc. has made
reasonable efforts to verify that the information contained herein is accurate, but A10 Networks, Inc. assumes no
responsibility for its use. All information is provided "as-is." The product specifications and features described in
this publication are based on the latest information available; however, specifications are subject to change without
notice, and certain features may not be available upon initial product release. Contact A10 Networks, Inc. for
current information regarding its products or services. A10 Networks, Inc. products and services are subject to A10
Networks, Inc. standard terms and conditions.
ENVIRONMENTAL CONSIDERATIONS
Some electronic components may possibly contain dangerous substances. For information on specific component
types, please contact the manufacturer of that component. Always consult local authorities for regulations
regarding proper disposal of electronic components in your area.
FURTHER INFORMATION
For additional information about A10 products, terms and conditions of delivery, and pricing, contact your nearest
A10 Networks, Inc. location, which can be found by visiting www.a10networks.com.
Table of Contents
Getting Started 20
Advantages of Using aFleX Policies 22
aFleX Processing Order 22
Packet Processing Order for Layer 4 Virtual Ports 22
Packet Processing Order for Layer 7 Virtual Ports 23
Packet Processing Example 23
When aFleX Policy Changes Take Effect 24
Support for Multiple aFleX Policies on a Single Virtual Port 24
Configure aFleX for GTP Director 24
Ruleset for Defining Payload 25
Syntax to Define Ruleset 25
Configuring aFleX for GTP Director 26
aFleX CLI Commands 36
aFleX Online Help 37
aFleX Script Rename 38
Copy aFleX Script 39
Maximum File Size of aFleX Scripts 39
Maximum Number of aFleX Scripts 40
aFleX Syntax 40
Local Variable Syntax 40
Global Variable Syntax 41
aFleX Script Components 42
aFleX Context 42
Tcl Symbols 43
Example aFleX Scripts 44
3
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
aFleX Operators 60
Logical Operators 61
and 61
not 61
or 62
Relational Operators 62
contains 63
ends_with 63
equals 64
matches 64
matches_regex 65
starts_with 66
aFleX Events 67
Overview 68
Global Events 69
RULE_INIT 70
LB_FAILED 71
LB_SELECTED 74
AAM Events 78
4
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
AAM_AUTHENTICATION_INIT 79
AAM_AUTHORIZATION_INIT 81
AAM_AUTHORIZATION_CHECK 83
AAM_RELAY_INIT 85
Database Load-Balancing Events 88
DB_COMMAND 89
DB_QUERY 90
Diameter Load-Balancing Events 93
DIAMETER_ANSWER 94
DIAMETER_ANSWER_SEND 95
DIAMETER_REQUEST 97
DIAMETER_REQUEST_SEND 98
DNS Events 101
DNS_REQUEST 102
DNS_RESPONSE 104
Financial Information eXchange Events 107
FIX_REQUEST 108
FIX_RESPONSE 109
HTTP Events 112
HTTP_RESPONSE_DATA 113
HTTP_RESPONSE_CONTINUE 117
HTTP_RESPONSE 121
HTTP_REQUEST_SEND 125
HTTP_REQUEST_DATA 129
HTTP_REQUEST 135
ICAP Events 142
ICAP_REQUEST 143
ICAP_RESPONSE 143
IP, TCP, and UDP Events 145
CLIENT_ACCEPTED 146
CLIENT_CLOSED 150
5
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
CLIENT_DATA 154
SERVER_CLOSED 159
SERVER_CONNECTED 162
SERVER_DATA 166
MQTT Events 171
MQTT_CLIENT_MESSAGE 171
MQTT_SERVER_MESSAGE_DATA 172
MQTT_SERVER_MESSAGE 173
MQTT_CLIENT_MESSAGE_DATA 175
MQTT_PUBLISH 176
MQTT_SUBSCRIBE 177
QUIC Events 179
QUIC_INITIAL 179
QUIC_CLIENT_ACCEPTED 180
QUIC_CLIENT_CLOSED 181
RAM Caching Events 183
CACHE_REQUEST 184
CACHE_RESPONSE 186
SIP Events 189
SIP_REQUEST 190
SIP_REQUEST_SEND 192
SIP_RESPONSE 195
SMTP Events 198
SMTP_MAIL 199
SMTP_EHLO 199
SSL Events 200
CLIENTSSL_CLIENTCERT 201
CLIENTSSL_CLIENTHELLO 204
CLIENTSSL_DATA 206
CLIENTSSL_HANDSHAKE 209
SERVERSSL_CLIENTHELLO_SEND 212
6
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
SERVERSSL_DATA 215
SERVERSSL_HANDSHAKE 217
SERVERSSL_SERVERCERT 220
SERVERSSL_SERVERHELLO 221
WAF Events 224
WAF_REQUEST_DENY 225
WAF_REQUEST_VIOLATION 227
WAF_RESPONSE_VIOLATION 229
7
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
members 249
nexthop 250
md5 251
node 251
ntohl 252
ntohs 252
persist 253
pool 257
reject 258
return 259
serverside 259
session 260
set encode 261
sha1 262
sha256 262
snat 262
snatpool 263
string map 264
session 265
sha1 266
sha256 266
snat 267
snatpool 268
substr 269
switch 270
use 273
virtual 274
when 274
whereis 275
Global Variable Commands 280
array 281
8
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
get 281
incre 282
Valid Events: 282
set 282
unset 282
AAM Commands 284
AAM::attribute 285
AAM::attribute_collection 286
AAM::authentication 287
AAM::authorization 289
AAM::bypass 290
AAM::client 291
AAM::relay 292
AAM::saml 293
AAM::session 295
Example AAM aFleX Scripts 296
Example 1: Processing aFlex Commands in AAM_AUTHORIZATION_CHECK Event 297
Example 2: Classifying AAA Policy Result while Authenticating and Authorizing 298
Example 3: Setting Authentication Service-group by Requested Domain 298
Example 4: Setting Authorization Server by Client IP Address 299
Example 5: Selecting Domain-based Auth Server 299
Example 6: Get Scripts for Domain-based Auth Server Selection 301
Example 7: Getting a constructed JWT from a Session 302
Application Firewall Commands 304
APPCLS::application 305
AES Commands 307
AES::decrypt 308
AES::encrypt 309
AES::key 310
Category Commands 311
CATEGORY::lookup 312
9
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
10
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
DNS::opt 346
DNS::query 347
DNS::question 347
DNS::rdata 348
DNS::return 349
DNS::rr 350
DNS::ttl 351
DNS::type 351
Financial Information eXchange Commands 352
FIX::begin_string 353
FIX::body_length 353
FIX::msg_seq_num 354
FIX::msg_type 354
FIX::sender_compid 355
FIX::sending_time 355
FIX::target_compid 356
HTTP Commands 358
HTTP::close 360
HTTP::collect 360
HTTP::cookie 363
HTTP::disable 366
HTTP::fallback 368
HTTP::header 368
HTTP::host 371
HTTP::is_keepalive 371
HTTP::is_redirect 372
HTTP::method 373
HTTP::path 373
HTTP::password 374
HTTP::payload 375
HTTP::query 376
11
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
HTTP::redirect 376
HTTP::release 377
HTTP::request 378
HTTP::request_num 379
HTTP::respond 379
HTTP::retry 381
HTTP::status 381
HTTP::stream 382
HTTP::uri 383
HTTP::username 384
HTTP::version 385
ICAP Commands 386
ICAP::disable 387
ICAP::header add 387
ICAP::header remove 388
ICAP::header values 388
ICAP::header replace 389
ICAP::header replace-all 389
ICAP::method 390
ICAP::status 390
ICAP::respmod_valid 391
ICAP::reqmod_valid 391
ICAP::uri 392
IP Commands 393
IP::addr 394
IP::category 395
IP::client_addr 396
IP::local_addr 397
IP::protocol 398
IP::remote_addr 399
IP::reputation 400
12
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
IP::server_addr 401
IP::stats 402
IP::tos 402
IP::ttl 403
IP::version 404
Limit ID Commands 406
LID::conn_limit 407
LID::conn_rate_limit 408
LID::exists 409
LID::nat_pool 410
LID::request_limit 411
LID::request_rate_limit 412
LID::type 413
Link Commands 415
LINK::lasthop 416
LINK::nexthop 416
LINK::vlan_id 417
Load-balancing Commands 418
LB::down 419
LB::reselect 419
LB::server 421
LB::status 423
MQTT Commands 426
MQTT::clean_session_flag 428
MQTT::client_id 428
MQTT::collect 429
MQTT::drop 429
MQTT::dup_flag 430
MQTT::keep_alive 430
MQTT::length 431
MQTT::packet_id 431
13
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
MQTT::password 432
MQTT::payload 432
MQTT::payload_length 434
MQTT::protocol_name 434
MQTT::protocol_version 435
MQTT::qos 435
MQTT::replace 437
MQTT::respond 437
MQTT::retain_flag 438
MQTT::return_code 438
MQTT::return_code_list 439
MQTT::session_present_flag 439
MQTT::topic 440
MQTT::type 442
MQTT::username 443
MQTT::will 443
QUIC Commands 446
QUIC::CID 446
QUIC::version 446
Policy-Based SLB Commands 448
POLICY::bwlist id 449
POLICY::source_rule 450
RADIUS Message Load-balancing Commands 451
RADIUS::avp 452
RADIUS::code 452
RADIUS::id 453
RADIUS::length 453
RAM Caching Commands 455
CACHE::age 456
CACHE::disable 456
CACHE::enable 457
14
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
CACHE::expire 458
CACHE::headers 459
CACHE::hits 459
Resolve Commands 460
RESOLVE::lookup 461
SIP Commands 464
SIP::call_id 465
SIP::from 465
SIP::header 466
SIP::method 467
SIP::respond 467
SIP::response 468
SIP::to 469
SIP::uri 469
SIP::via 470
SIP Command Examples 471
Example 1 471
Example 2 474
Example 3 475
SMTP Commands 478
SMTP::mail 479
SMTP::greet 479
SMTP::ehlo 480
SSL Commands 481
SSL::authenticate 482
SSL::cert 483
SSL::cipher 484
SSL::collect 485
SSL::disable 486
SSL::enable 487
SSL::extensions 487
15
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
SSL::hostname 488
SSL::mode 489
SSL::payload 489
SSL::release 491
SSL::renegotiate 492
SSL::respond 493
SSL::session invalidate 494
SSL::sessionid 495
SSL::template 496
SSL::verify_result 497
SSLI::bypass 497
SSLI::cache_cert 498
SSLI::inspect 499
SSLI::drop 499
Statistics Commands 501
STATS::clear 502
STATS::get 503
Table Commands 505
table add 507
table append 507
table delete 508
table incr 508
table keys 509
table lifetime 509
table lookup 510
table replace 510
table set 511
table timeout 511
Table Examples 512
Example 1 512
Example 2 513
16
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
Example 3 514
TCP Commands 516
TCP::client_port 517
TCP::close 518
TCP::collect 519
Support for Generic TCP Proxy 520
TCP::collect <length> 520
TCP::collect 521
Server Selection Behavior if TCP::collect [<length>] Command Is Not Used with Generic TCP-
Proxy Traffic 521
Additional Generic TCP-Proxy Examples 522
TCP::local_port 524
TCP::mss 527
TCP::notify 528
TCP::offset 529
TCP::option 529
TCP::payload 533
TCP::release 534
TCP::remote_port 535
TCP::respond 536
TCP::rtt 537
TCP::server_port 539
Template Commands 540
TEMPLATE::cache 541
TEMPLATE::client_ssl 542
TEMPLATE::conn_reuse 543
TEMPLATE::exists 544
TEMPLATE::http 545
TEMPLATE::server_ssl 547
TEMPLATE::tcp 548
TEMPLATE::udp 548
17
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
18
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide
Contents
X509::serial_number 580
X509::signature_algorithm 581
X509::subject 581
X509::subject_public_key 582
X509::subject_public_key_RSA_bits 582
X509::subject_public_key_type 583
X509::text 583
X509::verify_cert_error_string 584
X509::version 585
X509::whole 585
19
Getting Started
The aFleX scripting language is a powerful inline custom scripting engine that
provides in-depth, granular control of inspection and redirection policies (filter,
drop, redirect). The aFleX scripting language is based on the Tool Command
Language (Tcl) programming standard for simplicity and familiarity. For an aFleX
policy to work, it must be bound to a virtual port on the ACOS device. Then the
aFleX policy can make policy decisions by inspecting the payload packets from all
the traffic going through the virtual port.
Below is an example of a simple aFlex script:
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.1] } {
pool www_service_group
}
}
The chapters provide detailed information about working with aFleX policies.
20
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
21
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
22
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
NOTE: Server template limits are applied for both service-group and server
selection. Commands that call for server selection (i.e., “node”, “pool”,
“persist”, etc.) will enforce server template limits on the selected
server. As a result, new connections that match a persist uie entry may
be unable to use the rport and a default server selection will occur
instead. To prevent default server selection, use the def-selection-
if-pref-failed-disable command for the vport.
23
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
24
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
The ruleset for match type is added in the following aFleX example:
set::RuleSets {
1:imsi-e-3930:apn-s-int:pdna-q-0.0.0.0:sg2
71:mei-e-4916:apn-s-int:pdn-q-3:sg2
72:mei-e-4916:apn-s-int:ambruplink-q-150000:ambrdownlink-q-800000:sg2
75:mei-e-4916:apn-s-int:pdn-q-3:sg2
76:imsi-e-3930:apn-s-int:msisdn-e-066821:sg2
25
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
79:mei-e-4916:apn-s-int:pdna-q-0.0.0.0:sg2
82:imsi-e-3930:apn-s-int:rat-q-6:sg2
83:imsi-e-3930:apn-s-int:mcc-e-440:mnc-e-10:sg2
86:imsi-e-3930:apn-s-int:tac-e-85:tcellid-e-641:sg2
87:imsi-e-3930:apn-s-int:fteidkey-e-4eeb:fteid-q-49.103.66.36:sg2
95:imsi-e-3930:apn-s-int:cc-e-a00:sg2
99:mei-e-4916:apn-s-int:pdn-q-3:sg2
ii. Copy and paste the aFlex and insert ‘. ‘ (Dot) at the end
Example:
ACOS(config)#aflex create test1
NOTE: Type in your aFleX script (type ‘.’ on a line by itself when
done)
when HTTP_REQUEST {
HTTP::redirect https://[HTTP::host][HTTP::uri]
}
26
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
.
aFleX test1 created; syntax check passed
ACOS(config)#
27
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
28
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
29
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
30
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
31
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
NOTE:
l Only GTPv1-C and GTPv2-C is supported.
l The rule set defined is not in preferential order. However, the match
is done in the order in which the ruleset is configured and the first
match is chosen
l Up to 64 sets of match criteria are supported.
l Up to 16 service-groups are supported and if none of the configured
set of Match criteria is matched, then the default service-group
configured under the VIP is used to select one of the PGW’s.
The following fields are extracted and can be used to match the GTPv1 requests.
32
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
33
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
34
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
35
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
Example:
The packet can contain IMSI, MEI, MCC, MNC. Another packet might contain IMSI,
MEI, RAT.
36
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
NOTE: aFleX help information is available through the CLI only and not
accessible from the GUI.
Command Description
aflex help events View help for aFleX events.
aflex help global View help for aFleX global commands.
aflex help operators View help for aFleX operators.
aflex help command View help for a specific aFleX command.
TIME::clock seconds
- Returns the current time in the unit of seconds. The function is used
in SMP environment for high-performance processing.
TIME::clock milliseconds
37
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
38
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
The list of aFleX scripts reappears showing the new name. The GUI also automatically
updates the aFleX name everywhere the script is used. For example, if the script is
already bound to a virtual port, the script’s name is automatically updated in the
virtual port’s configuration. You do not need to manually update the virtual port
configuration.
NOTE: Scripts that contain syntax errors cannot be copied. The CLI console
notifies you if copy failure is due to a syntax error.
39
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
aFleX Syntax
An aFleX script is a Tcl-like script. Every command call has the following form:
command arg1 arg2 arg3 ...
The aFleX interpreter takes each word of command call and evaluates it. After
evaluation of each word, the first word (command) is considered to be a function
name. The function is executed with the rest of the words as arguments.
If a word is surrounded by curly braces { }, this word is unaffected and the
substitution is thus not applicable. Inside the braces, there may be spaces and
carriage returns. The { } may also be nested.
The first line beginning with set c sets the value of the specified local variable. The
local variable is only used within the current aFleX script. Replace “example text”
with the value you want to set for c; each variable must be set first before it can be
called.
The aFleX interpreter sees the remainder of this script as 5 words:
40
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
The first word, ' if', is taken as the command and this command is executed with the
4 following words as parameters. Later, the condition ' $c == "Exit"' is evaluated,
during the execution of the if command.
Use unset c to unset the local variable.
In the line beginning with set client_ip 10.10.10.10, client_ip is a local variable, as
previously discussed, which can be used within the current script. The next line
beginning with table set active_clients $client_ip 1 sets a global table variable named active_
clients with a key of $client_ip and a value of “1.” Replace the name, key, and
value with the terminology of your choice. Global table variables can be used by all
aFleX scripts.
41
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
aFleX Context
aFleX scripts support context for specifying either client or server side:
l Each event has a default context of either client-side or server-side.
l Key words: “clientside” or “serverside”
l Only specify the context keywords if you want to change default context.
Example This aFleX script uses the default CLIENT side association to the
REMOTE_ADDR. Because CLIENT_ACCEPTED has a default context of
clientside, the remote_addr field is automatically assigned to clientside.
when CLIENT_ACCEPTED {
if { [IP::addr [IP::remote_addr] equals 192.168.18.8] } {
pool www_service_group
}
}
To change the default context of any aFleX script, use the clientside
or serverside key words.
Example This aFleX policy switches the remote_addr field to the clientside from
the default serverside association with the SERVER_CONNECTED event.
when CLIENT_ACCEPTED {
if { [IP::addr [ clientside {IP::remote_addr}] equals
192.168.80.81 ] } {
pool www_service_group
}
42
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
Tcl Symbols
The Tcl symbols listed in Table 5 have special meanings.
NOTE: Not all Tcl commands and symbols are supported. See Disabled Tcl
Commands.
43
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
Example Node Selection—This aFleX script uses the node command to select one
specific server to send the traffic to.
when HTTP_REQUEST {
if { [HTTP::uri] ends_with ".gif" } {
node 192.168.100.10 80
}
}
Example IP Packet Header Query (IP Address)—This example shows that the
traffic from client in 192.168.0.0/16 subnet is directed to a special
service group called “192_168_service_group”.
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.0.0/16] }
{
pool 192_168_service_group
} else {
pool www_service_group
}
}
Example IP Packet Header Query (ToS Level)—This example shows the ToS field
being inspected for clientside ToS value of “16”.
when CLIENT_ACCEPTED {
if { [IP::tos] == 16 } {
pool priority_service_group
44
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Getting Started
} else {
pool www_service_group
}
}
Example TCP Query—This aFleX script uses the payload field to check for the
words TOP or BOT to properly redirect traffic.
when CLIENT_DATA {
if { [TCP::payload] contains "TOP" } {
pool top_service_group
} elseif { [substr[TCP::payload] 50, 3] equals "BOT" } {
pool bot_service_group
} else {
pool www_service_group
}
}
45
Applying aFleX Scripts To Virtual Ports
NOTE: You do not need to unbind an aFleX script before renaming it. The
ACOS device automatically updates the configuration wherever the
renamed script is used. For more information, see aFleX Script
Rename.
46
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
Now, the vport is not automatically marked UP when the aFleX policy is bound,
and the vport status will depend on the service group status as usual.
NOTE: For virtual port type fast-HTTP, aFleX commands that change the HTTP
header or payload are not supported.
47
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
NOTE: These scripts are intended for educational purposes to assist new
users. A10 Networks does not guarantee the sample scripts will work in
all contexts and is not liable for damages that result from the
misapplication of preloaded aFleX scripts.
48
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
You can specify one script with the command. Repeat the command for each
additional script to add.
The scripts will be processed in the order you add them, starting with the first script
you add. To re-order the scripts, do either of the following:
l Use the GUI. (See Configure using GUI.)
l In the CLI, use the no aflex name command to remove the scripts from the virtual
port, then re-add them in the correct order.
CLI Example
The example mentioned below explains how to import an aFleX policy onto the ACOS
device and bind it to a virtual port.
when RULE_INIT {
array set sg_array [list "youtube.com" "sg1" "google.com" "sg2"
"zynga.com" "sg2"]
}
when HTTP_REQUEST {
set host [HTTP::host]
if { [info exists $sg_array($host)] } {
log "host $host -> pool $sg_array($host)"
pool $sg_array($host)
}
}
49
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
1. Log on to the ACOS device through the CLI, and access Global configuration
mode.
ACOS>enable
Password:
ACOS#config
ACOS(config)#
50
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
4. Use the import command to import the aFleX policy (“test.afx”) onto the ACOS
device and rename it “my_aflex”:
ACOS(config)#import aflex my_aflex scp://192.168.1.118/aflex/test.afx
User name []?***
Password []?***
Importing ... Done.
ACOS(config)#
While importing the aFleX policy, the ACOS device checks for syntax errors. If any
syntax errors are found, error messages are displayed. You can modify an aFleX
policy and import it again until it passes the syntax check.
5. Use the show aflex command to view all aFleX policies on the ACOS device:
ACOS(config)#show aflex
Total aFlex number: 7
Max aFlex file size: 32K
51
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
6. To display the aFleX policy, use the show aflex aflex-name command:
ACOS(config)#show aflex my_aflex
when RULE_INIT {
array set ::SG_ARRAY [list "youtube.com" "sg1" "google.com" "sg2"
"zynga.com" "sg2"]
}
when HTTP_REQUEST {
set host [HTTP::host]
if { [info exists ::SG_ARRAY($host)] } {
log "host $host -> pool $::SG_ARRAY($host)"
pool $::SG_ARRAY($host)
}
}
7. Configure a virtual server and bind the aFleX policy to a virtual port on the virtual
server:
ACOS(config)#slb virtual-server v30 10.10.8.30
ACOS(config-slb vserver)#port 80 http
ACOS(config-slb vserver-vport)#aflex my_aflex
ACOS(config-slb vserver-vport)#exit
ACOS(config-slb vserver)#exit
ACOS(config)#
8. Show the aFleX policy list again to verify that the aFleX policy is now bound to a
virtual port:
ACOS(config)#show aflex
Total aFlex number: 7
Max aFlex file size: 32K
52
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
53
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
The CLI enters the input mode for the script text.
2. Type or copy-and-paste the script. If you type the script, use the Enter key at the
end of each line.
3. To complete the input process, type “ . ” (period) on a separate line and press
Enter.
NOTE:
l You do not need to save the configuration (write memory) to save
the aFleX script. The script is automatically added to a persistent
data folder and remains available across reboots.
l Regardless of how an aFleX script is added to the ACOS device, the
script does not take effect until you apply it to a virtual port.
Syntax Check
After you finish entering the script text, the CLI performs a syntax check and displays
one of the following messages:
l aFleX aflex-name created; syntax check passed. – Indicates the syntax is
valid.
l aFleX aflex-name created; syntax check failed. – Indicates the syntax is not
valid. In this case, see Troubleshooting aFleX Syntax Errors.
l This aFleX already exists. – Indicates that another aFleX script with the same
name is already on the ACOS device.
54
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
The same name can be used in different partitions, but must be unique within a
given partition.
55
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
NOTE: You edit an aFleX policy by clicking Edit in the Actions column next to
that aFleX policy’s name. You can delete an existing aFleX policy by
selecting the checkbox located on the left of its name, then clicking
Delete .
56
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
NOTE: You edit an aFleX policy by clicking Edit in the Actions column next to
that aFleX policy’s name. You can delete an existing aFleX policy by
selecting the checkbox located on the left of its name, then clicking
Delete .
57
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
In this case, you can fix the script using either CLI or GUI.
58
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Applying aFleX Scripts To Virtual Ports
59
aFleX Operators
60
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Operators
Logical Operators
Logical operators are used to compare numeric values to one another. They are
compatible with all the events, and compatible with any command that has a
numeric value (as opposed to a string value).
The following logical operators are supported:
l and
l not
l or
and
Description Performs a logical “and” comparison between two values.
Example Use the following example to compare the values for HTTP::host and
HTTP::uri:
when HTTP_REQUEST {
if { ([HTTP::host] equals "www.example.com") and ([HTTP::uri] starts_
with "/blog") } {
pool www_service_group
} else {
pool static_service_group
}
}
not
Description Performs a logical “not” on a value.
61
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Operators
Example Use the following example to see if HTTP::uri does not start with a
specified string:
when HTTP_REQUEST {
if { not ([HTTP::uri] starts_with "/images") } {
pool www_service_group
} else {
pool static_service_group
}
}
or
Description Performs a logical “or” comparison between two values.
Relational Operators
Relational operators are used to compare strings to one another. They are
compatible with all events, and compatible with any command that has a string value
(as opposed to a numeric value).
The following relational operators are supported:
l contains
l ends_with
62
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Operators
l equals
l matches
l matches_regex
l starts_with
contains
Description Tests whether one string (string1) contains another string (string2).
ends_with
Description Tests whether one string (string1) ends with another string (string2).
Example Use the following example to test if HTTP::uri ends with “.html” or
“.asp”:
when HTTP_REQUEST {
if { [HTTP::uri] ends_with ".html" } {
pool static_service_group
} elseif { [HTTP::uri] ends_with ".asp" } {
pool dynamic_service_group
}
}
63
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Operators
equals
Description Tests whether one string equals another string.
Example Use the following example to test if the domain of HTTP::host equals
“com”:
when HTTP_REQUEST {
if { [domain [HTTP::host] 1] equals "com" } {
pool www_service_group
}
}
matches
Description Tests whether one string matches another string.
NOTE: The matches operator uses the same comparison as the Tcl "string
match" command, which functions like a cut-down regular expression.
For the two strings to match, their contents must be identical except
that the following special sequences may appear in the pattern:
• * – Matches any sequence of characters in string, including a null
string.
• ? – Matches any single character in string.
• [chars] – Matches any character in the set given by chars. If a
sequence of the form x-y appears in chars, then any character
between x and y, inclusive, will match. When used with -nocase,
the end points of the range are converted to lower case first.
Whereas {[A-z]} matches '_' when matching case-sensitively ('_'
falls between the 'Z' and'a'), with -nocase this is considered to be
like {[A-Za-z]}.
64
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Operators
matches_regex
Description Tests whether one string matches a regular expression or another
string.
65
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Operators
starts_with
Description Tests whether one string (string1) starts with another string (string2).
Example Use the following example to test if HTTP::uri starts with “/static”:
when HTTP_REQUEST {
if { [HTTP::uri] starts_with "/static" } {
pool static_service_group
} else {
pool dynamic_service_group
}
}
66
aFleX Events
The following categories of aFleX events are available:
l Global Events
l AAM Events
l Database Load-Balancing Events
l Diameter Load-Balancing Events
l DNS Events
l Financial Information eXchange Events
l HTTP Events
l ICAP Events
l IP, TCP, and UDP Events
l MQTT Events
l RAM Caching Events
l SIP Events
l SMTP Events
l SSL Events
l WAF Events
67
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Overview
aFleX scripts are event-driven. The ACOS device triggers an aFleX policy based on a
specified event. For example, if an aFleX policy is configured to be triggered by the
HTTP_REQUEST event, the ACOS device triggers the aFleX policy when an HTTP
request is received.
Event declarations are made with the “when” keyword followed by the event name.
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::remote_addr] equals 192.168.1.80 ] } {
pool example_service_group
}
}
For information about other script components, see aFleX Script Components.
68
Global Events
This section describes the global events.
For information about aFleX events, see aFleX Events.
69
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
RULE_INIT
Description Use this event to immediately set global system variables; when an
aFleX script containing a RULE_INIT event is added to the virtual server
port, the RULE_INIT event is immediately triggered and global variables
are set.
The prefix placed before the variable specifies the variable scope. It
specifies whether to initialize that variable for all aFleX policies, or only
for the current aFleX policy.
Prefix Scope
:: Applies in the same aFlex policy. This variable
cannot be set or read by any other aFlex
policies. Once a global variable is defined, it
cannot be deleted.
::global:: Applies to all aFleX policies. This variable can be
set or read by all aFleX policies on the ACOS
device regardless of partition or CPU.
In the current release, it is recommended to avoid using the unset command to unset
global variables. Doing so may cause a problem. Use table create/delete instead.
70
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• unset
LB_FAILED
Description Execute specific aFleX commands when the ACOS device is not able to
select a node for the incoming request (for example, if all nodes in the
pool are down or all their connection limits have been reached).
When this event is used with aFleX scripts bound to TCP virtual ports,
it is triggered by the following conditions:
• The selected server is unreachable (no route host).
• The selected server is non-responsive (fails to respond to a
connection request)
• The selected server sent a TCP Reset. In order to enable this
trigger, configure inband-health-check resel-on-reset on a port
template attached to the service group or real server port
associated with the virtual port.
71
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• CLASS::match
• CLASS::names
• CLASS::type
72
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• cpu usage
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• pool
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
73
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to add a node to the error service group
“backup_service_group” when it fails.
when LB_FAILED {
pool backup_service_group
}
LB_SELECTED
Description Execute specific aFleX commands when a pool member is selected.
74
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• IP::version
75
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• snat
• snatpool
• string map
• substr
• switch
• use
• virtual
• whereis
76
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to add a pool member to a source NAT pool
when the member is selected.
when LB_SELECTED {
if { [IP::addr [IP::remote_addr] equals "192.168.8.8"] } {
snatpool snat-internal
}
}
77
AAM Events
This section describes the Authentication Authorization Management (AAM) events.
l For information about aFleX events, see aFleX Events.
l For information about AAM commands, see AAM Commands.
NOTE: aFleX scripts containing AAM events are only valid on HTTP and HTTPS
virtual ports. Also, AAM events are not triggered for OCSP
configurations.
78
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
AAM_AUTHENTICATION_INIT
Description Execute specific aFleX scripts in preparation for AAM authentication
and relay.
79
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
80
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to append a different prefix to the username
for authentication and relay. The ACOS device will use the username
AUTH_$name for authentication, RELAY_$name for relay, and $name for
authorization.
when AAM_AUTHENTICATION_INIT {
set name [AAM::client get username]
AAM::authentication set username "AUTH_$name"
AAM::relay set username "RELAY_$name"
}
AAM_AUTHORIZATION_INIT
Description Execute specific aFleX scripts in preparation for AAM authentication
and relay.
81
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
82
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example
AAM_AUTHORIZATION_CHECK
Description Execute specific aFleX commands for AAM authorization.
83
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
84
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
AAM_RELAY_INIT
Description Execute specific aFleX scripts in preparation for AAM relay.
85
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
86
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to append a different prefix to the username
for relay. The ACOS device will append AUTH_ to the username, and set
this new username to $relay_name for relay.
when AAM_RELAY_INIT {
set relay_name "AUTH_"
append relay_name [AAM::relay get username]
AAM::relay set username $relay_name
}
87
Database Load-Balancing Events
This section describes the database load-balancing (DBLB) events.
l For information about aFleX events, see aFleX Events.
l For information about DBLB commands, see Database Load-Balancing Commands.
88
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
DB_COMMAND
Description Execute specific aFleX commands when an SQL command is sent by the
client.
89
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• reject
• return
• serverside
• set encode
• sha1
• snat
• string map
• substr
• switch
• use
• virtual
DB_QUERY
Description Execute specific aFleX commands when a full SQL query is received from
the client.
90
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• snat
• string map
• substr
• switch
• use
• virtual
91
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
when DB_QUERY {
set ret [string tolower [ DB::query ]]
# log "aflex script got que\
ry: $ret"
if { ($ret starts_with "insert") or ($ret starts_with
"update") or ($ret starts_with "delete") } {
log "aflex got a write command: $ret"
pool sg-mysql-write
} else {
log "aflex got a read command: $ret"
pool sg-mysql-read }
}
when DB_COMMAND {
set ret [ DB::command ]
log "aflex script got command number: $ret"
pool sg-mysql-write
}
92
Diameter Load-Balancing Events
This section describes the diameter load-balancing events.
For information about aFleX events, see aFleX Events.
For information about diameter load-balancing commands, see Diameter Load-
Balancing Commands.
93
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
DIAMETER_ANSWER
Description Execute specific aFleX commands when a complete Diameter answer
message is fully parsed.
94
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to create a log entry whenever a Diameter
answer message is fully parsed.
when DIAMETER_ANSWER {
log "DIAMETER::cmd_code = [DIAMETER::cmd_code]"
}
DIAMETER_ANSWER_SEND
Description Execute specific aFleX commands immediately before a Diameter
answer is sent.
95
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
96
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• virtual
Example Use the following example to create a log entry immediately before a
Diameter answer is sent.
when DIAMETER_ANSWER_SEND {
log "DIAMETER::cmd_code = [DIAMETER::cmd_code]"
}
DIAMETER_REQUEST
Description Execute specific aFleX commands when a complete Diameter request
message is fully parsed.
97
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to create a log entry whenever a Diameter
request message is fully parsed.
when DIAMETER_REQUEST {
log "DIAMETER::cmd_code = [DIAMETER::cmd_code]"
}
DIAMETER_REQUEST_SEND
Description Execute specific aFleX commands immediately before a Diameter
request is sent.
98
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• DIAMETER::app_id
• DIAMETER::avp
• DIAMETER::cmd_code
• DIAMETER::length
• DIAMETER::version
99
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• sha1
• string map
• substr
• switch
• use
• virtual
Example To check the Origin-Realm value inside the incoming Diameter Request,
send a Diameter Response 3003 (Intended Realm is not recognized) back
to client if it is not "test.com".
when DIAMETER_REQUEST {
set dropflag 0
if { !\([DIAMETER::avp [DIAMETER::avp get_ids 296] value]
equals "test.com")}{
log " flag if Diameter AVP Origin-Realm is NOT test.com "
set dropflag 1
}
}
when DIAMETER_ANSWER_SEND {
if { $dropflag } {
log "Remove server response code and return code 3003 to
client "
DIAMETER::avp [DIAMETER::avp get_ids 268] delete
DIAMETER::avp insert 268 3003 -M-
}
when DIAMETER_REQUEST_SEND {
log "DIAMETER::cmd_code = [DIAMETER::cmd_code]"
}
100
DNS Events
The following DNS events are available:
l DNS_REQUEST
l DNS_RESPONSE
101
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
DNS_REQUEST
Description Execute specific aFleX commands when DNS request packets arrive.
102
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
103
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following command to log the length of DNS queries received:
when DNS_REQUEST {
log "DNS Len: [DNS::len]"
}
DNS_RESPONSE
Description Execute specific aFleX commands when DNS reply packets arrive.
104
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• DNS::header
• DNS::is_dnssec
• DNS::len
• DNS::name
• DNS::query
• DNS::question
• DNS::rdata
• DNS::return
• DNS::rr
• DNS::ttl
• DNS::type
•
105
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to log the length of DNS reply packets
received.
when DNS_RESPONSE {
log "DNS Len: [DNS::len]"
}
106
Financial Information eXchange Events
The following Financial Information eXchange (FIX) events are available:
l FIX_REQUEST
l FIX_RESPONSE
107
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
FIX_REQUEST
Description Execute specific aFleX commands when a FIX request is received.
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
108
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
when FIX_REQUEST {
if { [FIX::sender_compid] eq "CLIENT1" } {
pool fix_client_service_group
}
}
FIX_RESPONSE
Description Execute specific aFleX commands when a FIX response is received.
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
109
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
110
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to log FIX information as specified when a
FIX response is received.
when FIX_RESPONSE {
log "[FIX::sender_compid] -> [FIX::target_compid]"
}
111
HTTP Events
The following HTTP events are available:
l HTTP_RESPONSE_DATA
l HTTP_RESPONSE_CONTINUE
l HTTP_RESPONSE
l HTTP_REQUEST_SEND
l HTTP_REQUEST_DATA
l HTTP_REQUEST
112
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
HTTP_RESPONSE_DATA
Description Execute specific aFleX commands when an HTTP::collect command
finishes processing on the server side of a connection.
NOTE: This event is also triggered if the server closes the connection before
the HTTP:collect command finishes processing.
113
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
114
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• HTTP::release
• HTTP::request
• HTTP::request_num
• HTTP::respond
• HTTP::retry
• HTTP::status
• HTTP::stream
• HTTP::version
115
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
116
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
HTTP_RESPONSE_CONTINUE
Description Execute specific aFleX commands whenever the system receives a 100
Continue response from the server.
117
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to create a log entry whenever a “100-
Continue” response is received from the server and the HTTP version is
other than 1.1:
when HTTP_RESPONSE_CONTINUE {
if { [HTTP::version] != 1.1 } {
log "Bad server: sent 100-Continue to non-1.1 client."
}
}
118
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• COMPRESS::enable
• COMPRESS::gzip
119
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• clientside
• cpu usage
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
120
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
HTTP_RESPONSE
Description Execute specific aFleX commands when all of the response status and
header lines from the server response are parsed.
121
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• CLASS::match
• CLASS::names
• CLASS::type
122
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• IP::client_addr
• IP::local_addr
• IP::protocol
• IP::remote_addr
• IP::server_addr
• IP::tos
• IP::ttl
• IP::version
123
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• TCP::rtt
• TCP::server_port
124
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• session
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
HTTP_REQUEST_SEND
Description Execute specific aFleX commands immediately before a request is sent
to a server. This is a server-side event.
125
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• AAM::client
• AAM::session
126
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• IP::ttl
• IP::version
127
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• X509::hash
• X509::issuer
• X509::not_valid_after
• X509::not_valid_before
• X509::serial_number
• X509::signature_algorithm
• X509::subject
• X509::subject_public_key
• X509::subject_public_key_RSA_bits
• X509::subject_public_key_type
• X509::text
• X509::verify_cert_error_string
• X509::version
• X509::whole
128
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• members
• nexthop
• ntohl
• ntohs
• persist
• pool
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
Example Use the following example to begin collecting TCP data immediately
before an HTTP request is sent to a server.
when HTTP_REQUEST_SEND {
HTTP::collect
}
HTTP_REQUEST_DATA
Description Execute specific aFleX commands when an HTTP::collect command is
finished processing.
129
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• AAM::session
130
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• HTTP::payload
• HTTP::query
• HTTP::redirect
• HTTP::release
• HTTP::request
• HTTP::request_num
• HTTP::respond
• HTTP::retry
• HTTP::status
• HTTP::stream
• HTTP::uri
• HTTP::username
• HTTP::version
131
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• LID::conn_rate_limit
• LID::exists
• LID::nat_pool
• LID::request_limit
• LID::request_rate_limit
• LID::type
132
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• URI::decode
• URI::encode
• URI::path
• URI::query
133
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• cpu usage
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• lwnode
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• pool
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
134
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to record a persist variable after data is
collected by the HTTP::collect command, then log the recorded
variable.
when HTTP_REQUEST_DATA {
set rpc_var [findstr [HTTP::payload] "Authorization:" 14
20]
persist uie $rpc_var
log "Persist UIE: $rpc_var"
HTTP::release
}
HTTP_REQUEST
Description Execute specific aFleX commands when a complete client request
header (method, URI, version, and all headers, not including the body)
is parsed.
135
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• CACHE::age
• CACHE::disable
• CACHE::enable
• CACHE::expire
• CACHE::headers
• CACHE::hits
136
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• HTTP::query
• HTTP::redirect
• HTTP::release
• HTTP::request
• HTTP::request_num
• HTTP::respond
• HTTP::retry
• HTTP::status
• HTTP::stream
• HTTP::uri
• HTTP::username
• HTTP::version
137
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• LID::exists
• LID::nat_pool
• LID::request_limit
• LID::request_rate_limit
• LID::type
138
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• URI::path
• URI::query
139
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• lwnode
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• pool
• reject
• return
• serverside
• session
• set encode
• sha1
• snat
• snatpool
• string map
• substr
• switch
• use
• virtual
• whereis
140
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to redirect the client to HTTPS if a client
request URI contains the string "secure":
when HTTP_REQUEST {
if { [HTTP::uri] contains "secure" } {
HTTP::redirect "https://[HTTP::host][HTTP::uri]"
}
}
Example Use this example to group traffic based on the WebDAV method in the
HTTP request header.
when HTTP_REQUEST {
if { not ([HTTP::method] equals "PROPFIND") } {
if { [IP::addr [IP::client_addr] equals
192.168.1.0/24] } {
pool davwriters_service_group
}
} else {
pool davreaders_service_group
}
}
141
ICAP Events
The following global events are available:
l ICAP_REQUEST
l ICAP_RESPONSE
142
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
ICAP_REQUEST
Description Triggered when ICAP command is created but before being sent to ICAP
server.
Usage
• ICAP::header add
• ICAP::header remove
• ICAP::header replace
• ICAP::header replace-all
• ICAP::method
• ICAP::uri
Example
when ICAP_REQUEST {
ICAP::uri icap://A10icap:1344/echo
}
ICAP_RESPONSE
Description Triggered after ICAP response has been processed but before result is
sent to the virtual server.
Usage
• ICAP::header values
• ICAP::status
• HTTP::close
• HTTP::cookie
• HTTP::header
• HTTP::host
143
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• HTTP::is_redirect
• HTTP::method
• HTTP::path
• HTTP::redirect
• HTTP::request_num
• HTTP::respond
• HTTP::status
• HTTP::uri
Example
when ICAP_RESPONSE {
log "ICAP response code is [ICAP::status]"
log "ISTag header value is [ICAP::header values ISTag]"
}
144
IP, TCP, and UDP Events
The following events related to IP, TCP and UDP traffic are available:
l CLIENT_ACCEPTED
l CLIENT_CLOSED
l CLIENT_DATA
l SERVER_CLOSED
l SERVER_CONNECTED
l SERVER_DATA
145
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
CLIENT_ACCEPTED
Description Execute specific aFleX commands when a client establishes a connection
with the ACOS device.
NOTE: For UDP (and only UDP), the CLIENT_ACCEPTED event is triggered on the
first UDP packet received.
146
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• DIAMETER::avp
• DIAMETER::cmd_code
• DIAMETER::length
• DIAMETER::version
147
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• LINK::vlan_id
Related Information
• TCP::remote_port
• TCP::respond
148
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• b64decode
• b64encode
• clientside
• cpu usage
• discard
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• lwnode
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• pool
• reject
• return
• serverside
• session
• set encode
• sha1
• sha256
• snat
149
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• snatpool
• string map
• substr
• switch
• use
• virtual
• when
• whereis
Example Use the following example to log the time whenever a connection is
established:
when CLIENT_ACCEPTED {
log "Client [IP::client_addr] connected at [clock format
[TIME::clock seconds] -format {%T}]"
}
CLIENT_CLOSED
Description Execute specific aFleX commands at the end of any client connection,
regardless of protocol.
150
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
151
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• LB::server
• LB::status
Related Information
• TCP::remote_port
• TCP::respond
152
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
153
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
Example Use the following example to decrement the client IP counter by 1 each
time a client connection is closed. If all connections from the specified
client IP are closed, the counter is deleted.
when CLIENT_CLOSED {
set $client_ip 10.10.10.10
table set active_clients $client_ip 1
if { [table lookup active_clients $client_ip] != "" } {
table incr active_clients $client_ip -1
if {[table lookup active_clients $client_ip] <= 0 } {
table delete active_clients $client_ip}
}
}
CLIENT_DATA
Description Execute specific aFleX commands when new data is received from the
client while the connection is in a collect state.
NOTE: For UDP, the CLIENT_DATA event is automatically triggered for each UDP
packet received. IP fragmentation of a UDP packet is not supported for
the CLIENT_DATA event.
154
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• AES::encrypt
155
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• LID::request_limit
• LID::request_rate_limit
• LID::type
Related Information
• TCP::release
• TCP::remote_port
156
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• TCP::respond
157
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
Example Use the following example to select the service group “top_dns_
service_group” when a new client DNS request contains “TOP”:
when CLIENT_DATA {
if { [UDP::payload 50] contains "TOP" } {
pool top_dns_service_group
}
}
158
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
SERVER_CLOSED
Description Execute specific aFleX commands when the server-side connection
closes.
Valid Events
159
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• IP::client_addr
• IP::local_addr
• IP::protocol
• IP::remote_addr
• IP::server_addr
• IP::tos
• IP::ttl
• IP::version
160
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• TCP::local_port
• TCP::mss
• TCP::option
• TCP::rtt
• TCP::server_port
Related Information
• TCP::remote_port
• TCP::respond
161
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
Example Use the following example to generate a log message containing the IP
address of the server whenever a server-side connection is closed:
when SERVER_CLOSED {
log "Server [IP::server_addr] has closed the connection"
}
SERVER_CONNECTED
Description Execute specific aFleX commands when a connection is established with
the server.
162
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
163
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• LID::request_limit
• LID::request_rate_limit
• LID::type
Related Information
• TCP::remote_port
• TCP::respond
164
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
165
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• virtual
• whereis
Example Use this example to create variables that include the IP addresses and
TCP ports of the client and the server when a server connection is
established:
when CLIENT_ACCEPTED {
set vip "[IP::local_addr]:[TCP::local_port]"
}
when SERVER_CONNECTED {
set client "[IP::client_addr]:[TCP::client_port]"
set node "[IP::server_addr]:[TCP::server_port]"
}
when CLIENT_CLOSED {
log "Client $client -> VIP: $vip -> Node: $node"
}
SERVER_DATA
Description Execute specific aFleX commands when new data is received from the
server while the connection is in a hold state.
NOTE: For UDP, the SERVER_DATA event is triggered for every packet. For TCP,
you need to issue a TCP::collect.
166
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• CLASS::type
167
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• RADIUS::id
• RADIUS::length
Related Information
• TCP::release
• TCP::remote_port
• TCP::respond
168
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
• whereis
Example Use the following example to define the variable payload whenever
new data is received from the server while the connection is in a hold
state:
when SERVER_DATA {
169
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
170
MQTT Events
The following MQTT events are available:
l MQTT_CLIENT_MESSAGE
l MQTT_CLIENT_MESSAGE_DATA
l MQTT_SERVER_MESSAGE
l MQTT_SERVER_MESSAGE_DATA
l MQTT_PUBLISH
l MQTT_SUBSCRIBE
MQTT_CLIENT_MESSAGE
Description Executes the specific aFleX scripts when a client sends an MQTT
message.
171
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• MQTT::keep_alive
• MQTT::length
• MQTT::packet_id
• MQTT::password
• MQTT::payload
• MQTT::payload_length
• MQTT::protocol_name
• MQTT::protocol_version
• MQTT::qos
• MQTT::replace
• MQTT::respond
• MQTT::retain_flag
• MQTT::return_code
• MQTT::session_present_flag
• MQTT::topic
• MQTT::type
• MQTT::username
• MQTT::will
MQTT_SERVER_MESSAGE_DATA
Description Triggered only when MQTT::collect finishes collecting under MQTT_
SERVER_MESSAGE
Example
when MQTT_SERVER_MESSAGE {
MQTT::collect
}
when MQTT_SERVER_MESSAGE_DATA {
if { [MQTT::type] equals 8} {
log "payload in PUBLISH is [MQTT::payload]"
172
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
}
}
MQTT_SERVER_MESSAGE
Description Executes the specific aFleX scripts when a server sends an MQTT
message.
173
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
174
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
MQTT_CLIENT_MESSAGE_DATA
Description Triggered only when MQTT::collect finishes collecting under MQTT_
CLIENT_MESSAGE
Example
when MQTT_CLIENT_MESSAGE {
MQTT::collect
}
when MQTT_CLIENT_MESSAGE_DATA {
if { [MQTT::type] equals 8} {
log "payload in PUBLISH is [MQTT::payload]"
}
}
175
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• MQTT::return_code
• MQTT::return_code_list
• MQTT::session_present_flag
• MQTT::topic
• MQTT::type
• MQTT::username
• MQTT::will
MQTT_PUBLISH
Description Executes the specific aFleX scripts when a broker publishes an MQTT
PUBLISH message.
176
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• MQTT::qos
• MQTT::replace
• MQTT::respond
• MQTT::retain_flag
• MQTT::return_code
• MQTT::session_present_flag
• MQTT::topic
• MQTT::type
• MQTT::username
• MQTT::will
MQTT_SUBSCRIBE
Description Executes the specific aFleX scripts when a client subscribes to an MQTT
SUBSCRIBE message.
177
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• MQTT::payload_length
• MQTT::protocol_name
• MQTT::protocol_version
• MQTT::qos
• MQTT::replace
• MQTT::respond
• MQTT::return_code
• MQTT::return_code_list
• MQTT::session_present_flag
• MQTT::topic
• MQTT::type
• MQTT::username
• MQTT::will
178
QUIC Events
The following QUIC events are available for http-over-quic vport:
l QUIC_INITIAL
l QUIC_CLIENT_ACCEPTED
l QUIC_CLIENT_CLOSED
QUIC_INITIAL
Description Executes the specific aFleX commands when the initial packet is
received from the client side.
179
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• drop
• drop
Example
when QUIC_INITIAL {
log "**** QUIC INITIAL ****"
log "IP client addr [IP::client_addr]"
log "IP local addr [IP::local_addr]"
log "IP protocol [IP::protocol]"
log "IP remote addr [IP::remote_addr]"
log "IP version [IP::version]"
log "IP TOS [IP::tos]"
log "IP ttl [IP::ttl]"
log "UDP client_port [UDP::client_port]"
log "UDP local_port [UDP::local_port]"
log "UDP remote_port [UDP::remote_port]"
log "UDP server_port [UDP::server_port]"
log "Initial CID [QUIC::cid]"
log "QUIC Initial Version [QUIC::version]"
if { [IP::addr [IP::client_addr] equals 16.16.16.203] } {
drop
}
}
QUIC_CLIENT_ACCEPTED
Description Executes the specific aFleX commands after the SSL handshake is
complete and the client connection is established with the ACOS device.
180
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• IP::protocol
• IP::remote_addr
• IP::tos
• IP::ttl
• IP::version
Example
when QUIC_CLIENT_ACCEPTED {
log "**** QUIC CLIENT ACCEPTED ****"
if { [IP::addr [IP::client_addr] equals
16.16.16.123] } {
pool sg-http3-s149
}
}
QUIC_CLIENT_CLOSED
Description Executes the specific aFleX commands after the client side connection is
closed.
181
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• IP::client_addr
• IP::local_addr
• IP::protocol
• IP::remote_addr
• IP::tos
• IP::ttl
• IP::version
Example
when QUIC_CLIENT_CLOSED {
log "**** QUIC CLIENT CLOSED****"
}
}
182
RAM Caching Events
The following RAM caching events are available:
l CACHE_REQUEST
l CACHE_RESPONSE
NOTE: These commands are supported on HTTP traffic (the original proxy),
but not supported on HTTP2 traffic (or the new proxy).
183
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
CACHE_REQUEST
Description Execute specific aFleX commands when a virtual server receives a
request for a cached object.
184
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• clientside
• cpu usage
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to revalidate a cached object from the server
if the age of the cache is greater than 60 seconds. A log message is also
created:
185
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
when CACHE_REQUEST {
if { [CACHE::age] > 60 } {
CACHE::expire
log "Expired Content: Age is greater than 60 seconds"
}
}
CACHE_RESPONSE
Description Execute specific aFleX commands immediately before sending a cache
response.
186
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• LID::type
187
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• use
• virtual
Example Use the following example to revalidate a cached object from the server
if the ::expired variable is set to 1. An expiration message is logged,
and then the ::expired variable is set to 0.
when CACHE_RESPONSE {
if { $::expired == 1 } {
CACHE::expire
log "cache expire"
table set expired 0 0
}
}
188
SIP Events
Session Initiation Protocol (SIP) events are supported for the following:
l SIP – Session Initiation Protocol over UDP
l SIP-TCP – SIP over TCP
l SIPS – Secure SIP over TLS
189
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
SIP_REQUEST
Description Execute specific aFleX commands when a full SIP request header is
received from the client.
190
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• snat
• snatpool
• string map
• substr
• switch
• use
• virtual
191
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Related Information
• TCP::remote_port
• TCP::respond
Example Use the following example to log the value of the Call-ID whenever an
SIP request header is received.
when SIP_REQUEST {
log "SIP Call_ID: [SIP::call_id]"
}
SIP_REQUEST_SEND
Description Execute specific aFleX commands when a SIP request is sent to the
server.
192
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• SIP::header
• SIP::method
• SIP::respond
• SIP::response
• SIP::to
• SIP::uri
• SIP::via
193
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Related Information
• TCP::remote_port
• TCP::respond
194
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• UDP::local_port
• UDP::payload
• UDP::remote_port
• UDP::server_port
Example Use the following example to log the SIP method type whenever the
ACOS device sends a SIP request to the server.
when SIP_REQUEST_SEND {
log "SIP Method: [SIP::method]"
}
SIP_RESPONSE
Description Execute specific aFleX commands when a full SIP response is received
from the server.
195
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• snat
• snatpool
• string map
• substr
• switch
• use
• virtual
196
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• IP::local_addr
• IP::protocol
• IP::remote_addr
• IP::server_addr
• IP::tos
• IP::ttl
• IP::version
Related Information
• TCP::remote_port
• TCP::respond
Example Use the following example to log the SIP response code whenever a full
SIP response from the server is received.
when SIP_RESPONSE {
log "SIP Response Code: [SIP::response code]"
}
197
SMTP Events
The following Financial Information eXchange (FIX) events are available:
l SMTP_MAIL
l SMTP_EHLO
198
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
SMTP_MAIL
Description Triggers upon receiving MAIL FROM command from the client.
Example
When SMTP_MAIL {
If {[SMTP::mail] equals abc.com} {
node 1.1.1.1 25
} else {
Node 2.2.2.2 25
}
}
SMTP_EHLO
Description Triggered when EHLO command arrives
Example
When SMTP_EHLO {
SMTP::greet “VRFY”
}
199
SSL Events
The following SSL events are available:
l CLIENTSSL_CLIENTCERT
l CLIENTSSL_CLIENTHELLO
l CLIENTSSL_DATA
l CLIENTSSL_HANDSHAKE
l SERVERSSL_CLIENTHELLO_SEND
l SERVERSSL_DATA
l SERVERSSL_HANDSHAKE
l SERVERSSL_SERVERCERT
l SERVERSSL_SERVERHELLO
200
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
CLIENTSSL_CLIENTCERT
Description Execute specific aFleX commands when an SSL client certificate is
received.
201
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• SSL::verify_result
202
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• session
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to create a log and set the subject of the log
entry when an SSL client certificate is received.
when CLIENTSSL_CLIENTCERT {
log "X509 Subject: [X509::subject [SSL::cert 0]]"
}
203
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
CLIENTSSL_CLIENTHELLO
Description Execute specific aFleX command when an SSL Client Hello message is
received.
204
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to begin collecting SSL application data when
an SSL Client Hello message is received:
when CLIENTSSL_CLIENTHELLO {
SSL::collect 100
}
when CLIENTSSL_DATA {
log "SSL Payload Length: [SSL::payload length]"
log "SSL Payload: [SSL::payload]"
205
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
SSL::release
}
CLIENTSSL_DATA
Description Execute specific aFleX commands when the ACOS device is in SSL collect
mode and receives an SSL application data message from a client.
206
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
207
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use this example to trigger SSL authentication and renegotiation when
the device enters SSL collect mode and receives SSL application data.
when CLIENT_ACCEPTED {
set renegotiate 1
set index 1
}
when CLIENTSSL_HANDSHAKE {
if { $renegotiate == 1 } {
log "SSL Handshake done - Index: $index"
incr index
set renegotiate 0
SSL::collect
} else {
log "SSL Renegotiate Handshake done - Index: $index"
incr index
SSL::release
}
208
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
}
when CLIENTSSL_DATA {
log "Start SSL Renegotiate - Index: $index"
SSL::authenticate depth 2
SSL::authenticate once
SSL::cert mode request
SSL::renegotiate
}
CLIENTSSL_HANDSHAKE
Description Execute specific aFleX commands when an SSL handshake on the client
side is completed.
209
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• SSL::renegotiate
• SSL::respond
• SSL::session invalidate
• SSL::sessionid
• SSL::template
• SSL::verify_result
210
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• active_members
• b64decode
• b64encode
• clientside
• cpu usage
• domain
• drop
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
211
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
Example Use the following example to create a log and set the subject of the log
entry whenever an SSL handshake is completed on the client side.
when CLIENTSSL_HANDSHAKE {
log "X509 Subject: [X509::subject [SSL::cert 0]]"
}
SERVERSSL_CLIENTHELLO_SEND
Description Execute specific aFleX commands when the ACOS device sends a SSL
Client Hello message to the back-end server.
212
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• TCP::local_port
• TCP::mss
• TCP::rtt
213
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to begin collecting SSL application data
whenever an SSL Client Hello message is sent to the server.
when SERVERSSL_CLIENTHELLO_SEND {
SSL::collect
}
when SERVERSSL_DATA {
log "SSL Payload Length: [SSL::payload length]"
log "SSL Payload: [SSL::payload]"
SSL::release
}
214
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
SERVERSSL_DATA
Description Execute specific aFleX commands when ACOS device is in SSL collect
mode and receives an SSL application data message from a back-end
server.
215
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• X509::not_valid_after
• X509::not_valid_before
• X509::serial_number
• X509::signature_algorithm
• X509::subject
• X509::subject_public_key
• X509::subject_public_key_RSA_bits
• X509::subject_public_key_type
• X509::text
• X509::verify_cert_error_string
• X509::version
• X509::whole
216
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to log SSL data information and release the
collected data whenever the ACOS Device enters SSL collect mode and
receives data from the back-end server.
when SERVERSSL_HANDSHAKE {
SSL::collect 400
}
when SERVERSSL_DATA {
log "SSL Payload Length: [SSL::payload length]"
log "SSL Payload: [SSL::payload]"
SSL::payload replace 0 [SSL::payload length] "HTTP/1.1 200
OK\r\nContent-Length: 37\r\nContent-Type:
text/html;\r\n\r\n<html><head>Hello World!</head></html>"
SSL::release
}
SERVERSSL_HANDSHAKE
Description Execute specific aFleX commands when an SSL handshake on the server
side is completed.
217
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
218
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• X509::subject_public_key_RSA_bits
• X509::subject_public_key_type
• X509::text
• X509::verify_cert_error_string
• X509::version
• X509::whole
219
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to create a log and set the subject of the log
entry whenever an SSL handshake is completed on the server side.
when SERVERSSL_HANDSHAKE {
log "X509 Subject: [X509::subject [SSL::cert 0]]"
}
SERVERSSL_SERVERCERT
Description Triggered when the device receives an SSL certificate from the server
(after verification) .
220
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
SERVERSSL_SERVERHELLO
Description Execute specific aFleX command when an SSL Server Hello is received
from a back-end server.
221
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• TCP::rtt
222
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to enable SSL collect mode whenever an SSL
Server Hello message is received:
when SERVERSSL_SERVERHELLO {
SSL::collect
}
when SERVERSSL_DATA {
log "SSL Payload Length: [SSL::payload length]"
log "SSL Payload: [SSL::payload]"
SSL::release
}
223
WAF Events
The following Web Application Firewall (WAF) events are available:
l WAF_REQUEST_DENY
l WAF_REQUEST_VIOLATION
l WAF_RESPONSE_VIOLATION
224
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
WAF_REQUEST_DENY
Description Execute specific aFLeX commands whenever a WAF request is denied in
active deployment mode.
225
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following command to set a variety of variables when a WAF
request is denied:
when WAF_REQUEST_DENY {
set mode [WAF::mode]
set template [WAF::template]
set srcip [WAF::violation src_ip]
set type [WAF::violation type]
set msg [WAF::violation message]
set id [WAF::violation id]
set action [WAF::violation action]
set severity [WAF::violation severity]
226
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
WAF_REQUEST_VIOLATION
Description Execute specific aFleX commands whenever a violation occurs in an
HTTP request passing through WAF.
227
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• encoding
• event
• findstr
• getfield
• htonl
• htons
• if
• log
• md5
• members
• nexthop
• ntohl
• ntohs
• persist
• reject
• return
• serverside
• set encode
• sha1
• string map
• substr
• switch
• use
• virtual
Example Use the following example to set a variety of variables when a violation
occurs in an HTTP request passing through WAF:
when WAF_REQUEST_VIOLATION {
228
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
WAF_RESPONSE_VIOLATION
Description Execute specific aFleX commands whenever a violation occurs in an
HTTP response passing through WAF.
229
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• TCP::server_port
230
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Events
• use
• virtual
231
aFleX Commands
l Global Commands
l Global Variable Commands
l AAM Commands
l Application Firewall Commands
l AES Commands
l Category Commands
l Class List Commands
l Compression Commands
l Compression Commands
l Database Load-Balancing Commands
l Diameter Load-Balancing Commands
l DNS Commands
l Financial Information eXchange Commands
l HTTP Commands
l ICAP Commands
l IP Commands
l Limit ID Commands
l Link Commands
l Load-balancing Commands
l MQTT Commands
l Policy-Based SLB Commands
l RADIUS Message Load-balancing Commands
l RAM Caching Commands
l Resolve Commands
l SIP Commands
232
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
l SMTP Commands
l SSL Commands
l Statistics Commands
l Table Commands
l TCP Commands
l Template Commands
l Time Commands
l UDP Commands
l URI Commands
l URL Commands
l WAF Commands
l X509 Commands
l Deprecated and Disabled Commands
233
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Overview
aFleX commands can perform the following types of operations:
l Global – Performs actions such as selecting a pool (SLB service group) or node
(server).
Query commands:
l IP packet header query – Returns information from the IP header.
l IP, TCP, or UDP packet data query – Returns information from the payload.
l HTTP packet header or content query – Returns information from the HTTP
header or payload.
l Header and content manipulation:
l HTTP cookie manipulation – Changes cookies.
l TCP header and content manipulation – Changes TCP headers or content.
l HTTP header and content manipulation – Changes HTTP headers or content.
l SSL and X.509 query – Returns information from or about certificates.
l Deep packet inspection – Returns strings from packets.
For information about other script components, see aFleX Script Components.
234
Global Commands
The following global aFleX commands are available:
l active_members
l b64decode
l b64encode
l clientside
l cpu usage
l domain
l drop
l encoding
l event
l findstr
l getfield
l htonl
l htons
l log
l lwnode
l md5
l members
l nexthop
l node
l ntohl
l ntohs
l persist
l pool
235
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
l reject
l return
l serverside
l session
l set encode
l sha1
l snat
l snatpool
l string map
l substr
l switch
l use
l virtual
l when
l whereis
active_members
Description This command returns either the number of active members in a service
group or pool or a listing. When the optional list parameter is not used,
then the default behavior outputs the number of active members.
Example
Example 1:
when HTTP_REQUEST {
if { [active_members example_service_group] <= 3 } {
pool service_group_backup
236
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
}
Example Example 2:
w hen HTTP_ REQUEST {
log "The service group http active member list is [active_ members list
service_ group_ http]"
}
Output:
[AFLEX]:af: The service group http active member list is
{192.168.0.0 80}
Valid Events
All
b64decode
Description This command returns a specified string that was decoded from base-
64. If there is an error, it will return NULL.
Example
when HTTP_REQUEST {
set encoded_cookie [HTTP::cookie "EncodedCookie"]
set decoded_cookie [b64decode $encoded_cookie]
HTTP::cookie insert name "ClearCookie" value $decoded_
cookie
}
Valid Events
All
237
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
b64encode
Description This command returns a specified encoded base-64 string when used. If
there is an error, it will return NULL.
Example
when HTTP_REQUEST {
set decoded_cookie [HTTP::cookie "ClearCookie"]
set encoded_cookie [b64encode $decoded_cookie]
HTTP::cookie insert name "EncodedCookie" value $encoded_
cookie
}
Valid Events
All
clientside
Description Using this command will take specified aFleX commands to be put in
assessment under the client-side context. It will not affect aFleX
commands that are already under the client-side context being
assessed.
Example
when SERVER_CONNECTED {
if { [IP::addr [clientside {IP::remote_addr}] equals
192.1680.0.0] } {
discard
}
}
Valid Events
238
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
All
cpu usage
Description This command will return the average CPU load for an interval based on
the defined time. The average is a moving average that is exponentially
weighted over an interval.
Example
when HTTP_REQUEST {
if { [cpu usage 15secs] <= 60} {
example_service_group
} else {
HTTP::redirect "http://backup.example.com"
}
}
Valid Events
All
discard
Description Depending on the event, this command will discard the connection or
current packet. This must be conditionally associated with an if
statement and essentially functions the same as the drop command.
Syntax discard
Example
when SERVER_CONNECTED {
if { [IP::addr [IP::remote_addr] equals 192.168.0.0] } {
discard
239
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
}
Valid Events
All
domain
Description This command returns a specified string as a dotted domain name. In
addition, the last <count> portions of a domain name will be returned.
Example
when HTTP_REQUEST {
if { [domain [HTTP::host] 1] equals "com" } {
pool example_service_group
}
}
Valid Events
All
drop
Description Depending on the event, this command will drop the connection or
current packet. This must be conditionally associated with an if
statement and essentially functions the same as the discard command.
Syntax drop
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
240
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
drop
}
}
Valid Events
All
encoding
Description This command takes a character encoded payload and converts it to the
specified encoding format.
Valid Events
All
event
Description This command will abandon the review of specified aFleX events, or
everything on the connection depending on the parameters chosen,
while the aFlex script continues to run.
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.0.0] } {
event HTTP_REQUEST disable
}
}
when HTTP_REQUEST {
log "There is a HTTP Request from: [IP::client_addr]"
241
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All
findstr
Description This command is used to locate a string <search_string> within another
string <string>, where the result is the offset string specified from the
match. The value for <terminator> is a character or number (length). If
not specified, it will default to the end of the string. <Skip_count> will
default to zero if not specified. If neither parameters <terminator> and
<skip_count> are defined, it functions as the command string range
<string> [string first <string> <search_string>] end.
Example
when HTTP_REQUEST {
if { [findstr [HTTP::uri] "type=" 5 "&"] eq "cgi" } {
pool service_group_dynamic
} else {
pool example_service_group
}
}
Valid Events
All
getfield
Description This command provides the corresponding string from a specified field
through the <string> or <split> attributes. The first example shows the
242
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
extraction of the hostname from the host header. The second example
shows how to redirect request for example.net to example.edu
Example
when HTTP_REQUEST {
[getfield [HTTP::host] ":" 1]
}
Example
when HTTP_REQUEST {
if { [HTTP::host] contains "example.net" } {
HTTP::redirect http://[getfield [HTTP::host]
".example.net" 1].example.edu[HTTP::uri]
}
}
Valid Events
All
htonl
Description This command converts a hosts’ byte order of an unsigned integer to
network byte order.
Example
when HTTP_REQUEST {
set hostlong 12348765
set netlong [htonl $hostlong]
}
Valid Events
All
243
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
htons
Description This command converts a hosts’ byte order of an unsigned short
integer to network byte order.
Example
when HTTP_REQUEST {
set hostshort 1423
set netshort [htons $hostshort]
}
Valid Events
All
if
Description Use this command to query for a true or false answer, and take action
based upon that answer. The elseif and else commands can be added
after an if command.
244
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example
when HTTP_REQUEST {
if { [HTTP::uri] ends_with ".html" } {
pool service_group_static
} elseif { [HTTP::uri] ends_with ".asp" } {
pool service_group_dynamic
}
}
Valid Events
All
log
Description This command creates and logs a specified message to the Syslog utility
through a variable expansion on messages as prescribed for the HTTP
profile Header Insert setting. Use "local0" to "local7" as the value for
facility (Note: only "local0" is supported). For <level>, the number value
from 0 to 7 can be used, or its corresponding level string, "EMERG",
"ALERT", "CRIT", "ERR", "WARNING", "NOTICE", "INFO", and "DEBUG".
NOTE:
When using the Syslog facility, the log is limited to 1024 bytes per
request. Longer strings will be truncated.
Regardless of level, the aFlex log command messages are rate limited as
a class. Thus, subsequent messages within the rate-limit period may be
245
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example
log "The log message is from facility local0 by default and
level INFO (6) by default"
Example
log local2."The log message is from facility local2 and level
INFO (6) by default"
Example
log local2.0 "This log massage is from facility local2 and
level 0 (EMERG)"
Example
log local2.DEBUG "This log massage is from facility local2 and level
DEBUG (7)"
NOTE: In ACOS 4.0.1, aFlex log entries are recognized so log messages for aFlex
events will be linked with the aFlex script where they occurred.
Example
In ACOS 4.0.1 and higher, with the application of three aFleX scripts
(af1, af2, and af3) to its virtual port using the show log output for an
SLB, virtual server will display the following:
ACOS(config)#show log
Aug 05 2014 11:58:14 Info [AFLEX]:af3:HTTP status : 200
Aug 05 2014 11:58:14 Info [AFLEX]:af3:HTTP_RESPONSE event
Aug 05 2014 11:58:14 Info [AFLEX]:af2:Another http request
cmd!
Aug 05 2014 11:58:14 Info [AFLEX]:af1:This is http_request_
1
Prior to ACOS 4.0.1, the application of the three aFlex scripts would
have produced the following show log output:
ACOS(config)#show log
246
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All
matches
Description Tests whether one string matches another string.
NOTE: The matches operator uses the same comparison as the Tcl "string
match" command, which functions like a cut-down regular expression.
For the two strings to match, their contents must be identical except
that the following special sequences may appear in the pattern:
• * – Matches any sequence of characters in string, including a null
string.
• ? – Matches any single character in string.
• [chars] – Matches any character in the set given by chars. If a
sequence of the form x-y appears in chars, then any character
between x and y, inclusive, will match. When used with -nocase,
the end points of the range are converted to lower case first.
Whereas {[A-z]} matches '_' when matching case-sensitively ('_'
falls between the 'Z' and'a'), with -nocase this is considered to be
like {[A-Za-z]}.
247
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
lwnode
Description This command forces the specified server node to be used directly,
bypassing any load-balancing. The difference between this command
and the node command is that lwnode can be referred to an entity that
is not a service-group member or a defined part of the real server
configuration.
NOTE: When using the lwnode command, a source NAT pool must be applied.
NOTE: Nodes selected by using this command do not have connection limiting
and connection rate limiting applied.
Example
when HTTP_REQUEST {
switch -glob [string tolower [HTTP::uri]] {
"/static1/*" { lwnode 192.168.0.1 }
"/static2/*" { lwnode 192.168.0.2 }
"/static3/*" { lwnode 192.168.0.3 }
default { lwnode 192.168.0.4 8080 }
}
}
248
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENT_ACCEPTED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
md5
Description This command provides the RSA MD5 Message Digest Algorithm
message digest of the specified string.
Example
when CLIENT_ACCEPTED {
set md5_binary [md5 "1234509876"]
binary scan $md5_binary H* md5_ascii
log "MD5: $md5_ascii"
}
Valid Events
All
members
Description This command counts or lists all the service group members.
Example Use the following example to list members. If this option is removed,
the output is the member count.
when CLIENT_ACCEPTED {
log "Here are the Total Member(s): [members list example_
service_group]"
}
249
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All
nexthop
Description This command will set the next hop for a connection.
For the events listed, using this command overwrites the default
reverse next-hop IP address:
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• SERVER_CONNECTED
• SERVER_DATA
For other cases, use of this command will overwrite the forward next-
hop IP address.
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.0/24] }
{
nexthop 192.168.1.254
log "Nexthop: 192.168.1.254"
} else {
log “Nexthop: default (192.168.1.10)”
}
}
Valid Events
All
250
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
md5
Description This command provides the RSA MD5 Message Digest Algorithm
message digest of the specified string.
Example
when CLIENT_ACCEPTED {
set md5_binary [md5 "1234509876"]
binary scan $md5_binary H* md5_ascii
log "MD5: $md5_ascii"
}
Valid Events
All
node
Description This command forces the specified server node that is comprised of IP
address and port number to be used directly, and bypass any load-
balancing.
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
NOTE:
l Use of the node command requires the configuration of a real server
(node) and service port as a member of a service group.
l Nodes selected through this command do not have connection
limiting and connection rate limiting applied to them.
251
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to change the file extension while it remains
in 192.168.0/24.
when HTTP_REQUEST {
if { [HTTP::uri] ends_with ".png" } {
node 192.168.1.200 80
}
}
ntohl
Description This command converts a network byte order’s unsigned integer to a
host byte order.
Example
when HTTP_REQUEST{
set netlong 12348765
set hostlong [ntohl $netlong]
}
Valid Events
All
ntohs
Description This command converts a network byte order’s unsigned short integer
to a host byte order.
Example
when HTTP_REQUEST {
set netshort 1243
set hostshort [ntohs $netshort]
252
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All
persist
Description This command sets client persistence based on the value chosen.
Use of this command sets the key for an entry on the persistence table.
This maps the client to an SLB resource (real server, real server port, or
service group). If the persistence table contains the specified key, the
ACOS device uses the SLB resource that key is mapped to in the table.
Otherwise, the ACOS device will use SLB to select a resource and create
a corresponding persistence table entry. The uie option, “Universal
Inspection Engine”, indicates that persistence can be set based on any
key.
Use the following syntax to add an entry to the persistence table. This
command differs from the command above because it does not first
check the persistence table for an existing entry for the key. The
persist add form of the command is useful for setting persistence
based on data that is set on the server and is therefore first observed
by the ACOS device in the server response, rather than in the client
request.
253
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
all – This parameter returns all the values listed below. (If not
specified, and none of the other options are specified, the command
interpretation is equivalent to specifying all.
port – This parameter will return the real service port number.
pool – This parameter will return the pool (service group) name.
Use the following syntax to delete the persistence table entry for the
specified key.
persist delete uie <key>
<key> Syntax
The use of the <key> specifies the data upon which the persistence is
based. It can be specified with one of the following options:
<specified-value>
Use persist to the same real server and port if traffic contains the
specified key value and is sent to the same virtual port.
{<specified-value> [any virtual | any service | any pool]
[pool <pool-name>]}
254
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
value>
any virtual Use for persistence to the same real server and port
if traffic contains the specified key value and is sent
to the same virtual port and service group (pool).
any service Use for persistence to the same real server if traffic
contains the specified key value and is sent to the
same virtual server, to any virtual port.
any pool Use for persistence to the same real server if traffic
contains the specified key value.
pool <pool- Use for persistence to the same real server and port
name> if traffic contains the specified key value and is sent
to the same virtual port and to the specified service
group.
NOTE:
l Server template limits are applied for both service-group and server
selection. Commands that call for server selection such as “node”,
“pool”, and “persist” will enforce server template limits on the
selected server. As a result, new connections that match a persist uie
entry may find themselves unable to use the rport and a default
server selection will occur instead. To prevent default server
selection, use the no def-selection-if-pref-failed command for the
vport.
l If the length of the persist UIE key in aFlex exceeds the internal limit
of 63 characters, aFlex truncates the key to an appropriate length for
use.
l To show the persistent sessions managed by this aFleX command,
use the following command in the CLI: show session persist uie.
Example Use the following example script to provide persistence on a VIP on any
port.
when HTTP_REQUEST {
set IP [IP::client_addr]
set p [persist lookup uie { $IP any virtual } all]
if { $p ne "" } {
255
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example script to provide the same persistence for a
client IP address accessing one VIP and port:
when HTTP_REQUEST {
set IP [IP::client_addr]
persist uie $IP
}
when HTTP_RESPONSE {
set IP [IP::client_addr]
persist add uie $IP 1800
}
Example Use the following example script to provide the same persistence for a
client IP address accessing any VIP and any port:
when HTTP_REQUEST {
set IP [IP::client_addr]
set p [persist lookup uie { $IP any service } all]
if { $p ne "" } {
log " UIE located([lindex $p 0] [lindex $p 1] [lindex
$p 2])"
node [lindex $p 1] [lindex $p 2]
}
}
when HTTP_RESPONSE {
set IP [IP::client_addr]
persist add uie { $IP any service } 1800
}
Valid Events
All.
256
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
pool
Description This command will cause the system to load balance traffic to the
specified pool or pool member. This statement must have an if
statement conditionally associated with it.
This command acts upon the service groups (pools) located in the
partition that contains the aFleX policy.
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
NOTE: Server template limits are applied for both service-group and server
selection. Commands that call for server selection such as “node”,
“pool”, and “persist” will enforce server template limits on the selected
server. As a result, new connections that match a persist uie entry may
be unable to use the rport and a default server selection will occur
instead. To prevent a default server selection, use the no def-selection-
if-pref-failed command for the vport.
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
pool example_server_group
}
}
Valid Events
• CLIENT_ACCEPTED
257
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• LB_FAILED
Events that do not generate an error, but are likely not valid for this
command:
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
reject
Description This command will cause the connection to be rejected, and return a
reset as appropriate for the protocol.
Syntax reject
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
reject
}
}
Valid Events
All
258
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
return
Description This command terminates execution of an aFleX event and would
optionally return the result of the evaluating expression.
Example Use of the following example shows that the foreach loop is broken by
the return command if the string “X-ClientIP” is found in the HTTP
header.
when HTTP_REQUEST {
foreach header [HTTP::header names] {
if { [HTTP::header exists "X-ClientIP"] } {
return
} else {
HTTP::header insert X-Forwarded-For [IP::client_
addr]
}
}
}
Valid Events
All
serverside
Description This command will cause the specified aFleX command or commands to
be evaluated under the server-side context. This command has no effect
if the aFleX policy is already being evaluated under the server-side
context.
Example
259
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when CLIENT_ACCEPTED {
if {[IP::addr [serverside {IP::remote_addr}] equals
192.168.80.81] } {
drop
}
}
Valid Events
All
session
Description This command manages SSL sessions.
Use the following syntax to search the SSL table for information about
the specified key.
session lookup ssl <key>
Example
when CLIENTSSL_HANDSHAKE {
set cert1 [SSL::cert 0]
session add ssl [SSL::sessionid] $cert1 300
}
when HTTP_REQUEST {
set cert2 [session lookup ssl [SSL::sessionid]]
}
260
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENT_ACCEPTED
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_RESPONSE
set encode
Description This command will set the character encoding for data payloads.
Example Use the following example of an aFleX policy to convert payload data
into Japanese encoding Shift_JIS:
when HTTP_RESPONSE {
if { [HTTP::header "Content-Type"] contains "Shift_JIS" } {
set encode "shiftjis"
HTTP::collect
}
}
when HTTP_RESPONSE_DATA {
set hoge [HTTP::payload length]
set payload [encoding convertfrom $encode [HTTP::payload]]
regsub -all "abc" $payload "xyz" newdata
set newdata3 [encoding convertto $encode $newdata]
HTTP::payload replace 0 $hoge $newdata3
HTTP::release
}
Valid Events
All
261
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
sha1
Description This command will return the Secure Hash Algorithm version 1.0 (SHA1)
message digest of the specified string.
Valid Events
All
sha256
Description This command will return the Secure Hash Algorithm version 2.0
(SHA256) message digest of the specified string.
Example
when CLIENT_ACCEPTED {
log "[sha256 "123456789"]"
}
Valid Events
All
snat
Description This command will assign, select or disable source NAT.
262
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Usage Use of this command will assign the specified NAT address (<addr>) to
the server-side connection. The command replaces the reverse
destination address of the connection with the specified IP address.
Example The following example script will apply the specified source NAT
address for clients in the 192.168.10.0/24 subnet:
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.10.0/24] }
{
snat 203.113.80.150
} else {
snat 203.113.80.250
}
}
Valid Events
• CLIENT_ACCEPTED
• LB_SELECTED
• SIP_REQUEST
• SIP_RESPONSE
• DB_COMMAND
• DB_QUERY
• HTTP_REQUEST
snatpool
Description This command will use the specified pool of IP addresses as translation
addresses to create a SNAT. It uses the specified NAT pool instead of
the NAT pool that is already bound to the virtual port in the ACOS
configuration.
263
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
snatpool none
NOTE: A NAT pool must already be bound to a virtual port in the ACOS
configuration. This is the virtual port’s default NAT pool.
NOTE: The IP type, IPv4 or IPv6 of the pool must be the same as the IP type of
the real servers.
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
snatpool snat-internal
} else {
snatpool snat-external
}
}
Valid Events
• CLIENT_ACCEPTED
• HTTP_REQUEST
• LB_SELECTED
• SIP_REQUEST
• SIP_RESPONSE
string map
Description This command will map the value of the second string to the value of
the first string. Each instance of the <string1> will be replaced with
<string2>.
264
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example This example illustrates that when an HTTP request comes in and has
"/abc" in its uri, it will be changed to "/def" when it is sent to the
backend server.
when HTTP_REQUEST {
if {[HTTP::uri] contains "static"} {
HTTP::uri [string map {"/static" "/images"} [HTTP::uri]]
}
}
Valid Events
All
session
Description This command manages SSL sessions.
Use the following syntax to search the SSL table for information about
the specified key.
session lookup ssl <key>
Example
when CLIENTSSL_HANDSHAKE {
set cert1 [SSL::cert 0]
session add ssl [SSL::sessionid] $cert1 300
}
when HTTP_REQUEST {
265
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENT_ACCEPTED
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_RESPONSE
sha1
Description This command will return the Secure Hash Algorithm version 1.0 (SHA1)
message digest of the specified string.
Valid Events
All
sha256
Description This command will return the Secure Hash Algorithm version 2.0
(SHA256) message digest of the specified string.
Example
when CLIENT_ACCEPTED {
log "[sha256 "123456789"]"
}
266
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All
snat
Description This command will assign, select or disable source NAT.
Usage Use of this command will assign the specified NAT address (<addr>) to
the server-side connection. The command replaces the reverse
destination address of the connection with the specified IP address.
Example The following example script will apply the specified source NAT
address for clients in the 192.168.10.0/24 subnet:
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.10.0/24] }
{
snat 203.113.80.150
} else {
snat 203.113.80.250
}
}
Valid Events
• CLIENT_ACCEPTED
• LB_SELECTED
• SIP_REQUEST
• SIP_RESPONSE
• DB_COMMAND
• DB_QUERY
• HTTP_REQUEST
267
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
snatpool
Description This command will use the specified pool of IP addresses as translation
addresses to create a SNAT. It uses the specified NAT pool instead of
the NAT pool that is already bound to the virtual port in the ACOS
configuration.
NOTE: A NAT pool must already be bound to a virtual port in the ACOS
configuration. This is the virtual port’s default NAT pool.
NOTE: The IP type, IPv4 or IPv6 of the pool must be the same as the IP type of
the real servers.
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
snatpool snat-internal
} else {
snatpool snat-external
}
}
Valid Events
• CLIENT_ACCEPTED
• HTTP_REQUEST
• LB_SELECTED
• SIP_REQUEST
• SIP_RESPONSE
268
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
substr
Description This command returns a sub-string named <string>, based on the
values of the <skip_count> and <terminator> arguments.
This command is the same as the Tcl string range command except that
the value of the <terminator> argument may either be a character or a
count.
Example
when HTTP_REQUEST {
set uri [substr $uri 1 "?"]
log local0. "Uri Part = $uri"
}
log "[substr "abcdefghijklm" 2 "x"]"
log "[substr "abcdefghijklm" 2 "gh"]"
log "[substr "abcdefghijklm" 2 4]"
log "[substr "abcdefghijklm" 2 20]"
log "[substr "abcdefghijklm" 2 0]"
269
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All
switch
Description This is a built-in Tcl command that evaluates one of several scripts,
depending on a given value.
This command matches its string argument against each of the pattern
arguments in order. As soon as the command finds a pattern that
matches the string, it evaluates the following body argument by
passing it recursively to the Tcl interpreter and returns the result of
that evaluation. If the last pattern argument is "default", then it
matches anything. When no pattern argument matches string and no
default is given, the command returns an empty string.
If the initial arguments start with "-", then these arguments are treated
as options. The proceeding options are supported:
Use this following default option for exact matching to compare string
to a pattern.
-exact
If matching string to the patterns, use the following option for glob-
style matching which is the same as implementation by the string
match command.
-glob
270
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will mark the end of options. The argument following this one will
be treated as string even if it starts with a "-".
--
There are two syntaxes provided for the pattern and body arguments.
The first syntax uses a separate argument for each of the patterns and
commands. It is normally easier to use if substitutions are desired on
some of the patterns or commands.
The second form will place all of the patterns and commands together
into a single argument. The argument must have a proper list structure
with elements of the list being the patterns and commands. The second
form facilitates construction of multi-line commands since the braces
around the whole list make it unnecessary to include a backslash at the
end of each line. Since the second form has its pattern arguments in
braces, no command or variable substitutions are performed on them;
this differentiates the second form from the first form in some
situations.
When a body is specified as "-", it means the body’s next pattern
should be used as the body for this pattern. Although, note that when
the next pattern also has a body of "-", then the body after that is used,
and so forth. Doing this allows sharing of a single body among several
patterns.
NOTE: If the result of the switch evaluation is invalid, the script stops but no
compilation error will be displayed. Make sure that all possible
outcomes are valid, or consider using the if ... elseif syntax instead
of switch.
271
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example The use of the following example sends traffic with host header
"www.domain.com" to pool www, host header "www.domain2.com",
which will cause header manipulation and URI rewriting to take place
first, and requests with any other host header will be discarded:
when HTTP_REQUEST {
switch -glob [string tolower [HTTP::uri]] {
"/images*" -
"/static*" { pool service_group_static }
"/blog*" { pool service_group_example }
"/internal*" { pool service_group_internal }
default { pool service_group_dynamic }
272
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
}
Valid Events
All
use
Description This command is used to deal with backwards compatibility. It must be
paired with the node, pool or other ACOS command. It is recommended
that use of these commands be done directly rather than the use
command.
Example
when HTTP_REQUEST {
if { [HTTP::uri] ends_with ".html" } {
use pool service_group_static
} elseif { [HTTP::uri] ends_with ".asp" } {
use pool service_group_dynamic
}
}
Valid Events
All
273
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
virtual
Description This command returns the name of the associated virtual server that
the connection is flowing through.
Example
when HTTP_REQUEST {
log "Virtual Server: [virtual name]"
}
Valid Events
All
when
Description This command allows one to specify an event in an aFleX script. All
aFleX events begin with a when command. Multiple when commands can
be specified within a single aFleX script.
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
drop
}
}
Valid Events
All
274
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
whereis
Description This command will return the geo-location information for a given IP
address. The command will search in the geo-location database in use
on the ACOS device. This can be helpful when used in a script that looks
up information in a geo-location database from a third-party vendor.
Example The use of the following example takes a geo-location database from a
third-party vendor to look up the location of clients who send requests
to a specific VIP.
Each entry in this database has 6 fields. The aFleX script uses a GSLB
CSV template to search the data in 4 of the fields:
275
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
The use of the following example aFleX script performs search in the
database:
when CLIENT_ACCEPTED {
log "This is the country: [IP::client_addr]: [lindex
[whereis [IP::client_addr]] 0]"
log "This is the continent: [IP::client_addr]: [lindex
[whereis [IP::client_addr]] 1]"
}
Example The following steps illustrate the ACOS configuration steps required to
install the geo-location database and use the aFleX script to search the
data in the database.
The following commands will change the CLI to the global configuration
level, and configure a template for extracting data from the geo-
location database:
ACOS#config
ACOS(config)#gslb template csv geo-lookup
ACOS(config-gslb template csv)#field 1 ip-from
ACOS(config-gslb template csv)#field 2 ip-to-mask
ACOS(config-gslb template csv)#field 6 continent
ACOS(config-gslb template csv)#field 3 country
ACOS(config-gslb template csv)#exit
The following commands will load the geo-location database (the .csv
file) to activate it, and verify that it is loaded and activated:
ACOS(config)# gslb system geo-location load ipligence-lite.csv geo-
lookup
ACOS(config)#show gslb geo-location file
276
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
The following command will text the database by searching the location
information for a client IP address:
ACOS(config)#show gslb geo-location ip 74.125.224.33
Last = Last Matched Client, Hits = Count of
Client matched
T = Type, Sub = Count of Sub Geo-location
G(global)/P(policy), S(sub)/R(sub range)
M(manually config)/B(built-in)
Global
Name From To Last
Hits Sub T
--------------------------------------------------------------
------------------
NORTH AMERICA 74.124.206.88 74.126.95.255
0 17821GR
.US
The following command will add the aFleX script to the ACOS device.
The script is copy-pasted into the CLI in this example. Alternatively, the
script can be configured elsewhere and then imported as a file.
ACOS(config)#aflex create geo-lookup-script
Type in your aFleX script (type . on a line by itself when
done)
when CLIENT_ACCEPTED {
log "Country=[lindex [whereis 74.125.224.35] 0]"
277
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
The following commands will bind the aFleX script to a virtual port.
ACOS(config)#slb virtual-server vip-L7-25-130 203.0.113.130
ACOS(config-slb vserver)#port 80 http
ACOS(config-slb vserver-vport)#aflex geo-lookup-script
ACOS(config-slb vserver-vport)#end
NOTE: The provided example does not show real servers and service group
configuration, but they are required. In addition, network connectivity
connection (Network Address Translation (NAT)), may also be needed.
NOTE: The end command is not a part of the VIP configuration. It functions by
returning the CLI prompt to the Privileged EXEC configuration level.
After some traffic is sent to the VIP, the ACOS log will list the geo-
location information for the client:
ACOS#show log
Log Buffer: 30000
May 15 2012 04:15:37 Info [AFLEX]:geo_test:Continent=ASIA
May 15 2012 04:15:37 Info [AFLEX]:geo_test:Country=CN
May 15 2012 04:15:37 Info [AFLEX]:geo_test:Continent=NORTH
AMERICA
May 15 2012 04:15:37 Info [AFLEX]:geo_test:Country=US
May 15 2012 04:15:37 Info [AFLEX]:geo_test:Continent=NORTH
AMERICA
May 15 2012 04:15:37 Info [AFLEX]:geo_test:Country=US
Valid Events
• CLIENT_ACCEPTED
278
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
279
Global Variable Commands
You can use the following operators to quickly modify global variables across
multiple parameters:
l array
l get
l incre
l set
l unset
280
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
array
Description This command will set or return elements in a global array.
This will set the values of one or more elements in the <global_array>.
array size <global_array>
This will provide a list of names for all the elements in the <global_
array>.
array get <global_array> <key>
Valid Events
All.
get
Description This command will return the value of a global variable.
Valid Events
All
281
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
incre
Description This command will increment the specified global variable by a value of
1. It is different from the Tcl command incr where it alters the global
variables.
Valid Events:
All.
set
Description This command will set the value of a local variable.
This will set the <local_variable> to the specified <value>. When the
variable does not exist, a new variable will be created upon this
command’s execution. The recommendation is to use table set/delete
for global variables.
Valid Events
All.
unset
Description This command will unset the value of a local variable.
This will delete the value for the <local_variable>. It also forces the
specified variable to return an empty string.
Valid Events
282
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
All.
283
AAM Commands
The following Application Access Management (AAM) commands are supported:
l AAM::attribute
l AAM::attribute_collection
l AAM::authentication
l AAM::authorization
l AAM::bypass
l AAM::client
l AAM::relay
l AAM::saml
l AAM::session
284
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
AAM::attribute
Description This command will find the attribute value from an attribute collection
in the AAM session according to the attribute name. This command will
return correspondent attribute value to specific attribute name and
multi-valued index.
This returns the value of the attribute specified. Since neither a multi-
valued index or collection ID are specified, the default value of 1 is
assumed for both arguments.
This returns the value of the attribute specified, with the specified
multi-valued index.
AAM::attribute get <attribute-name> collection-id <collection-
id>
This returns the value of the attribute specified within the specified
collection.
AAM::attribute get_multivalue_count <attribute-name>
285
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: This command is only supported on HTTP and HTTPS virtual ports.
Valid Events
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
AAM::attribute_collection
Description This will specify a collection to be used by <collection-id>. If the
backend authentication server type is LDAP, the ACOS device will only
query the attributes defined in this collection.
Valid Events
286
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• AAM_AUTHENTICATION_INIT
AAM::authentication
Description This command will set or return authentication information.
This will set the username for the authentication to the specified value.
AAM::authentication get password
This will set the password for the authentication to the specified value.
AAM::authentication get ntlm_domain
This will set the NTLM domain for the authentication to the specified
value.
For RSA authentication servers, only get username, set username and
get password are supported.
AAM::authentication set server <server_name>
287
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will set an authentication service group to the specified name. The
following are the return values:
0: Success
Example Use the following example to append a different prefix to the username
for authentication. The ACOS device will use the username AUTH_$name
for authentication.
when AAM_AUTHENTICATION_INIT {
set name "AUTH_"
append name [AAM::client get username]
AAM::authentication set username $name
log "=$user@$domain="
288
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example For additional examples, see Example 7: Getting a constructed JWT from
a Session.
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
AAM::authorization
Description This command will set or return authorization information.
289
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will set the LDAP search filter to the specified value.The maximum
length of the search filer is 255. Disable 'use Subject DN as LDAP search
base DN' using the disable option. This option is for the client-SSL
template only. The following are the return values:
0: Success
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
AAM::bypass
Description This command will skip the authentication of a specific real server
destination port through EP.
290
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Syntax AAM::bypass
Example
when HTTP_REQUEST {
if {[HTTP::host} contains ":1433" } {
AAM::bypass
}
}
Valid Events
• HTTP_REQUEST
AAM::client
Description This command will return information about user input.
This will return the username that was input by the user.
AAM::client get password
This will return the password that was input by the user.
AAM::client get ntlm_domain
This will return the NTLM domain that was input by the user. For
example, if the input for the username were in the format
“domain\username”, this command would return the string “domain”.
AAM::client get authn_realm
This will return the realm used for authentication. For example, if the
input for username were in the format “domain\username” or
“username@domain”, this command would return the string “domain”.
Example Use the following example to append a different prefix to the username
for authentication and relay. The ACOS device will use the username
AUTH_$name for authentication, RELAY_$name for relay, and $name for
authorization.
291
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when AAM_AUTHENTICATION_INIT {
set name [AAM::client get username]
AAM::authentication set username "AUTH_$name" AAM::relay
set username "RELAY_$name"
}
Example For additional examples, see Example 7: Getting a constructed JWT from
a Session.
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
AAM::relay
Description This will set or return information about relay.
This will set the username used in relay to the specified value.
AAM::relay get password
This will set the password used in relay to the specified value.
AAM::relay get realm
292
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to append a different prefix to the username
for authentication and relay. The ACOS device will use the username
AUTH_$name for authentication, RELAY_$name for relay, and $name for
authorization.
when AAM_AUTHENTICATION_INIT {
set name [AAM::client get username]
AAM::authentication set username "AUTH_$name"
AAM::relay set username "RELAY_$name"
}
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
AAM::saml
Description SAML is an XML-based markup language for security assertions. This
command returns information about the XML elements.
This command parses the SAML Assertion XML entity and gets XML
element content or attributes from it. The path variable is the XML
element tree path for the SAML Assertion XML entity.
Get content: To get the content of NameID element in the XML entity
use: "AAM::saml get Assertion.Subject.NameID". The result is "test" in
this case.
293
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This command parses the SAML Assertion XML entity and gets the
number of contents for an XML element. The path variable is the XML
element tree path for the SAML Assertion XML entity.
Example To get the number of content elements for NameID element in the XML
entity, use "AAM::saml get_multivalue_count
Assertion.Subject.NameID". The result is 2 in this case.
<saml:Assertion>
<saml:Subject>
<saml:NameID Format="string"> test1 </saml:NameID>
<saml:NameID Format="string"> test2 </saml:NameID>
</saml:Subject>
</saml:Assertion>
Example For more examples with SAML, see Example 7: Getting a constructed
JWT from a Session.
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
294
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
AAM::session
Description This will return information about the auth session.
This will return the name of the AAA policy matched for this session.
This command can be used before the authentication session is
established.
AAM::session get matched_aaa_rule
This will return the AAA rule index this session matched. This command
can be used before the authentication session is established.
AAM::session get cookie_domain
This will return the cookie domain of this session. This command must
be used after the authentication session is established. If it is used
before the authentication session is established, it will return an empty
string.
AAM::session get cookie_domain_group
This will return the cookie domain groups of this session. This
command must be used after the authentication session is established.
If it is used before the authentication session is established, it will
return an empty string.
AAM::session set jwt <jwt-message>
This will set the constructed JWT message to the session, so for the
next client request there is no need to re-construct it and it can be
received through the "AAM::session get jwt" command directly.
This will get the constructed JWT from the session if it is set through
the "AAM::session set jwt <jwt-message>" command before.
295
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
296
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when AAM_AUTHENTICATION_INIT {
if { [IP::addr [IP::client_addr] equals 192.168.1.0/16] } {
AAM::attribute_collection 1
} else {
AAM::attribute_collection 2
}
}
when AAM_AUTHORIZATION_CHECK {
if { [IP::addr [IP::client_addr] equals 192.168.1.0/16] } {
set username_c1 [AAM::attribute get UserName collection_id 1]
297
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
}
}
when AAM_AUTHORIZATION_CHECK {
if { [AAM::session get matched_aaa_rule] equals 3 and [AAM::session get
matched_aaa_policy] equals "ldap"} {
set username [AAM::attribute get UserName collection_id 2]
} else {
set username_c2 [AAM::attribute get displayName collection_id 1]
set businessCategory [AAM::attribute get businessCategory collection_i
1]
when HTTP_REQUEST {
298
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when AAM_AUTHNTICATION_INIT {
if { $reqhost equals “secure.example.domain.com” } {
AAM::authentication set service-group “SECURE-LDAP-GROUP”
}
# use authenticaion server/service-group in configuration
}
when AAM_AUTHENTICATION_INIT {
if { [IP::addr [IP::client_addr] equals 198.168.0.0] } {
AAM::authorization set server “LDAP-INTERNAL”
} else {
AAM::authorization set server “LDAP-EXTERNAL”
}
}
299
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
300
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
301
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when HTTP_REQUEST_SEND {
set jwt_msg [AAM::session get jwt]
if { $jwt_msg equals "" } {
# check necessary jwt contents
set name [AAM::attribute get Fname collection_id 1]
set role_count [AAM::attribute get_multivalue_count
MemberOf]
set nameId [AAM::saml get
Assertion.Conditions.AudienceRestriction.Audience]
set nbf_str [AAM::saml get [email protected]]
set exp_str [AAM::saml get
[email protected]]
set attr_cnt [AAM::saml get_multivalue_count
Assertion.AttributeStatement.Attribute]
# hdr
set jwt_hdr [b64encode "{ \"alg\": \"ES256\", \"typ\":
\"JWT\"}"]
log local0.0 "hdr = { \"alg\": \"ES256\", \"typ\":
\"JWT\"}"
302
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
# signature
set jwt_signature [b64encode [esha256 "$jwt_hdr.$jwt_
payload" ec_256]]
# jwt
set jwt_msg "$jwt_hdr.$jwt_payload.$jwt_signature"
AAM::session set jwt $jwt_msg
}
303
Application Firewall Commands
The following commands related to application firewall are supported:
l APPCLS::application
304
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
APPCLS::application
Description Use the command to view information about the application protocol
and category name from the connection. The command is only
supported when you have configured application firewall for your ACOS
system and you have a valid QOSMOS license. The command only
supports TCP and UDP data plane events and TCP and UDP type
services. At least one single application firewall rule must be configured
to enable application classification. Application classification needs
several packet exchanges, so you cannot predict at which aFleX event
the classification is completed. Application Level Gateway (ALG) is not
supported.
Example The following script returns a list of application protocol names. The
value returned can be pending for a pending state, a blank string for no
application protocol names, or the name of the application protocol if
one is configured.
when HTTP_REQUEST {
log "app protocol = '[APPCLS::application get protocol]'"
}
Example The following script returns a classification path. The value returned
can be a blank string for no application classification path, or the name
of the application classification path if one is configured.
305
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when HTTP_REQUEST {
log "app path = '[APPCLS::application get classification-
path]'"
}
Example The following script returns the list of application category names. The
value returned can be pending for a pending state, a blank string for no
category names, or the names of the categories of the most classified
protocols.
when HTTP_REQUEST {
log "app category = '[APPCLS::application get category]'"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• SERVERSSL_CLIENTHELLO_SEND
• SERVERSSL_DATA
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERHELLO
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
306
AES Commands
The following Advanced Encryption Standard (AES) commands are supported:
l AES::decrypt
l AES::encrypt
l AES::key
307
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
AES::decrypt
Description This command will use an AES key to decrypt content.
Example Use the following example to set the key and log a message about
decrypted content.
when HTTP_REQUEST {
set key [AES::key password 256]
log "The AES decrypted content is [AES::decrypt $key
[HTTP::payload]]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
308
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
AES::encrypt
Description This command will use an AES key to encrypt the content.
Example Use the following example to set the key and log a message about
encrypted content.
when SERVER_DATA {
set key [AES::key password 192]
log "The AES encrypted content is [AES::encrypt $key
[TCP::payload]]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
309
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
AES::key
Description This command will use a randomly created key for
encrypting/decrypting data using AES.
The 8-byte header is of the form “AES xxx” where xxx is 128, 192, or 256.
The resulting key file can be 40, 48, or 56 bytes long.
The [256 | 192 | 128] option specifies the key length, in bits. The
default is 128.
Example Use the following example to log a message about the AES key.
when SERVER_DATA {
log "The AES key is [AES::key password]"
}
Valid Events
All.
310
Category Commands
The following category commands is supported:
l CATEGORY::lookup
311
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
CATEGORY::lookup
Description It accepts one parameter (URL) input. This returns the web category
received from local library or Bright Cloud server.
Syntax CATEGORY::lookup
Valid Events
312
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• AAM_RELAY_INIT
313
Class List Commands
The following class list commands are supported, but currently limited to non-Aho-
Corasick access lists:
l CLASS::exists
l CLASS::match
l CLASS::names
l CLASS::type
NOTE: The class-list must be configured and attached to the same vport as
the aFleX script using a policy template.
NOTE: Class list commands require the LID to be defined in the configuration,
either globally or on the virtual-server or virtual port.
NOTE: Multiple LID definitions may be available for a non-global LID. This
includes a LID in a policy template bound to a virtual port, a LID in a
DNS template bound to a virtual port, a LID in a policy template bound
to a virtual server, and a LID configured in a system-wide policy
template. For more information, see Limit ID Commands.
314
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
CLASS::exists
Description This example will return a Boolean value that indicates whether the
class list exists.
Example Use the following example to log when a class list exists.
when HTTP_REQUEST {
log "The class exists for [CLASS::exists example_list]."
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
315
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
CLASS::match
Description Queries class lists to check for matches and returns any component of a
matching entry.
NOTE: Queries to a string class list are case sensitive. Queries to a DNS class
are not case sensitive.
NOTE: In this release, string class lists can be referenced by name and
externally modified.
NOTE: Class commands read class lists only and do not modify the entries in
any way.
This will return whether <param> matches an [ip | dns] entry in class
list <list-name>. Omitting the [ip | dns] argument will result in IP
entries in the class list being searched first, followed by DNS entries.
CLASS::match <param> <list-name> <key> [ip | dns]
This will return the key of the match when <param> matches an [ip |
dns] entry in class list <list-name>. Omitting the [ip | dns] argument
will result in IP entries in the class list being searched first, followed by
DNS entries.
CLASS::match <param> <list-name> <lid> [ip | dns]
This will return the LID of the match (only if configured) when <param>
matches an [ip | dns] entry in classlist <list-name>. Omitting the [ip
| dns] argument will result in IP entries in the class list being searched
first, followed by DNS entries.
316
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
or
[CLASS::match [IP::client_addr] $classlist ip]
This will return the key of the match when <param> matches an entry in
class list <list-name>.
CLASS::match <param> <operator> <list-name> <lid>
This will return the LID of the match when <param> matches an entry in
class list <list-name>.
CLASS::match <param> <operator> <list-name> <value>
317
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will return the value of the match when <param> matches an entry
in class list <list-name>.
NOTE: The maximum number of string entries for a class list depends on the
total available system memory of the ACOS device.
Example
when HTTP_REQUEST {
log "The class match is [CLASS::match example.com ends_
with example_hosts]"
log "The class match key is [CLASS::match www starts_with
example_hosts key]"
log "The class match lid is [CLASS::match www.example.com
equals example_hosts lid]"
log "CLASS Match value: [CLASS::match www.example.com
equals example_hosts value]"
}
Example Use the following example to redirect an HTTP request to the URL that
has an entry in the class list.
when HTTP_REQUEST {
set uri [string tolower [HTTP::uri]]
set redirect_url [CLASS::match $uri equals value]
if { not ($redirect_url equals "") } {
HTTP::redirect $redirect_url
log "The redirected $uri is $redirect_url" }
}
}
318
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
CLASS::names
Description This command will return a list of class-list names.
Syntax CLASS::names
319
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when HTTP_REQUEST {
log "CLASS Name: [CLASS::names]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
CLASS::type
Description This command will return the type of the specified class list.
320
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
The type value that can be returned by aFleX depends on whether the
type was explicitly specified during class-list configuration. If the type is
a pair of empty brackets ( [] ), the class list does not contain any
entries.
• Explicitly configured: dns, ipv4, ipv6, string
• Implicitly configured by the ACOS device based on the class-list
entries: [], [dns], [ipv4], [ipv6], [dns, ipv4], [dns, ipv6]
Example Use the following example to log the class type for the class-list name.
when HTTP_REQUEST {
log "The class type for example_ips is [CLASS::type
example_ips]"
log "The class type for example_hosts is [CLASS::type
example_hosts]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
321
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
322
Compression Commands
The following compression commands are supported on HTTP traffic (original proxy)
and HTTP2 traffic (new proxy):
l COMPRESS::brotli
l COMPRESS::disable
l COMPRESS::enable
l COMPRESS::gzip
COMPRESS::brotli
Description Brotli (RFC 7932) is a lossless compression technique that compresses
data utilizing a combination of the LZ77 algorithm. ADC supports Brotli
compression and decompression for HTTP/2 protocol and HTTP/1
traffic is also supported when compression algorithm is specified
through method order command under http template or via aFleX.
Specify the value of the window size (i.e. value of lgwin) of Brotli.
COMPRESS::method_order <compression method order>
323
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
COMPRESS::brotli sliding-window
when HTTP_REQUEST {
COMPRESS::enable
COMPRESS::brotli level 4
COMPRESS::brotli sliding-window 5
}
COMPRESS::method_order
when HTTP_REQUEST {
COMPRESS::enable
COMPRESS::brotli level 4
COMPRESS::brotli sliding-window 5
COMPRESS::method_order gzip brotl
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
324
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
COMPRESS::disable
Description This command will disable the compression for an HTTP response.
Syntax COMPRESS::disable
Example Use the following example to check if a particular header response does
not exist, and then disable compression.
when HTTP_RESPONSE {
if { not ([HTTP::header exists "Accept-Encoding"]) } {
COMPRESS::disable
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
COMPRESS::enable
Description This command will enable compression for an HTTP response.
325
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Syntax COMPRESS::enable
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
COMPRESS::gzip
Description This command will set the level for HTTP compression.
326
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: Setting the compression level to a higher value results in more HTTP
compression at a greater CPU cost. Additional CPU usage can outweigh
the benefit of a higher level. For example, setting compression to level 6
can provide equivalent performance to level 9. For best performance,
A10 Networks recommends setting compression to level 1.
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
327
Database Load-Balancing Commands
The following commands related to database load balancing (DBLB) are supported:
l DB::command
l DB::query
328
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
DB::command
Description The command returns a numeric value that represents the command
number.
Syntax DB::command
Example Use the following example to log the DB command value to the
assigned service group.
when DB_COMMAND {
log "DB Command: [DB::command]"
pool mssg1_service_group
}
Valid Events
DB_COMMAND
DB::query
Description This command returns a string that holds the entire SQL query which
was sent by the client.
Syntax DB::query
Example Use the following example to log the DB query value to the assigned
service group.
when DB_QUERY {
log "DB Query: [DB::query]"
pool mssg1_service_group
}
Valid Events
DB_QUERY
329
Diameter Load-Balancing Commands
You can use the following operators to quickly modify global variables across
multiple parameters:
l DIAMETER::app_id
l DIAMETER::avp
l DIAMETER::cmd_code
l DIAMETER::length
l DIAMETER::version
330
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
DIAMETER::app_id
Description This command returns the application ID of a Diameter message.
Syntax DIAMETER::app_id
Example Use the following example to log the Diameter App ID value.
when DIAMETER_REQUEST {
log "The DIAMETER::app_id is [DIAMETER::app_id]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• DIAMETER_ANSWER
• DIAMETER_ANSWER_SEND
• DIAMETER_REQUEST
• DIAMETER_REQUEST_SEND
• SERVER_CLOSED
DIAMETER::avp
Description This command is used to read, write, or delete AVPs.
This command returns a list of the IDs of AVPs with matching <avp_
code> or <name>. If the <avp_code> or <name> is not specified, the IDs of
all AVPs are returned.
331
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: The order of IDs might not be the same as the order of the AVPs in the
packet.
This command returns the numeric AVP code of the AVP with ID <id>. If
the [name] is specified and the AVP is a standard AVP, a user-readable
string is returned; otherwise, an empty string is returned. If [type] is
specified, and the AVP is a standard AVP, its type is returned;
otherwise, an empty string is returned.
DIAMETER::avp <id> index
This command returns the index value within the packet of the AVP
with ID <id>.
DIAMETER::avp <id> flags
This command returns flags of the AVP with ID <id> in the following
format: {V|-}{M|-}{P|-}
DIAMETER::avp <id> length
This command returns the vendor_id of the AVP with ID <id> if the AVP
has the “V” flag specified; otherwise, an empty string is returned.
DIAMETER::avp <id> value [<type>]
This command returns the value of the AVP with ID <id>. If the specified
<type> is Unsigned32, Unsigned64, Integer32, Integer64, Address, or
OctetString, the value is interpreted accordingly if it does not conflict
with the AVP (for example, for an Integer32 AVP, Unsigned64 cannot be
returned). For AVPs of type DiameterIdentity, Grouped, Time, DiamURI,
Enumerated, or UTF8String, a byte array is returned.
DIAMETER::avp <id> delete
332
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to log the AVP count, ID values, ID values for
code 257, and session IDs.
when DIAMETER_REQUEST {
log "Number of AVPs = [DIAMETER::avp count]"
log "Ids of all AVPs = [DIAMETER::avp get_ids]"
log "Ids of AVPs of code 257 = [DIAMETER::avp get_ids 257]"
log "Ids of Session-Id AVPs = [DIAMETER::avp get_ids
Session-Id]"
}
Example Use the following example to incrementally log ID codes, code names,
code types, index values, flag values, and message lengths.
when DIAMETER_REQUEST {
set ids [DIAMETER::avp get_ids]
for { set i 0 } { $i < [llength $ids] } { incr i } {
set id [lindex $ids $i]
log "DIAMETER::avp $id code = [DIAMETER::avp $id code]"
log "DIAMETER::avp $id code name = [DIAMETER::avp $id code
name]"
log "DIAMETER::avp $id code type = [DIAMETER::avp $id code
type]"
333
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to insert a new AVP to the Diameter message
and then log AVP code, code names, code types, index values, flag
values, message length, and vendor IDs of the new AVP.
when DIAMETER_REQUEST_SEND {
set newid [DIAMETER::avp insert 12345 6789 VMP 567 type
Unsigned32]
log "DIAMETER::avp $newid code = [DIAMETER::avp $newid code]"
log "DIAMETER::avp $newid code name = [DIAMETER::avp $newid
code name]"
log "DIAMETER::avp $newid code type = [DIAMETER::avp $newid
code type]"
log "DIAMETER::avp $newid index = [DIAMETER::avp $newid
index]"
log "DIAMETER::avp $newid flags = [DIAMETER::avp $newid
flags]"
log "DIAMETER::avp $newid length = [DIAMETER::avp $newid
length]"
log "DIAMETER::avp $newid vendor_id = [DIAMETER::avp $newid
vendor_id]"
log "DIAMETER::avp $newid value Unsigned32 = [DIAMETER::avp
$newid value Unsigned32]"
334
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to add a new AVP with ID 12345 and then
replace the values for Flag and Type. Log AVP index, flags, message
length, and vendor ID.
when DIAMETER_REQUEST_SEND {
set newid [DIAMETER::avp 0 insert 12345 6789 VMP 567 type
Unsigned32]
DIAMETER::avp $newid replace value 12345 type Unsigned32 flags
VMP 567
log "DIAMETER::avp $newid index = [DIAMETER::avp $newid
index]"
log "DIAMETER::avp $newid flags = [DIAMETER::avp $newid
flags]"
log "DIAMETER::avp $newid length = [DIAMETER::avp $newid
length]"
log "DIAMETER::avp $newid vendor_id = [DIAMETER::avp $newid
vendor_id]"
log "DIAMETER::avp $newid value Unsigned32 = [DIAMETER::avp
$newid value Unsigned32]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• DIAMETER_ANSWER
• DIAMETER_ANSWER_SEND
• DIAMETER_REQUEST
• DIAMETER_REQUEST_SEND
• SERVER_CLOSED
DIAMETER::cmd_code
Description This command returns the command code, or its name of a Diameter
message. If [name] is specified, an empty string or one of the following
335
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
is returned as appropriate: ASR, ASA, ACR, ACA, CER, CEA, DWR, DWA,
DPR, DPA, RAR, RAA, STR, or STA.
If you use the [name] option, the name is returned,. If you omit the
[name] option, the command code is returned instead.
Example Use the following example to log the Diameter code value.
when DIAMETER_REQUEST {
log "DIAMETER::cmd_code = [DIAMETER::cmd_code]"
}
Example Use the following example to log the Diameter code name.
when DIAMETER_REQUEST {
log "DIAMETER::cmd_code name = [DIAMETER::cmd_code name]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• DIAMETER_ANSWER
• DIAMETER_ANSWER_SEND
• DIAMETER_REQUEST
• DIAMETER_REQUEST_SEND
• SERVER_CLOSED
DIAMETER::length
Description This command returns the length of a Diameter message.
Syntax DIAMETER::length
Example Use the following example to log the Diameter message length.
when DIAMETER_REQUEST {
log "DIAMETER::length = [DIAMETER::length]"
336
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• DIAMETER_ANSWER
• DIAMETER_ANSWER_SEND
• DIAMETER_REQUEST
• DIAMETER_REQUEST_SEND
• SERVER_CLOSED
DIAMETER::version
Description This command returns the version of a Diameter message.
Syntax DIAMETER::version
Example Use the following example to log the Diameter version value.
when DIAMETER_REQUEST {
log "DIAMETER::version = [DIAMETER::version]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• DIAMETER_ANSWER
• DIAMETER_ANSWER_SEND
• DIAMETER_REQUEST
• DIAMETER_REQUEST_SEND
• SERVER_CLOSED
337
DNS Commands
The following DNS commands are supported:
l DNS::additional
l DNS::answer
l DNS::authority
l DNS::cache
l DNS::class
l DNS::header
l DNS::is_dnssec
l DNS::len
l DNS::name
l DNS::opt
l DNS::query
l DNS::question
l DNS::rdata
l DNS::return
l DNS::rr
l DNS::ttl
l DNS::type
338
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
DNS::additional
Description This command returns, inserts, removes, or clears RRs from the
Additional section. With no arguments, the command returns a Tcl list
of RR objects. With an argument, the command inserts/removes RR Tcl
objects in the Additional section or clears all RRs from the Additional
section.
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::answer
Description This command returns, inserts, removes, or clears RRs from the Answer
section. With no arguments, this command returns a Tcl list of RR
objects. With an argument, this command inserts or removes RR Tcl
objects in the Answer section or clears all RRs from the Answer section.
Example Use the following example to set RR objects for a DNS response.
when DNS_RESPONSE {
set rr [DNS::rr example.tld 149 IN A 127.0.0.10]
DNS::answer insert $rr
log "rrs = '[DNS::answer]'"
}
Example Use the following example to remove SOA records from the Answer
section.
when DNS_RESPONSE {
set rr [DNS::rr example.com 149 IN A 127.0.0.10]
DNS::answer insert $rr
log "DNS Answer: [DNS::answer]"
}
339
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to remove one RR from the answer.
when DNS_RESPONSE {
set rrs [DNS::answer]
set i 0
foreach rr $rrs {
log "i = $i rr = '$rr'"
incr i
}
set rr1 [lindex $rrs 0]
log "remove rr1 = '$rr1'"
DNS::answer remove $rr1
set k 0
foreach rr [DNS::answer] {
log "k = $k rr = '$rr'"
incr k
}
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::authority
Description This command returns, inserts, removes, or clears RRs from the
Authority section. With no arguments, this command returns a Tcl list
of RR objects. With an argument, this command returns inserts or
removes RR Tcl objects in the Authority section or clears all RRs from
the Authority section.
Example Use the following example to remove all the authority records.
when DNS_RESPONSE {
set rrs [DNS::answer]
set i 0
foreach rr $rrs {
log " i = $i rr ='$rr'"
340
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
incr i
}
set rrs2 [DNS::authority]
set j 0
foreach rr2 $rrs2 {
log "j = $j rr2 = '$rr2'"
incr j
}
DNS::authority clear
}
Example Use the following example to remove a single authority record if there
is more than one authority record.
when DNS_RESPONSE {
set rrs2 [DNS::authority]
set rr2 [lindex $rrs2 1]
DNS::authority remove $rr2
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::cache
Description This command controls the DNS cache access and update for the
current DNS session.
NOTE: This command enables or disables the DNS cache for the current DNS
session.
NOTE: This command is only effective when global DNS cache or a DNS cache
template is enabled.
DNS::cache update
341
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: This command updates the DNS cache with content changed through
aFleX.
Example Use the following example to bypass the cached response for a DNSSEC
query.
when DNS_REQUEST {
if {[DNS::is_dnssec]} {
log "This is DNSSEC request!"
DNS::cache disable
}
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::class
Description This command gets or sets the resource record class field (IN, CH, HS,
and so on).
Example Use the following example to insert a record for a DNS response.
when DNS_RESPONSE {
set rr [DNS::rr example.com 149 IN A 127.0.0.10]
set rr1 [DNS::class $rr HS]
DNS::answer insert $rr1
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
342
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
DNS::header
Description This command gets or sets simple bits or byte fields. Return value is
always an integer except for successful recognition of the rcode or
opcode fields, where a string is returned.
Example Use the following example to log all questions and responses for DNS
requests and responses:
when DNS_REQUEST {
343
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::is_dnssec
Description This command checks for a DNSSEC query or reply. It returns 1 if true
and 0 if false.
Syntax DNS::is_dnssec
Valid Events
344
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• DNS_REQUEST
• DNS_RESPONSE
DNS::len
Description This command returns the DNS packet message length.
Syntax DNS::len
Example Use the following example to log the packet length for a DNS request.
when DNS_REQUEST {
log "DNS len: [DNS::len]"
}
Example Use the following example to log the packet length for a DNS response.
when DNS_RESPONSE {
log "DNS len: [DNS::len]"
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::name
Description This command gets or sets the resource record name field (FQDN); for
example, “www.example.com”.
Example Use the following example to set the FQDN for a DNS response.
when DNS_RESPONSE {
set rr [DNS::rr www1.example.com 149 IN A 127.0.0.10]
set rr1 [DNS::name $rr "www2.example.com"]
DNS::answer insert $rr1
}
Valid Events
345
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• DNS_REQUEST
• DNS_RESPONSE
DNS::opt
Description This command gets or sets the parameters of a DNS OPT record. If there
is no OPT record in the DNS content, the return value is NULL for ‘get’
commands.
NOTE: This command gets or sets the DO value for DNSSEC in an OPT record.
NOTE: This command gets or sets the UDP size value in an OPT record.
NOTE: This command gets or sets the extended RCODE value in an OPT record.
Example Use the following example to log DNS opt record for DNS requests and
responses.
when DNS_REQUEST {
if { [DNS::is_dnssec] } {
log "This is DNSSEC request!"
log "DNS opt udpsize: [DNS::opt udpsize]"
}
}
when DNS_RESPONSE {
if { [DNS::opt do] } {
DNS::opt udpsize 8196
}
}
346
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::query
Description This command returns a Tcl list of RR Tcl objects lists, one for each
section: Answer, Authority, and Additional.
NOTE: The <target> can be “dnsx”. The <name> is the fully qualified domain
name (for example, “www.example.com”). The <type> specifies the
record type (A, AAA, MX, NPTR, and so on). The dnssec option gets
DNSSEC data.
Example Use the following example to return RR Tcl objects for a DNS response.
when DNS_RESPONSE {
set rrtcl [DNS::query dnsx ns1.example.com SOA]
foreach rrs $rrtcl {
foreach rr $rrs {
if { [DNS::type $rr] equals "SOA" } {
DNS::additional insert $rr
}
}
}
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::question
Description This command gets or sets the question field value. A question RR has
no rdata and only requests with qdcount == 1 are accepted. The return
types for name, type, and class are all strings. Type returns/accepts any
347
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
of the valid DNS types defined in the RFCs. The class returns/accepts IN,
CH, and HS.
Example Use the following example to set a question field name and object for a
DNS request and response.
when DNS_REQUEST {
if { [DNS::question name] contains "internal.example.com"
} {
log "DNS Question name: [DNS::question name]"
DNS::question name "internal.example.com"
}
}
when DNS_RESPONSE {
set rr_ext [DNS::rr external.example.com 300 IN A
192.168.0.80]
set rr_int [DNS::rr internal.example.com 300 IN A
192.168.0.0]
if { [DNS::question name] contains "internal.example.com"
} {
log "Original response question name: [DNS::question
name]"
DNS::answer insert $rr_int
} elseif { [DNS::question name] contains
"external.example.com" } {
DNS::answer insert $rr_ext
}
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::rdata
Description This command gets or sets the resource record rdata field.
348
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to set a resource record object for a DNS
request.
when DNS_RESPONSE {
set rr [DNS::rr example.com 149 IN A 127.0.0.10]
set rr2 [DNS::rdata $rr "192.168.0.0"]
DNS::answer insert $rr2
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::return
Description This command skips all further processing after Tcl execution and sends
the DNS packet in the opposite direction.
Syntax DNS::return
NOTE: When responding to a DNS query in the event DNS_REQUEST, you must
use DNS::return in order to prevent the response being overwritten by
the real DNS server or by the GSLB function when running GSLB on
ACOS."
Example Use the following example to set a resource record name and object for
a DNS request.
when DNS_REQUEST {
if { [DNS::question name] contains "a10.example.com" } {
DNS::header qr 1
DNS::header ra 1
set name [DNS::question name]
set rr1 [DNS::rr $name 0 IN CNAME
vip1.a10.example.com]
DNS::answer insert $rr1
DNS::return
}
}
349
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::rr
Description This command creates a new resource record object with the specified
attributes.
NOTE: The <name> is the FQDN (for example, “www.example.com”). The <ttl>
specifies time to live in seconds. The <class> specifies the DNS class
(IN, CH, HS, and so on). The <type> specifies the record type (A, AAA,
MX, NPTR, and so on). The <rdata> value depends on the type of RR.
For example for an A record, the <rdata> will be an IP address
(“X.X.X.X”).
Example Use the following example to set a resource record object for a DNS
response.
when DNS_RESPONSE {
set rr [DNS::rr www.example.com 149 IN A 127.0.0.10]
log "DNS rr: $rr"
}
Example Use the following example to set a resource record name and object for
a DNS response.
when DNS_RESPONSE {
set name [DNS::question name]
set rr [DNS::rr $name 0 IN CNAME vip1.a10.example.com]
DNS::answer insert $rr
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
350
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
DNS::ttl
Description This command gets or sets the resource record TTL field.
Example Use the following example to set resource record TTL field for a DNS
response.
when DNS_RESPONSE {
set rr [DNS::rr example.com 149 IN A 127.0.0.10]
set rr1 [DNS::ttl $rr 200]
DNS::answer insert $rr1
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
DNS::type
Description This command gets or sets the resource record type field (A, AAAA, MX,
NPTR, etc.).
Example Use the following example to set the resource record for a DNS
response.
when DNS_RESPONSE {
set rr [DNS::rr example.com 149 IN A 127.0.0.10]
set rr1 [DNS::type $rr CNAME]
DNS::answer insert $rr1
}
Valid Events
• DNS_REQUEST
• DNS_RESPONSE
351
Financial Information eXchange Commands
The following commands related to Financial Information eXchange (FIX) are
supported:
l FIX::begin_string
l FIX::body_length
l FIX::msg_seq_num
l FIX::msg_type
l FIX::sender_compid
l FIX::sending_time
l FIX::target_compid
352
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
FIX::begin_string
Description This command returns the value of the BeginString tag. The BeginString
tag identifies the beginning of a new FIX message and the FIX protocol
version. It is always the first field in the message and is always
unencrypted.
Syntax FIX::begin_string
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
Example Use the following example to log the beginning string for a FIX request.
when FIX_REQUEST {
log "FIX begin_string: [FIX::begin_string]"
}
Valid Events
• FIX_REQUEST
• FIX_RESPONSE
FIX::body_length
Description This command returns the value of the BodyLength tag. The FIX
BodyLength tag gives the message length in bytes, forward to the
CheckSum field. It is always the second field in the FIX message and is
always unencrypted.
Syntax FIX::body_length
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
Example Use the following example to log the body length of a FIX request.
when FIX_REQUEST {
log "FIX body_length: [FIX::body_length] bytes"
}
353
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• FIX_REQUEST
• FIX_RESPONSE
FIX::msg_seq_num
Description This command returns the integer message sequence number. It is
always a positive value.
Syntax FIX::msg_seq_num
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
Example Use the following example to log the message sequence number of a FIX
request.
when FIX_REQUEST {
log "FIX msg_seq_num: [FIX::msg_seq_num]"
}
Valid Events
• FIX_REQUEST
• FIX_RESPONSE
FIX::msg_type
Description This command returns the value of the MsgType tag. The MsgType tag
defines the message type, which is a string that is one or two
characters in length. It is always the third field in the message and is
always unencrypted.
Syntax FIX::msg_type
NOTE: A “U” as the first character in the MsgType field (examples: U, U2, and
so on) indicates that the message format is privately defined between
the sender and receiver.
354
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
Example Use the following example to log the message type of a FIX request.
when FIX_REQUEST {
log "FIX msg_type: [FIX::msg_type]"
}
Valid Events
• FIX_REQUEST
• FIX_RESPONSE
FIX::sender_compid
Description This command returns the value of the SenderCompID tag. The
SenderCompID is an assigned string value used to identify the firm
sending the FIX message.
Syntax FIX::sender_compid
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
Example Use the following example to log the sender company ID of a FIX
request.
when FIX_REQUEST {
log "FIX sender_compid: [FIX::sender_compid]"
}
Valid Events
• FIX_REQUEST
• FIX_RESPONSE
FIX::sending_time
Description This command returns the value of the time of message transmission,
always expressed in UTC time. The time is returned as a string in either
of the following formats:
355
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Syntax FIX::sending_time
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
Example Use the following example to log the timestamp of a FIX request.
when FIX_REQUEST {
log "FIX sending_time: [FIX::sending_time]"
}
Valid Events
• FIX_REQUEST
• FIX_RESPONSE
FIX::target_compid
Description This command returns the value of the TargetCompID tag. The
TargetCompID is an assigned string value used to identify the firm
receiving the FIX message.
Syntax FIX::target_compid
NOTE: This event is only valid on TCP-proxy and FIX virtual ports.
Example Use the following example to log the target company ID of a FIX
request:
when FIX_REQUEST {
log "FIX target_compid: [FIX::target_compid]"
}
356
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• FIX_REQUEST
• FIX_RESPONSE
357
HTTP Commands
The following HTTP commands are supported on HTTP traffic (original proxy) and
HTTP2 traffic (new proxy):
l HTTP::close
l HTTP::collect
l HTTP::cookie
l HTTP::disable
l HTTP::fallback
l HTTP::header
l HTTP::host
l HTTP::is_keepalive
l HTTP::is_redirect
l HTTP::method
l HTTP::path
l HTTP::password
l HTTP::payload
l HTTP::query
l HTTP::redirect
l HTTP::release
l HTTP::request
l HTTP::retry
l HTTP::request_num
l HTTP::respond
l HTTP::status
l HTTP::stream
l HTTP::uri
358
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
l HTTP::username
l HTTP::version
359
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
HTTP::close
Description This command will insert a “Connection: close” header and close the
HTTP connection.
Syntax HTTP::close
Example
Example 1:
when HTTP_REQUEST {
if { not ([IP::addr [IP::client_addr] equals
192.168.1.0/24]) } {
HTTP::close
}
}
Example 2:
when ICAP_RESPONSE {
if { not ([IP::addr [IP::client_addr] equals 10.10.10.10/24])
} {
HTTP::close
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::collect
Description This command will collect the amount of data specified using the
<length> argument. When the system collects the specified amount of
360
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Syntax HTTP::collect
This will collect data. It is important to note when the content length is
dropped, as it may strand your connection.
HTTP::collect [<length>]
This will collect the amount of data that is specified with the <length>
argument. Specifying a value larger than the actual length may strand
your connection.
• When the <length> option is not applied, the ACOS device behaves
as follows:
• When the packet has an HTTP Content-Length header, the ACOS
device will collect as much data as specified by the header, up to
1.25 MB, the maximum allowable limit.
• When the packet does not have an HTTP Content-Length header,
the ACOS device keeps collecting data until one of the following
occurs:
• The collection of 1.25 MB of data (This is the maximum limit.)
• A zero-size chunk-encoded packet is obtained
• RST is obtained from the server
• FIN is obtained from the server
• Typically, a packet without a Content-Length header is a chunk-
encoded packet.
361
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE:
• The ACOS device will buffer the entire payload before responding
to the client, so when the object to be collected is huge, there may
be a performance hit.
• If RAM caching is enabled, the HTTP::collect command is not
supported.
• When the HTTP::payload replace command is used in the same
aFleX policy as the HTTP::collect command:
• For packets not containing chunk-encoded data, the ACOS device
replaces the collected data with the specified string.
• For chunk-encoded packets, the command de-chunks the packet
first, removing the chunk header and assembling the packet. The
ACOS device will then replace the content with the new string
without re-chunking the payload. The packet received by the client
will not be chunk-encoded.
• The HTTP::payload replace command supports only clear text
replacement. If the server response is compressed (transfer-
encoded, tar, gz, bz, and so on), it will not work correctly.
Therefore, when HTTP::collect is used in an aFlex policy (also
with event HTTP_RESPONSE), the “Accept-Encoding” header will be
automatically removed from the Request.
Example
when HTTP_RESPONSE {
if { ([HTTP::status] == 200) and ([HTTP::header "Content-
Type"] contains "text") } {
if { [HTTP::header exists Content-Length] } {
HTTP::collect [HTTP::header Content-Length]
} else {
HTTP::collect
}
}
Valid Events
• HTTP_REQUEST
362
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
HTTP::cookie
Description This command will query for or manipulate cookies in HTTP requests
and responses. It replaces the http_cookie command. If the attribute of
the incoming set-cookie string in aFlex does not conform to RFC6265
standard, ACOS treats the string as an extension variable. However, if
there is more than one of such attributes, only the last variable is
stored and the previous ones are discarded.
When the extension is free format, HTTP::cookie only supports sanitize for
standard attributes.
This will return the names of all the cookies present in the HTTP header.
HTTP::cookie count
This will return the number of cookies present in the HTTP header.
HTTP::cookie [value] <name> [string]
This will set or get the cookie value of the given name in an HTTP
request. Drop the keyword value from this command if the cookie
name does not collide with any of the other commands.
HTTP::cookie encrypt <name> <pass phrase> ["128" | "192" |
"256"]
Encrypts the value for the given cookie using a key generated from the
pass phrase.
HTTP::cookie decrypt <name> <pass phrase> ["128" | "192" |
"256"]
Decrypts the value for the given cookie using a key generated from the
pass phrase.
HTTP::cookie version <name> [version]
363
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will set or get the cookie port lists for V2 cookies.
HTTP::cookie insert name <name> value <value> [path <path>]
[domain <domain>] [version <0 | 1 | 2>]
This will add or replace a cookie in an HTTP response. The default value
for the version is 0.
HTTP::cookie remove <name>
This will remove everything except the specified attributes from the
cookie.
HTTP::cookie exists <name>
This will set or get the max-age. Version 1 cookies and response
messages are only affected by this.
HTTP::cookie expires <name> [seconds] [absolute | relative]
This will set or get the expires attribute. Version 0 cookies are only
affected. If an absolute argument is specified, the seconds value will
represent the number of seconds based from the UNIX epoch, which is
January 1, 1970. The default number of seconds is relative, which is the
number of seconds from the current time. It applies to response
messages only.
HTTP::cookie comment <name> [comment]
364
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will set or get the cookie comment. Version 1 cookies and response
messages are only affected by this.
HTTP::cookie secure <name> [enable | disable]
This will set or get the value of the secure attribute. Response
messages are only affected by this.
HTTP::cookie commenturl <name> [commenturl]
This will set or get the comment URL. Version 2 cookies and response
messages are only affected by this.
HTTP::cookie discard <name> [enable | disable]
This will set or get the value of the discard attribute. Version 2 cookies
and response messages are only affected by this.
Example
Example 1: The following example aFleX script adds HttpOnly to
all cookies set by the server.
when HTTP_RESPONSE {
set current_time [TIME::clock seconds]
foreach cookie_name [HTTP::cookie names] {
if { [HTTP::cookie exists "$cookie_name"] } {
set new_cookie "$cookie_name=[HTTP::cookie value
"$cookie_name"]"
if { [HTTP::cookie expires "$cookie_name"] >
$current_time } {
set cookie_expires [clock format [HTTP::cookie
expires "$cookie_name"] -format {%a, %d %b %Y %H:%M:%S GMT} -
gmt 1]
append new_cookie "; Expires=$cookie_expires"
}
if { [HTTP::cookie domain "$cookie_name"] ne "" }
{
append new_cookie "; Domain=[HTTP::cookie
domain "$cookie_name"]"
}
365
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example 2:
when ICAP_RESPONSE {
if { not ([IP::addr [IP::client_addr] equals 192.168.1.0/24])
} {
HTTP::close
}
}
Valid Events
• HTTP_REQUEST
• HTTP_RESPONSE
• ICAP_RESPONSE
HTTP::disable
Description This command will change an HTTP proxy from full parsing to pass-
through mode.
Syntax HTTP::disable
Example
366
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when CLIENT_ACCEPTED {
TCP::collect 7
}
when CLIENT_DATA {
if { [TCP::payload 7] equals "CONNECT" } {
SSL::disable
}
TCP::release
}
when HTTP_REQUEST {
if { [HTTP::method] equals "CONNECT" } {
log "A HTTP CONNECT was received."
HTTP::respond 200 content OK
HTTP::disable
SSL::enable
SSL::collect
}
}
Example
when HTTP_REQUEST {
HTTP::disable
log "Work with SSL Proxy or TCP (generic) "
node 192.168.80.81 80
}
Example
when HTTP_RESPONSE {
HTTP::disable
log "Ignore HTTP processes after this point."
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
367
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• SERVER_CONNECTED
• SERVERSSL_DATA
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERHELLO
HTTP::fallback
Description This command will specify or override the fallback host that is specified
in the HTTP profile.
Example
when LB_FAILED {
HTTP::fallback "http://backup.example.com"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
HTTP::header
Description This command will query for or manipulate an HTTP header.
This will return the value of the HTTP header named <name>. Drop the
<value> argument when the header name does not enter any conflicts
with subcommands.
HTTP::header names
This will return a list of all the headers present on the request or
response.
HTTP::header count
368
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will return the number of HTTP headers present in the request or
response.
HTTP::header at <index>
This will return the HTTP header that the ACOS device finds at the zero-
based index value.
HTTP::header exists <name>
This will return true if the named header is present on the request or
response.
HTTP::header insert ["lws"] <name> <value>
This will insert the named HTTP header and its value into the end of the
HTTP request or response. If "lws" is specified, the ACOS device adds
linear white space to long header values.
HTTP::header insert ["lws"] {n1, v1, n2, v2, n3, v3, …}
This will pass a Tcl list to insert into a header. In this situation, the
ACOS device will treat the list as a list of name/value pairs. If "lws" is
specified, the ACOS device adds linear white space to long header
values.
HTTP::header [value] <name> <string>
This will set the value of the named header. When there is a present
header, the command will replace the header; In other situations, the
command will add the header. Drop the <value> argument if the header
name does not collide with any other values.
HTTP::header replace <name> [<string>]
This will replace the last occurrence of the named header with the
string <string>. It performs a header insertion when the header was
not present.
HTTP::header remove <name>
This will remove everything except the headers specified. It does not
remove essential HTTP headers, though.
369
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This will return the HTTP header that the ACOS device finds in at the
zero-based index value. The nvp option will return the entire header as
a name-value-pair (NVP).
HTTP::header values <name>
This will return the value or values of the HTTP header named <name>.
NOTE:
l If both HTTP::cookie and HTTP::header commands are used to modify
the same header, then HTTP::cookie takes precedence. When there is
a single value for the HTTP header, that value is returned. When
there are multiple headers with the same name, the command
returns the last value from all of them. If it is required to check all
HTTP headers that include multiple headers of the same name, use
HTTP::header at <index> nvp.
l To check if an HTTP header exists or not, use the HTTP::header
exists <name> command. For example, HTTP::header exists “foo”
will return true if an HTTP header exists and false if it doesn't exist. If
"exists" in the above command is misspelled as "exist", then ACOS
will interpret this command differently and insert a header called
"exist" with the string "foo" as HTTP::header [value] <name>
<string>.
Example
when HTTP_REQUEST {
if { [HTTP::header exists "Accept-Encoding"] } {
HTTP::header remove “Accept-Encoding”
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
370
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
HTTP::host
Description This command will return the host name of the HTTP request.
Syntax HTTP::host
Example
Example 1:
when HTTP_REQUEST {
if { [HTTP::host] starts_with "secure"} {
HTTP::redirect "https://[HTTP::host][HTTP::uri]"
}
}
Example 2:
when ICAP_RESPONSE {
if { [HTTP::host] starts_with "secure"} {
HTTP::redirect "https://[HTTP::host][HTTP::uri]"
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::is_keepalive
Description This command will return a true value when it is a Keep-Alive
connection.
Syntax HTTP::is_keepalive
Example
when HTTP_RESPONSE {
if { not ([HTTP::is_keepalive]) } {
371
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
HTTP::close
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
HTTP::is_redirect
Description This command will return a true value if the response is a redirect of a
certain type.
Syntax HTTP::is_redirect
Example
Example 1:
when HTTP_RESPONSE {
if { [HTTP::is_redirect] } {
log "This is the server redirect value:"
}
}
Example 2:
when ICAP_RESPONSE {
if { [HTTP::is_redirect] } {
log "This is the server redirect value:"
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
372
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
HTTP::method
Description This command will return the type of HTTP request method.
Syntax HTTP::method
Example
Example 1:
when HTTP_REQUEST {
log "This is the HTTP method: [HTTP::method]"
}
Example 2:
when ICAP_RESPONSE {
{
log "This is the HTTP method: [HTTP::method]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::path
Description This command will return the path part of the HTTP request.
Example
Example 1:
when HTTP_REQUEST {
log "This is the host HTTP: [HTTP::host]"
log "This is the path of HTTP: [HTTP::path]"
}
Example 2:
373
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when HTTP_REQUEST {
if { [HTTP::path] equals "/" } {
HTTP::redirect "https://[HTTP::host]/exchange/"
} else {
pool example_service-group
}
}
Example 3:
when ICAP_RESPONSE {
log "This is the host HTTP: [HTTP::host]"
log "This is the path of HTTP: [HTTP::path]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::password
Description Returns the password from HTTP basic authentication.
Syntax HTTP::password
Example
[AFLEX_NSCMDID_HTTP_PASSWORD] = {
"HTTP::password",
A10Tcl_HTTP_PasswordObjCmd, A10TclCompileHTTP_
PasswordCmd,
AFLEX_VPORT_BITS_HTTP,
{0},
0
}
Valid Events
• AAM_AUTHENTICATION_INIT
374
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• AAM_AUTHORIZATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
HTTP::payload
Description This command will query for or replace content information. It allows
retrieval of content, queries for content size, or replacement for a
certain amount of content.
This will return the content that the HTTP::collect command has
collected by time of the request. If no size is specified, the system will
return the collected content.
HTTP::payload length
This will return the size of the content that the command has collected
by time of the request, but without the HTTP headers.
HTTP::payload <offset> <size>
This will return the content that the HTTP::collect command has
collected, starting at <offset> with size equals <size>.
HTTP::payload replace <offset> <size> <string>
This will replace the amount of content that is specified using the
<size> argument, starting at <offset> with <string>.
Example
when HTTP_RESPONSE {
HTTP::collect [HTTP::header Content-Length]
}
when HTTP_RESPONSE_DATA {
375
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
HTTP::query
Description This command will return the query part of the HTTP request.
Syntax HTTP::query
Example
when HTTP_REQUEST {
log "This is the HTTP path: [HTTP::path]"
log "This is our HTTP query: [HTTP::query]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
HTTP::redirect
Description This command will redirect an HTTP request or response to the
specified URL.
376
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: This command will send the response to the client immediately. It
cannot be specified multiple times in an aFleX script, nor can commands
that modify header or content be specified after this command, due to
its functionality.
Example
when HTTP_RESPONSE {
if { [HTTP::status] == 404 } {
HTTP::redirect "http://backup.example.com"
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::release
Description This command will release the collected data. Unless a subsequent
HTTP::collect command was issued, the HTTP::release command
inside of the HTTP_REQUEST_DATA and HTTP_RESPONSE_DATA events
is unnecessary, since in these situations, the data is implicitly released.
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Syntax HTTP::release
Example
when HTTP_RESPONSE {
HTTP::collect [HTTP::header Content-Length]
}
377
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when HTTP_RESPONSE_DATA {
regsub "Internal Site" [HTTP::payload] "Public Site"
newpayload
log "We have changed payload to reflect Public Site"
HTTP::payload replace 0 [HTTP::header Content-Length]
$newpayload
HTTP::release
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
HTTP::request
Description This command will return the raw request header string. Access the
request payload using the HTTP::collect command.
Syntax HTTP::request
Example Using this example will return the raw request header string. It uses the
HTTP::method and the HTTP version. It demonstrates the generation of
identical results for both log entries.
when HTTP_REQUEST {
log "This is the HTTP request: [HTTP::method] [HTTP::uri]
HTTP/[HTTP::version]"
log "This is the HTTP request: [HTTP::request]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
378
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
HTTP::request_num
Description This command will return the number of HTTP requests that a client
made on the connection.
Syntax HTTP::request_num
Example
Example 1:
when HTTP_REQUEST {
log "This is the Request #: [HTTP::request_num]"
}
Example 2:
when ICAP_RESPONSE {
{
log "This is the Request #: [HTTP::request_num]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::respond
Description This command will allow users to generate or rewrite a client request or
a server response. It is a powerful API that gives users the ability to
generate or rewrite a client request or a server response
Upon execution of the command on the client side, it will send the
response to the client without any load balancing taking place.
Upon execution of the command on the server side, the content from
the actual server will be discarded and replaced with information
provided to this API.
379
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: The maximum size response for this command that can be sent is 64 KB.
NOTE: No further aFlex scripts should be run after this API due to the
functionality of this command.
Example
Example 1: Use of the following example sends a redirect with
a cookie set.
when HTTP_REQUEST {
set cookie [format "%s=%s; path=/; domain=%s" CookieName
CookieValue ".example.com"]
HTTP::respond 302 Location "https://www.example.com" "Set-
Cookie" $cookie
}
Example 2:
when ICAP_RESPONSE {
{
HTTP::respond 200 content "<html><head><title>Apology Page</
title></head><body>We are sorry for the inconvenience, but the
site
is temporarily out of service<br>If you feel you have reached
this
page in error, please try again.<p></body></html>"
}
380
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::retry
Description This command will send an HTTP request to the server. It also triggers
the HTTP_REQUEST event.
Syntax HTTP:retry
NOTE: The HTTP retry command is supported only for virtual port types HTTP
and HTTPS. Fast-HTTP or other virtual port types are not supported.
Example
when HTTP_RESPONSE {
if { [HTTP::status] == 503 } {
HTTP::retry
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
HTTP::status
Description This command will return the response status code.
Syntax HTTP::status
381
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example
Example 1:
when HTTP_RESPONSE {
if { [HTTP::status] == 404 } {
HTTP::redirect "http://backup.example.com"
}
}
Example 2:
when ICAP_RESPONSE {
if { [HTTP::status] == 404 } {
HTTP::redirect "http://backup.example.com"
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• ICAP_RESPONSE
HTTP::stream
Description This command will replace the specified string of an HTTP response.
Example
382
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example 1:
when HTTP_RESPONSE {
HTTP::stream replace "Internal Site" "Public Site"
HTTP::stream replace "http://" "https://"
}
Example 2:
when ICAP_RESPONSE {
HTTP::stream replace "Internal Site" "Public Site"
HTTP::stream replace "http://" "https://"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
HTTP::uri
Description This command will return or set the URI of the request. This command
replaces the http_uri command.
This will change the URI passed to the server. Check that it starts with a
slash. The URI string does not include the http or https protocol or
hostname.
Example
Example 1:
when HTTP_REQUEST {
if { [HTTP::uri] ends_with ".html" } {
pool service_group_static
} elseif { [HTTP::uri] ends_with ".asp" } {
pool service_group_dynamic
}
}
383
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example 2:
when ICAP_RESPONSE {
if { [HTTP::uri] ends_with ".html" } {
pool service_group_static
} elseif { [HTTP::uri] ends_with ".asp" } {
pool service_group_dynamic
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• ICAP_RESPONSE
HTTP::username
Description This command will returns the username from HTTP basic
authentication..
Syntax HTTP:username
Example
[AFLEX_NSCMDID_HTTP_USERNAME] = {
"HTTP::username",
A10Tcl_HTTP_UsernameObjCmd, A10TclCompileHTTP_
UsernameCmd,
AFLEX_VPORT_BITS_HTTP,
{0},
0
}
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_RELAY_INIT
384
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
HTTP::version
Description This command will return or set the HTTP version of the request or
response. It replaces the http_version command.
Example
when HTTP_RESPONSE {
log "This is the version of HTTP: [HTTP::version]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
385
ICAP Commands
The following IP commands are supported:
l ICAP::disable
l ICAP::header add
l ICAP::header remove
l ICAP::header values
l ICAP::header replace
l ICAP::header replace-all
l ICAP::method
l ICAP::status
l ICAP::respmod_valid
l ICAP::reqmod_valid
l ICAP::uri
386
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
ICAP::disable
Description This command will disable ICAP for certain requests, based on the HTTP
headers.
Syntax ICAP::disable
Example Use of the following example selects a specific pool for a specific client
IP address.
when HTTP_REQUEST {
set method [HTTP::method]
if { ($method matches "POST")
or ($method matches "PUT") } {
return // follow the ICAP policy configured with CLI
} else {
ICAP::disable // disable ICAP template policy
}
}
Valid Events
• HTTP_REQUEST
• HTTP_RESPONSE
ICAP::header add
Description This command inserts a header to ICAP reqmod/respmod packet
387
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• ICAP_REQUEST
ICAP::header remove
Description This command will remove default, non-default, and previously header
values.
Example
when ICAP_REQUEST {
ICAP::header remove X-Unknown
ICAP::header remove X-CLIENT-IP
ICAP::header add X-DEF aaaaaa
ICAP::header remove X-DEF
}
Valid Events
• ICAP_REQUEST
ICAP::header values
Description This command can get a header value from ICAP reqmod/respmod
response.
Example
when ICAP_RESPONSE {
log " ISTag header value is [ICAP::header values ISTag]"
}
388
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• ICAP_RESPONSE
ICAP::header replace
Description The replace and add command are similar except that replace will not
append value to list, it will replace the existing values.
Example
when ICAP_REQUEST {
ICAP::header replace Preview 2
ICAP::header replace Preview 3
ICAP::header replace X-CLIENT-IP replaced
ICAP::header add X-DEF abc
ICAP::header replace X-DEF def
}
Valid Events
• ICAP_REQUEST
ICAP::header replace-all
Description This command will replace existing header values.
Example
when ICAP_REQUEST {
ICAP::header replace-all "Host: 20.20.5.10:1344\r\nDate:
Tue, 28-May-2019 09:17:50 GMT\r\nEncapsulated:
req-hdr=0, req-body=147\r\nPreview: 1\r\nAllow:
204\r\nX-Client-IP: 20.20.3.10\r\nX-Server-IP: 20.20.5.10\r\n"
ICAP::header add X-DEF abc
}
Valid Events
389
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• ICAP_REQUEST
ICAP::method
Description This command returns ICAP request method which can be reqmod or
respmod.
Syntax ICAP::method
Example
when ICAP_REQUEST {
log "method [ICAP::method]"
log "get uri [ICAP::uri]"
}
Valid Events
• ICAP_REQUEST
ICAP::status
Description This command will get ICAP response status code.
Syntax ICAP::status
Example
when ICAP_RESPONSE {
log "status [ICAP::status]"
}
Valid Events
• ICAP_RESPONSE
390
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
ICAP::respmod_valid
Description This command will check if respmod-icap template is bound under the
vPort and the ICAP service used is active. Return 1 only when respmod-
icap template is bound and the ICAP service used is active; otherwise,
return 0.
Syntax ICAP::respmod_valid
Example
when HTTP_RESPONSE {
log "resp [ICAP::respmod_valid]"
}
Valid Events
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
ICAP::reqmod_valid
Description This command will check if reqmod-icap template is bound under the
vPort and the ICAP service used is active. Return 1 only when reqmod-
icap template is bound and the ICAP service used is active; otherwise,
return 0.
Syntax ICAP::reqmod_valid
Example
when HTTP_REQUEST {
log "req [ICAP::reqmod_valid]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
391
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
ICAP::uri
Description This command will set or return ICAP service URI sent to ICAP server.
Syntax ICAP::uri
Example
when ICAP_REQUEST {
ICAP::uri icap://A10icap:1344/echo
}
Valid Events
• ICAP_REQUEST
392
IP Commands
The following topics are covered in this section:
l IP::addr
l IP::category
l IP::client_addr
l IP::local_addr
l IP::protocol
l IP::remote_addr
l IP::reputation
l IP::server_addr
l IP::stats
l IP::tos
l IP::ttl
l IP::version
393
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
IP::addr
Description This command will compare IP address/subnet/supernet to IP
address/subnet/supernet. It returns 0 if there is no match, and 1 in case
there is a match.
NOTE: The IP::addr command does not perform a string comparison. If a literal
string comparison is needed, compare the 2 strings with the
appropriate operator (for example, equals, contains, starts_with)
instead of using this command.
Example Use of the following example selects a specific pool for a specific client
IP address.
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
pool example_service_group
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• HTTP_REQUEST
394
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
IP::category
Description This command fetches the IP category from a local database.
A TCL contains the following category list:
• spam-sources
• windows-exploits
• web-attacks
• botnets
• scanners
• dos-attacks
• reputation
• phishing
• proxy
• mobile-threats
• tor-proxy
• uncategorized
Syntax IP::category IP
Example
395
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when HTTP_REQUEST {
set local_ip [IP::local_addr]
set cat_list [IP::category $local_ip]
foreach cat $cat_list {
log "IP category: $cat"
}
}
Valid Events
• CLIENT_ACCEPTED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• DNS_REQUEST
• DNS_RESPONSE
IP::client_addr
Description This command will return the client IP address of a connection. It is the
same as using the command clientside { IP::remote_addr }.
Syntax IP::client_addr
Example Use the following example to select a specific service group for a
specific client IP address.
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.1.10] } {
pool example_service_group
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• HTTP_REQUEST
396
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
IP::local_addr
Description This command is useful for addressing generic rules that are reused. It
is also useful in reusing the connected endpoint in another statement
or in making routing type decisions. The IP::client_addr and
IP::server_addr commands can also be specified.
Syntax IP::local_addr
This will return the IP address of the ACOS being used in the
connection. From the clientside position, this is the destination IP
address (virtual IP address). From the serverside position, this is the
source IP address. The following example shows the SNAT address if
SNAT is used, otherwise it spoofs client IP address).
Example Use the following example to select a specific service group for a
specific virtual IP address.
when CLIENT_ACCEPTED {
if { [IP::addr [IP::local_addr] equals 192.168.1.10] } {
pool service_group_internal
} else {
pool example_service_group
}
}
Example
when SERVER_CONNECTED {
397
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
IP::protocol
Description This command will return the IP protocol value.
Syntax IP::protocol
Example Use the following example to select a specific service group based on IP
protocol version.
when CLIENT_ACCEPTED {
if { [IP::protocol] == 6 } {
pool service_group_tcp
} else {
pool service_group_udp
}
}
Valid Events
• CLIENT_ACCEPTED
398
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_CLOSED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
IP::remote_addr
Description This command will return the IP address of the host at the far end of
the connection. From the clientside position, this is the client IP
address. From the serverside position, this is the node IP address. The
IP::client_addr and IP::server_addr commands can also be
specified.
Syntax IP::remote_addr
Example Use the following example to select a specific service group for a
specific client IP address. Then log the server address of the real server
where the request is to be forwarded.
when CLIENT_ACCEPTED {
if { [IP::addr [IP::remote_addr] equals 192.168.1.10] } {
pool example_service_group
}
}
when SERVER_CONNECTED {
log "This is the node IP address [IP::remote_addr]
assigned to [IP::client_addr]"
}
Valid Events
399
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
IP::reputation
Description This command fetches the IP reputation value from a local database. It
can display one of the following values:
Syntax IP::reputation IP
NOTE: There are only 'high risk' records in the local database.
Example
400
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when HTTP_REQUEST {
set local_ip [IP::local_addr]
log "Access Server $local_ip (reputation: [IP::reputation
$local_ip])"
}
Valid Events
• CLIENT_ACCEPTED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• DNS_REQUEST
• DNS_RESPONSE
IP::server_addr
Description This command will return the server’s (node’s) IP address, after a server
side connection has been established. It is the same as using the server
side command {IP::remote_addr}. The command will return a value of 0
if no server side connection has been made.
Syntax IP::server_addr
Example Use the following example to log the end node or the real server
address.
when SERVER_CONNECTED {
log "This is the node IP address [IP::server_addr]"
}
Valid Events
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
401
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• WAF_RESPONSE_VIOLATION
IP::stats
Description This command will supply information regarding the number of packets
or bytes being sent or received in a given connection.
Example Use the following example to log the total received packets for the
connection.
when CLIENT_CLOSED {
log "Total received packets: [IP::stats pkts in]"
}
Valid Events
• All.
• For information about aFleX events, see aFleX Events.
IP::tos
Description This command will select a different pool of servers based on the Type
of Service (ToS) level within a packet. The ToS standard is one method
where network equipment can identify and treat traffic differently
based on an identifier. As soon as traffic enters the site, the ACOS
402
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
device can apply a rule that sends traffic to different pools of servers
based on the ToS level within a packet.
Syntax IP::tos
This will select a different pool of servers based on the ToS level within
a packet.
Example Use the following example to select a specific pool based on TOS level
in the packet.
when CLIENT_ACCEPTED {
if { [IP::tos] == 16 } {
pool service_group_priority
} else {
pool example_service_group
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
IP::ttl
Description This command will return the TTL of the current packet being acted
upon.
403
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Syntax IP::ttl
Example Use the following example to drop the connection if the TTL for the
packet is below 3.
when CLIENT_ACCEPTED {
if { [IP::ttl] < 3 } {
drop
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
IP::version
Description This command will return the version of the current packet being acted
upon.
Syntax IP::version
Example Use the following example to select a specific service group based on IP
protocol version.
when CLIENT_ACCEPTED {
if { [IP::version] == 6 } {
pool service_group_ipv6
404
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
} else {
pool service_group_ipv4
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• CLIENT_DATA
• SERVER_DATA
405
Limit ID Commands
The following Limit ID (LID) commands are supported:
l LID::conn_limit
l LID::conn_rate_limit
l LID::exists
l LID::nat_pool
l LID::request_limit
l LID::request_rate_limit
l LID::type
NOTE: Multiple LID definitions may be available for a non-global LID. This
includes a LID in a policy template bound to a virtual port, a LID in DNS
template bound to a virtual port, a LID in a policy template bound to a
virtual server, and a LID configured in a system-wide policy template.
NOTE: To apply these commands, the LID must be configured and attached to
the same virtual port as the aFleX policy using the template. If GLID is
used, it must be configured and enabled on the configuration.
406
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
LID::conn_limit
Description Returns a list of conn-limit and LID type, each one for a matching LID
where conn-limit is configured.
Example Use the following example to log the connection limit specified for LID
1.
when HTTP_REQUEST {
log "The LID connection limit for LID1 is [LID::conn_limit
lid1]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
407
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
LID::conn_rate_limit
Description Returns a list of conn-rate-limit values and LID type, one each for a
matching LID where conn-rate-limit is configured.
Example Use the following example to log the connection rate limit specified for
GLID 1.
when HTTP_REQUEST {
log "The LID connection rate limit for glid1 is
[LID::conn_rate_limit glid1]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
408
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
LID::exists
Description Returns a Boolean value that indicates whether the specified LID exists.
Example Use the following example to log the presence of the specified GLID.
when HTTP_REQUEST {
log "The LID exists for glid1 [LID::exists glid1]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
409
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
LID::nat_pool
Description Returns a list of string and LID type, one each for a matching LID where
nat-pool is configured.
Example Use the following example to log the NAT pool associated with GLID 1.
when HTTP_REQUEST {
log "The LID NAT pool for glid1 is [LID::nat_pool glid1]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
410
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
LID::request_limit
Description Returns a list of request-limit and LID type, one each for a matching LID
where request-limit is configured.
Example Use the following example to log the request limit specified for GLID 1.
when HTTP_REQUEST {
log "The LID request limit for glid1 is [LID::request_
limit glid1]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
411
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
LID::request_rate_limit
Description Returns a list of request-rate-limit values and LID type, one each for a
matching LID where conn-rate-limit is configured.
Example Use the following example to log the request rate limit specified for
GLID 1.
when HTTP_REQUEST {
log "The LID request rate limit for glid is [LID::request_
rate_limit glid1]"
}
412
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
LID::type
Description Returns a list of LIDs of the specified type.
413
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use this example to return a list of LID types, one each for a matching
LID. The type can be one of the following: global, vport-policy, vport-
dns, vserver-policy, system-policy.
when HTTP_REQUEST {
log "The glid1 type is [LID::type glid1]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• DNS_REQUEST
• DNS_RESPONSE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
414
Link Commands
The following link commands are supported:
l LINK::lasthop
l LINK::nexthop
l LINK::vlan_id
415
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
LINK::lasthop
Description Returns the MAC address of the last hop.
Syntax LINK::lasthop
Example
when HTTP_REQUEST {
log "The LID request rate limit for glid1 is
[LID::request_rate_limit glid1]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
LINK::nexthop
Description Returns the MAC address of the next hop.
Syntax LINK::nexthop
Example
when SERVER_CONNECTED {
log "The Ethernet is { [LINK::lasthop] to [LINK::nexthop]
tag is [LINK::vlan_id] }"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
416
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
LINK::vlan_id
Description Returns the VLAN tag of the packet. In some cases, the VLAN ID may be
unavailable. In these cases a value of 0 will be returned.
Syntax LINK::vlan_id
Example
when CLIENT_ACCEPTED {
set log_message "Client is { [IP::client_addr]:
[TCP::client_port] -> [IP::local_addr]:[TCP::local_port] }"
append log_message " Ethernet is { [string range
[LINK::lasthop] 0 16] -> [string range [LINK::nexthop] 0 16]"
append log_message " Tag is [LINK::vlan_id] }"
log "$log_message"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
417
Load-balancing Commands
The following load-balancing (LB) commands are supported:
l LB::down
l LB::reselect
l LB::server
l LB::status
418
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
LB::down
Description Temporarily marks the current real port down for 30 seconds.
Syntax LB::down
Valid Events
• LB_FAILED
• LB_SELECTED
LB::reselect
Description Reperforms server selection.
Causes SLB to select the next available member (server and port) from
the same service group used for the initial server selection. To specify
the service group to use, use the pool <pool-name> option. If you also
use the <member> option, the specified member is selected from the
specified service group.
NOTE: This command applies to Layer 7 traffic only for HTTP and HTTPS.
NOTE: Failure to execute this command will not always trigger the LB_FAILED
event.
NOTE: Server template limits are applied for both service-group and server
selection. Commands that call for server selection (i.e., node, pool,
persist, etc.) will enforce server template limits on the selected server.
As a result, new connections that match a persist uie entry may be
unable to use the rport and a default server selection will occur
instead. To prevent default server selection, use the no def-selection-if-
pref-failed command for the virtual port.
419
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example In this aFleX policy, the HTTP::retry command retries sending a client’s
request to a service port that replies with an HTTP 5xx status code. If
the first server continues to reply with a 5xx status code after 3 retries,
the LB::reselect command reassigns the client request to another
server.
when CLIENT_ACCEPTED {
set retry 0
set max_retry 3
set reselect 0
}
when LB_SELECTED {
if { $retry > 0 } {
LB::reselect
incr reselect
}
}
when HTTP_RESPONSE {
if { $retry < $max_retry } {
if { [HTTP::status] starts_with "5" } {
incr retry
}
}
}
Example This aFleX policy is similar to the one above, except the LB::down
command in the policy marks the service port down for 30 seconds.
when CLIENT_ACCEPTED {
set retry 0
set max_retry 3
}
when HTTP_REQUEST {
log "HTTP_REQUEST: Retry Count: $retry"
}
when LB_SELECTED {
log "LB_SELECTED: Current Retry Count: $retry"
if { $retry > 0 } {
log "LB::reselect"
LB::down
420
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
LB::reselect
}
}
when HTTP_RESPONSE {
log "HTTP_RESPONSE: [HTTP::status]"
if { $retry < $max_retry } {
if { [HTTP::status] starts_with "5" } {
log "HTTP::retry"
incr retry
HTTP::retry
}
}
}
Valid Events
• LB_FAILED
• LB_SELECTED
LB::server
Description Returns the results of pool and node selection.
Syntax LB::server
Returns a Tcl list containing the pool, node, node IP address, and Layer
4 protocol port selected by SLB. If no server was selected when the
script was executed, or all servers are down, the command returns only
the default pool name.
LB::server pool
421
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Returns the name of the server with the specified IPv4 or IPv6 address.
Returns an empty string if no server with the specified IP address
exists.
Example The following example shows a script that replaces the Host header
with a header that contains the backend server’s hostname:
when LB_SELECTED {
switch [LB::server addr] {
"192.168.2.16" { HTTP::header replace Host
server1.example.com }
"192.168.2.18" { HTTP::header replace Host
server2.example.com }
}
}
Example This examples shows a script which checks if the default pool has less
than 2 active members.
when HTTP_REQUEST {
if { [active_members [LB::server pool]] < 2 } {
HTTP::respond 200 content "We are sorry, but the site
you are looking for is temporarily out of service."
}
}
422
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example The following example show a script that logs server names with their
associated IP addresses.
when CLIENT_DATA {
log "The LB Server resolve of 192.168.80.82 is [LB::server
resolve addr 192.168.80.82]"
log "The LB server resolve of rs1 is [LB::server resolve
name rs1]"
log "[LB::server resolve addr 2001:DB8::a10]"
log "[LB::server resolve name rs1]"
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
NOTE: The LB::server resolve [addr] option is valid with all events.
LB::status
Description Returns the health check status (up or down) of a node or pool.
If you were to specify the node IP address only, the Layer 3 health
status of the server is returned. If you also specify a protocol port and
423
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
its transport protocol, the health status of the port is also returned. If
you use the port option, the port number and the transport protocol
are required.
LB::status pool <pool_name>
Example
when HTTP_REQUEST {
if { [LB::status node 192.168.80.82 port 80 tcp] equals
"up" } {
log "node 192.168.80.82 port 80 is UP!"
} else {
log "node 192.168.80.82 port 80 is DOWN!"
}
}
Example
when HTTP_REQUEST {
if { [LB::status pool example_service_group 192.168.80.82
80] equals "up" } {
log "The member 192.168.80.82 port 80 of service group
example_service_group is UP!"
} else {
log "The member 192.168.80.82 port 80 of service group
example_service_group is DOWN!"
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
424
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
425
MQTT Commands
The following MQTT commands supported are:
l MQTT::clean_session_flag
l MQTT::client_id
l MQTT::collect
l MQTT::drop
l MQTT::dup_flag
l MQTT::keep_alive
l MQTT::length
l MQTT::packet_id
l MQTT::password
l MQTT::payload
l MQTT::payload_length
l MQTT::protocol_name
l MQTT::protocol_version
l MQTT::qos
l MQTT::replace
l MQTT::respond
l MQTT::retain_flag
l MQTT::return_code
l MQTT::return_code_list
l MQTT::session_present_flag
l MQTT::topic
l MQTT::type
426
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
l MQTT::username
l MQTT::will
NOTE:
l Default and Client_id based load balancing methods are supported
on MQTT vPort.Clientid-hash-persist first N: Use the first N bytes for
server selection.Clientid-hash-persist last N: Use the last N bytes for
server selection.
l Clientid-hash-persist offset N: Start from Nth bytes of the client id.
l Must be used together with first or last option.
l aFleX processes a message within 1MB only.
l For bigger messages, aFleX forwards the message successfully, but
only prints message contents and flags up to 1MB.
Example
If the field or flag does not exist, then the output value is -1, so that
users can detect the situation.
For information about aFleX commands, see aFleX Commands.
For information about MQTT events, see MQTT Events.
427
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::clean_session_flag
Description Gets the flag for an MQTT CONNECT message.
Syntax MQTT::clean_session_flag
Example Uses the following example to log the clean session flag value.
when MQTT_CLIENT_MESSAGE {
log “[MQTT::clean_session_flag]”
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::client_id
Description Gets the client identifier for an MQTT CONNECT message.
Syntax MQTT::client_id
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
428
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::collect
Description Collects at least bytes of payload
Syntax MQTT::collect
MQTT::collect <bytes>
Example
when MQTT_CLIENT_MESSAGE {
MQTT::collect
}
when MQTT_CLIENT_MESSAGE_DATA {
if { [MQTT::type] equals 8} {
log "payload in PUBLISH is [MQTT::payload]"
}
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_SERVER_MESSAGE
MQTT::drop
Description Drop the current MQTT message
Syntax MQTT::drop
Example Use the following example to drop the MQTT message from the server
side which includes "5min" in its topic:
429
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when MQTT_SERVER_MESSAGE {
if { [MQTT::topic] contains "5min" } {
MQTT::drop
}
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::dup_flag
Description Gets the duplicate flag for an MQTT PUBLISH message.
Syntax MQTT::dup_flag
Example Use the following example to log the dup flag value.
when MQTT_CLIENT_MESSAGE {
log “[MQTT::dup_flag]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::keep_alive
Description Gets the keep_alive field for an MQTT CONNECT message.
Syntax MQTT::keep_alive
430
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
log “[MQTT::keep_alive]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::length
Description Gets the length for an MQTT message.
Syntax MQTT::length
Example Use the following example to log the length for an MQTT message.
when MQTT_CLIENT_MESSAGE {
log “[MQTT::length]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::packet_id
Description MQTT::packet_id - Gets the packet-id for an MQTT message.
MQTT::packet_id <packet-id> - Set the packet-id of the MQTT message
to the given value and the value range is [0 to 65535]
Syntax MQTT::packet_id
MQTT::packet_id <packet-id>
Example Example 1
Use the following example to log the packet Id for an MQTT message.
431
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when MQTT_CLIENT_MESSAGE {
log “[MQTT::packet_id]”
}
Example 2
when MQTT_CLIENT_MESSAGE {
MQTT::packet_id -1
MQTT::packet_id 1 1
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::password
Description Gets the password field for an MQTT CONNECT message.
Syntax MQTT:password
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::payload
Description
MQTT::payload - Gets the payload of an MQTT PUBLISH message
432
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Syntax MQTT::payload
MQTT::payload [<replace | prepend | append> <content>]
Example
Example 1:
when MQTT_CLIENT_MESSAGE_DATA {
log “[MQTT::payload]”
}
Example 2:
when MQTT_CLIENT_MESSAGE_DATA {
MQTT::payload replace test
MQTT::payload prepend test:
MQTT::payload append :test
log "[MQTT::payload]"
}
Example 3:
when MQTT_CLIENT_MESSAGE_DATA {
MQTT::payload replace 5 10 aflex_data
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
433
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::payload_length
Description Gets the payload length for an MQTT PUBLISH message.
Syntax MQTT::payload_length
Example Use the following example to log the payload length for an MQTT
PUBLISH message
when MQTT_CLIENT_MESSAGE_DATA {
log “[MQTT::payload_length]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::protocol_name
Description Gets the protocol name for an MQTT CONNECT message.
Syntax MQTT::protocol_name
Example Use the following example to log the protocol name for an MQTT
message.
when MQTT_CLIENT_MESSAGE {
log “[MQTT::protocol_name]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
434
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::protocol_version
Description Gets the protocol review level for an MQTT CONNECT message.
Syntax MQTT::protocol_version
Example Use the following example to log the protocol version for an MQTT
message.
when MQTT_CLIENT_MESSAGE {
log “[MQTT::protocol_version]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::qos
Description
Gets the Quality of Services (QoS) for an MQTT PUBLISH message.
Supports the following three types of QoS:
• At most once
• At least once
• Exactly once
435
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Syntax MQTT::qos
Example
Example 1: Use the following example to log the QoS for an MQTT
message
when MQTT_CLIENT_MESSAGE {
log “[MQTT::qos]”
}
Example 2
when MQTT_PUBLISH {
set old_qos [MQTT::qos]
log "In MQTT_PUBLISH event, initial qos=[MQTT::qos], packet_
id=[MQTT::packet_id] "
if {$old_qos==0 } {
MQTT::packet_id [expr {int (rand()*65000)}]
}
MQTT::qos 2
log "After setting qos as 2, the new qos = [MQTT::qos],
packet_
id=[MQTT::packet_id] "
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
436
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::replace
Description This command replaces an MQTT message.
Example
when MQTT_CLIENT_MESSAGE {
MQTT::replace type PUBACK packet_id 111
MQTT::replace type PUBREC packet_id 111
MQTT::replace type PUBREL packet_id 111
MQTT::replace type PUBCOMP packet_id 111
MQTT::replace type UNSUBACK packet_id 111
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::respond
Description This command transmits an MQTT message to sender of the incoming
message.
Example
when MQTT_CLIENT_MESSAGE {
MQTT::respond type PUBACK packet_id 111
MQTT::respond type PUBREC packet_id 111
MQTT::respond type PUBREL packet_id 111
MQTT::respond type PUBCOMP packet_id 111
MQTT::respond type UNSUBACK packet_id 111
}
437
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::retain_flag
Description MQTT::retain_flag - Gets the retain flag for an MQTT PUBLISH message
MQTT::retain_flag <0, 1> - Set the retain flag of MQTT PUBLISH messages
Syntax MQTT::retain_flag
Example
Example 1 - MQTT::retain_flag
Use the following example to log the retain flag value for an
MQTT message.
when MQTT_CLIENT_MESSAGE_DATA {
log “[MQTT::retain_flag]”
}
Example 2 - MQTT::retain_flag <0, 1>
when MQTT_SERVER_MESsAGE {
MQTT::retain_flag 0
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::return_code
Description Gets the return-code field for an MQTT CONNACK message.
438
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Syntax MQTT::return_code
Example Use the following example to log the return code for an MQTT message.
when MQTT_SERVER_MESSAGE_DATA {
log “[MQTT::return_code]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::return_code_list
Description Gets the return-code-list for multiple MQTT SUBACK messages.
Syntax MQTT::return_code_list
Example Use the following example to log the return code list for multiple MQTT
messages.
when MQTT_SERVER_MESSAGE_DATA {
log “[MQTT::return_code_list]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::session_present_flag
Description Gets the session_present flag for an MQTT CONNACK message.
Syntax MQTT::session_present_flag
439
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to log the value of session present flag for
an MQTT message.
when MQTT_SERVER_MESSAGE_DATA {
log “[MQTT::session_present_flag]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::topic
Description
MQTT::topic - Get the list of the topic names from
SUBSCRIBE/UNSUBSCRIBE message, or the topic name from PUBLISH
message.
440
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::topic index <index-number> - Get the topic name from the given
index of SUBSCRIBE/UNSUBSCRIBE message.
Syntax MQTT::topic
Example 2
when MQTT_CLIENT_MESSAGE_DATA{
MQTT::topic replace test300
}
when MQTT_SERVER_MESSAGE_DATA {
log "[MQTT::topic count]"
log "[MQTT::topic]"
log "[MQTT::topic index 0]"
log "[MQTT::topic qos test]"
log "[MQTT::topic add test100 2]"
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
441
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::type
Description Gets the type for an MQTT message. The following are the message
types:
• Reserved (0):
• CONNECT (1): When a client requests to connect to a server.
• CONNACK ( 2): When a server acknowledges the connection from a
client.
• PUBLISH 3 (3): When the server publishes a message.
• PUBACK (4): When the server acknowledges the publishing for a
message.
• PUBREC (5): When the server receives the message for publication.
(Part 1 of Assured Delivery)
• PUBREL (6): When the server releases the message for publication.
(Part 2 of Assured Delivery)
• PUBCOMP ( 7): When the server completes the publication of
message. (Part 3 of Assured Delivery)
• SUBSCRIBE (8): When a client subscribes to a request.
• SUBACK (9): When a server acknowledges the subscription to a
client.
• UNSUBSCRIBE (10): When a client unsubscribes a request.
• UNSUBACK (11): When a server unsubscribes an acknowledgment.
• PINGREQ (12): When a client pings a request to the server.
• PINGRESP (13): When the server pings a response to the client.
• DISCONNECT (14):When the client is disconnected with the server.
• Reserved (15):
Syntax MQTT::type
Example Use the following example to log the type for an MQTT message.
when MQTT_CLIENT_MESSAGE {
log “[MQTT::type]”
}
Valid Events
442
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::username
Description Gets the username field for an MQTT CONNECT message.
Syntax MQTT::username
Example Use the following example to log the username included in an MQTT
message.
when MQTT_CLIENT_MESSAGE {
log “[MQTT::username]”
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
MQTT::will
Description Gets and sets the parts of the will message for an MQTT Connect
message in the following sequence:
• will-topic
• will-message
• will-qos
• will-retain flag
• will-flag
443
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example
when MQTT_CLIENT_MESSAGE {
MQTT::will will-topic aflexTest
MQTT::will will-message aflexTest
444
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
MQTT::will will-qos 0
MQTT::will will-retain-flag 0
}
Valid Events
• MQTT_CLIENT_MESSAGE
• MQTT_CLIENT_MESSAGE_DATA
• MQTT_SERVER_MESSAGE
• MQTT_SERVER_MESSAGE_DATA
445
QUIC Commands
The following QUIC commands are supported on QUIC traffic:
l QUIC::CID
l QUIC::version
QUIC::CID
Description This command returns the client-side QUIC connection ID.
Syntax QUIC::CID
Example
when QUIC_CLIENT_ACCEPTED {
log "**** QUIC CLIENT ACCEPTED ****"
log "Accepted CID [QUIC::cid]"
# log "QUIC Initial Version [QUIC::version]"
if { [IP::addr [IP::client_addr] equals 16.16.16.225] } {
pool sg-http3-s149
}
}
Valid Events
• QUIC_INITIAL
• QUIC_CLIENT_ACCEPTED
• QUIC_CLIENT_CLOSED
QUIC::version
Description This command returns the client-side QUIC version that is in use.
Syntax QUIC::version
Example
446
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when QUIC_CLIENT_ACCEPTED {
log "**** QUIC CLIENT ACCEPTED ****"
log "QUIC Initial Version [QUIC::version]"
}
Valid Events
• QUIC_INITIAL
• QUIC_CLIENT_ACCEPTED
• QUIC_CLIENT_CLOSED
447
Policy-Based SLB Commands
The following Policy-Based SLB command is supported:
l POLICY::bwlist id
l POLICY::source_rule
448
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
POLICY::bwlist id
Description Returns the group ID associated with an IP address in a black/white list.
This command causes the ACOS device to look in the black/white list
that is bound to the same virtual port to which the aFleX policy is
bound.
POLICY::bwlist id <ip> <bwlist_name>
This command causes the ACOS device to look in the specified list.
NOTE: When using POLICY::bwlist without a file name, the virtual port
requires a Policy Template with Black-White List file.
Example
when HTTP_REQUEST {
if { [POLICY::bwlist id [IP::client_addr]] == 10 } {
pool sg-internal
} elseif { [POLICY::bwlist id [IP::client_addr] bwfile] ==
20 } {
pool sg-www
} else {
reject
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
449
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
POLICY::source_rule
Description This command specifies the source rule name in the policy template
which is to be used during the policy matching process. Each source
rule has its priority. Even though the aFleX script selects a source rule,
the priority of this rule is used to compare with the source rule selected
by the original policy template matching (without aFleX). The higher
priority rule is chosen.
Example
when HTTP_REQUEST {
if { [HTTP::header exists "PASS"] } {
log "Header is matched. Set EP source rule as \"source-1\""
POLICY::source_rule set source-1
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• HTTP_RESPONSE_CONTINUE
450
RADIUS Message Load-balancing Commands
The following commands are supported for RADIUS message load-balancing:
l RADIUS::avp
l RADIUS::code
l RADIUS::id
l RADIUS::length
451
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
RADIUS::avp
Description This command returns RADIUS attribute-value pairs (AVPs). Bind the
virtual port that uses this aFleX command to UDP port 1812.
The list of AVPs in the message are returned as {attr, len, value} tuples.
The <attr> option specifies a RADIUS attribute, 1-255 (RFC 2865). If an
<attr> option is specified, then only the AVP for that attribute is
returned. If an option is not specified, then the AVPs for all attributes
are returned.
Example
when CLIENT_DATA {
binary scan [RADIUS::avp 40] H* radius_avp40
switch $radius_avp40 {
1 { log "RADIUS Start for [IP::client_addr]" }
2 { log "RADIUS Stop for [IP::client_addr] " }
default {
drop
}
}
}
Valid Events
• CLIENT_DATA
• SERVER_DATA
RADIUS::code
Description This command returns the Code field of a RADIUS message.
Syntax RADIUS::code
452
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example
when CLIENT_DATA {
log "RADIUS Code: [RADIUS::code]"
}
Valid Events
• CLIENT_DATA
• SERVER_DATA
RADIUS::id
Description This command returns the Identifier field of a RADIUS message.
Syntax RADIUS::id
Example
when CLIENT_DATA {
log "RADIUS Identifier: [RADIUS::id]"
}
Valid Events
• CLIENT_DATA
• SERVER_DATA
RADIUS::length
Description This command returns the Length field of a RADIUS message.
Syntax RADIUS::length
Example
when CLIENT_DATA {
log "RADIUS Length: [RADIUS::length]"
}
Valid Events
• CLIENT_DATA
453
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVER_DATA
454
RAM Caching Commands
The following RAM caching commands are supported on HTTP traffic (original proxy)
and HTTP2 traffic (new proxy):
l CACHE::disable
l CACHE::enable
l CACHE::expire
l CACHE::hits
These commands are supported on HTTP traffic (the original proxy), but not
supported on HTTP2 traffic (the new proxy).
l CACHE::age
l CACHE::headers
455
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
CACHE::age
Description This command returns the age (in seconds) of a cached object. The age
is how long the object has been in the cache.
Syntax CACHE::age
Example
when CACHE_REQUEST {
if { [CACHE::age] > 60 } {
CACHE::expire
log "The cache content expires when age > 60 seconds"
}
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• HTTP_REQUEST
• HTTP_RESPONSE
CACHE::disable
Description This command disables the current HTTP request from being cached.
Syntax CACHE::disable
Example
when HTTP_REQUEST {
switch -glob [HTTP::uri] {
"*.jpg" { CACHE::enable }
"*.png" { CACHE::enable }
"*.gif" { CACHE::enable }
456
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• HTTP_REQUEST
• HTTP_RESPONSE
CACHE::enable
Description This command caches an object, with the possibility of specifying how
long to cache the object for.
The <age> option specifies how long the object should be cached for, in
seconds. If the <age> option is not used, then the default time is the age
in the RAM caching template.
Example
when HTTP_REQUEST {
switch -glob [HTTP::uri] {
"*.jpg" { CACHE::enable }
"*.png" { CACHE::enable }
"*.gif" { CACHE::enable }
"*.css" { CACHE::enable 86400 }
"*.js" { CACHE::enable 86400 }
default { CACHE::disable }
}
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
457
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
CACHE::expire
Description This command removes an object from the cache. It must be revalidated
by the server to be cached again.
Syntax CACHE::expire
Example
when RULE_INIT {
set ::expirecache 0
}
when HTTP_REQUEST {
if { [HTTP::uri] starts_with "/expirecache" } {
set ::expirecache 1
}
}
when CACHE_RESPONSE {
if { $::expirecache == 1 } {
CACHE::expire
log "Cache must be revalidated by [IP::client_addr]"
set ::expirecache 0
}
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• HTTP_REQUEST
• HTTP_RESPONSE
458
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
CACHE::headers
Description This command returns the HTTP headers of a cached object. The name
and value of header fields are returned in a Tcl list.
Syntax CACHE::headers
Example
when CACHE_RESPONSE {
log "Cache Headers: [CACHE::headers]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• HTTP_REQUEST
• HTTP_RESPONSE
CACHE::hits
Description This command returns the number of hits in the cache for a cached
object.
Syntax CACHE::hits
Example The following example logs the number of cache hits for a specific
HTTP::uri:
when HTTP_REQUEST {
log "CACHE Hits: There are [CACHE::hits] hits for
[HTTP::uri]"
}
Valid Events
• CACHE_REQUEST
• CACHE_RESPONSE
• HTTP_REQUEST
• HTTP_RESPONSE
459
Resolve Commands
The following DNS resolution command is supported:
RESOLVE::lookup
For information about aFleX commands, see aFleX Commands.
460
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
RESOLVE::lookup
Description This command sends a DNS request to the DNS server for the list of IP
addresses associated with the specified domain name. This command
works when the DNS server is in asynchronous mode.
This command performs a DNS lookup for the specified domain name,
using the default DNS server.
NOTE: Using the following CLI command, configure a primary DNS server: ip
dns primary ip_address. A secondary DNS server can be configured
using the following CLI command: ip dns secondary ip_address.
This command will use the default DNS server. In case the default DNS
server fails, if a secondary DNS server is configured, the command
RESOLVE::lookup will use the secondary DNS server.
This command performs a DNS lookup for the specified domain name,
using the specified DNS server.
NOTE: For HTTP or HTTPS virtual ports, the valid events are HTTP_REQUEST
and HTTP_REQUEST_DATA. For TCP-proxy, the valid events are CLIENT_
ACCEPTED and CLIENT_DATA.
Example
Use the following example to perform a DNS lookup with the default
DNS server:
when HTTP_REQUEST {
log "RESOLVE Lookup: [HTTP::host] resolves to
[RESOLVE::lookup [HTTP::host]]"
461
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example
Use the following example to perform a DNS lookup with the specified
DNS server:
when HTTP_REQUEST {
log "RESOLVE Lookup: [HTTP::host] resolves to
[RESOLVE::lookup @8.8.8.8 [HTTP::host]]"
}
Example
Use the following example to dynamically choose the DNS server for the
DNS lookup, and then perform the DNS lookup:
when HTTP_REQUEST {
set cnt 0
set s1 192.168.1.1
set s2 192.168.1.2
set client_ip [IP::client_addr]
set method [HTTP::method]
set uri [HTTP::uri]
log "client ip = $client_ip"
if {[expr $cnt % 2]} {
set server "$s1"
} else {
set server "$s2"
}
set ips [RESOLVE::lookup @$server "www.example.com"]
log "cnt = $cnt server = '$server' ips = '$ips'"
log "HTTP method = '$method' uri = '$uri'"
incr $cnt 1
}
when HTTP_RESPONSE {
log "Response: HTTP method = '$method' uri = '$uri'"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
462
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_ACCEPTED
• CLIENT_DATA
463
SIP Commands
The following SIP commands are supported:
l SIP::call_id
l SIP::from
l SIP::header
l SIP::method
l SIP::respond
l SIP::response
l SIP::to
l SIP::uri
l SIP::via
For examples of the SIP command in use, see SIP Command Examples.
For information about aFleX commands, see aFleX Commands.
For information about SIP events, see SIP Events.
464
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
SIP::call_id
Description This command returns the value of the Call-ID header in a SIP request.
Syntax SIP::call_id
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
SIP::from
Description This command returns the value of the “From” header in a SIP request.
Syntax SIP::from
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
465
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
SIP::header
Description This command either returns the specified SIP header, or else it inserts
a header name and a corresponding header value into the SIP header.
The <value> option specifies the header value. The <index> option
specifies which header level the value applies to in case of multiple
header levels. If an index is not specified, then aFleX applies the value
to the first header corresponding to the header-name.
SIP::header insert “header-name” “header-value” [<index>]
The <index> option specifies where to insert the new header. If the
optional index does not exist, then a “via” header is inserted at the
beginning of the SIP headers, and all other headers are inserted at the
end of the SIP headers. If the index is not specified, then the header is
inserted before other headers with the same name and value.
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
466
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVER_CONNECTED
• SERVER_DATA
SIP::method
Description This command returns what type the SIP request method is.
Syntax SIP::method
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
SIP::respond
Description This commands returns a response with the defined code, phrase, and
header name and corresponding header value.
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
467
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
SIP::response
Description This command returns the SIP response code or phrase. You can also
use this command to rewrite the response code or phrase.
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
468
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVER_DATA
SIP::to
Description This command returns the value of the “To” header in the SIP request.
Syntax SIP::to
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
SIP::uri
Description This command returns the request’s URI.
Syntax SIP::uri
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
469
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
SIP::via
Description This command returns the “via” information for SIP.
The above command returns the information in the SIP “via” header. If
the <index> option is specified, then only the information at that index
is returned.
SIP::via proto [<index>]
The above command returns the SIP “via” protocol part. If the <index>
option is specified, then only the information at the index is returned.
SIP::via sent_by [<index>]
The above command returns the “sent by” from the SIP “via”
information. If the <index> option is specified, then only the
information at the index is returned.
SIP::via received [<index>]
The above command returns the “received” value of the SIP “via”
information. If the <index> option is specified, then only the
information at the index is returned.
SIP::via branch [<index>]
The above command returns the “branch” value of the SIP “via”
information. If the <index> option is specified, then only the
information at the index is returned.
SIP::via maddr [<index>]
470
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
The above command returns the multicast address value of the SIP
“via” information. If the <index> option is specified, then only the
information at the index is returned.
SIP::via ttl [<index>]
The above command returns the TTL value of the SIP “via” information.
If the <index> option is specified, then only the information at the
index is returned.
Valid Events
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
Example 1
Use the following example to log all the available header values when a full SIP
request is received from the client and the SIP request method is subscribe.
471
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when SIP_REQUEST {
if { [SIP::method] contains "SUBSCRIBE" } {
log "***************** SIP-REQUEST *******************"
log "SIP::call_id is [SIP::call_id]"
log "---------------------------------------------------"
log "SIP::from is [SIP::from]"
log "---------------------------------------------------"
log "SIP::header Via [SIP::header Via]"
log "SIP::header Via value index0 [SIP::header value Via 0]"
log "SIP::header Via index9 [SIP::header Via 9]"
log "SIP::header From [SIP::header From]"
log "SIP::header value From index0 [SIP::header value From 0]"
log "SIP::header From index9 <not exist> [SIP::header From 9]"
log "SIP::header To [SIP::header To]"
log "SIP::header To index0 [SIP::header To 0]"
log "SIP::header value To index9 <not exist> [SIP::header value To 9]"
log "SIP::header Call-ID [SIP::header Call-ID]"
log "SIP::header value Call-ID index0 [SIP::header value Call-ID 0]"
log "SIP::header value Call-ID index9 <not exist> [SIP::header value
Call-ID 9]"
log "SIP::header CSeq [SIP::header CSeq]"
log "SIP::header CSeq value index0 [SIP::header value CSeq 0]"
log "SIP::header CSeq index9 <not exist> [SIP::header CSeq 9]"
log "SIP::header Contact [SIP::header Contact]"
log "SIP::header value Contact index0 [SIP::header value Contact 0]"
log "SIP::header Contact index9 <not exist> [SIP::header Contact 9]"
log "SIP::header Max-Forwards [SIP::header Max-Forwards]"
log "SIP::header Event [SIP::header Event]"
log "SIP::header User-Agent [SIP::header User-Agent]"
log "SIP::header Expires [SIP::header Expires]"
log "SIP::header Allow [SIP::header Allow]"
log "SIP::header Accept [SIP::header Accept]"
log "SIP::header Content-length [SIP::header Content-length]"
log "SIP::header abc <not valid header> [SIP::header abc]"
log "---------------------------------------------------"
SIP::header remove Via
log "SIP::header remove Via [SIP::header Via]"
SIP::header remove From
log "SIP::header remove From [SIP::header From]"
log "---------------------------------------------------"
472
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
473
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example 2
Use the following example to look for SIP response codes, rewrite the codes to
customized messages, and log them when a full SIP response is received from the
server.
when SIP_RESPONSE {
if { [SIP::response code] equals "401" } {
SIP::response rewrite 411 Phrase_Unauthorized
log "SIP::response code [SIP::response code]"
log "SIP::response phrase [SIP::response phrase]"
}
if { [SIP::response code] equals "501" } {
SIP::response rewrite 511 Phrase_Not_Implemented
log "SIP::response code [SIP::response code]"
log "SIP::response phrase [SIP::response phrase]"
}
if { [SIP::response code] equals "200" } {
SIP::response rewrite 210 okok
474
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example 3
Use the following example to log all the available header values when a full SIP
request is received from the client and the SIP request method is subscribe.
when SIP_REQUEST_SEND {
if { [SIP::method] contains "SUBSCRIBE" } {
log "***************** SIP-REQUEST-SEND *******************"
log "SIP::header Via 1 (request_sent) [SIP::header Via 1]"
475
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
log "---------------------------------------------------"
SIP::header insert From "<sip:[email protected]>;tag=1043119751"
log "SIP::header insert From index1 [SIP::header From]"
476
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
log "---------------------------------------------------"
log "SIP::uri [SIP::uri]"
log "---------------------------------------------------"
log "SIP::via [SIP::via]"
log "SIP::via index0 [SIP::via 0]"
log "SIP::via index9 [SIP::via 9]"
log "SIP::via proto [SIP::via proto]"
log "SIP::via proto index0 [SIP::via proto 0]"
log "SIP::via proto index9 [SIP::via proto 9]"
log "SIP::via sent_by [SIP::via sent_by]"
log "SIP::via sent_by index0 [SIP::via sent_by 0]"
log "SIP::via sent_by index9 [SIP::via sent_by 9]"
log "SIP::via received [SIP::via received]"
log "SIP::via received index0 [SIP::via received 0]"
log "SIP::via received index9 [SIP::via received 9]"
log "SIP::via branch [SIP::via branch]"
log "SIP::via branch index0 [SIP::via branch 0]"
log "SIP::via branch index9 [SIP::via branch 9]"
log "SIP::via maddr [SIP::via maddr]"
log "SIP::via maddr index0 [SIP::via maddr 0]"
log "SIP::via maddr index9 [SIP::via maddr 9]"
log "SIP::via ttl [SIP::via ttl]"
log "SIP::via ttl index0 [SIP::via ttl 0]"
log "SIP::via ttl index9 [SIP::via ttl 9]"
}
}
477
SMTP Commands
The following category commands is supported:
l SMTP::mail
l SMTP::greet
l SMTP::ehlo
478
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
SMTP::mail
Description Retrieves MAIL command parameter (reverse-path)
Example
When SMTP_MAIL {
If {[SMTP::mail] equals abc.com} {
node 1.1.1.1 25
} else {
Node 2.2.2.2 25
}
}
Valid Events
SMTP::greet
Description Set EHLO ok messages.
Example
When SMTP_EHLO {
SMTP::greet “VRFY”
}
Valid Events
479
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SMTP_EHLO
SMTP::ehlo
Description Retrieve client's ehlo/helo message.
Syntax SMTP::ehlo
Example
When SMTP_EHLO {
SMTP::ehlo
}
Valid Events
480
SSL Commands
The following SSL commands are supported:
l SSL::authenticate
l SSLI::bypass
l SSLI::cache_cert
l SSL::cert
l SSL::cipher
l SSL::collect
l SSL::disable
l SSLI::drop
l SSL::enable
l SSL::extensions
l SSL::hostname
l SSLI::inspect
l SSL::mode
l SSL::payload
l SSL::release
l SSL::renegotiate
l SSL::respond
l SSL::session invalidate
l SSL::sessionid
l SSL::template
l SSL::verify_result
481
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
SSL::authenticate
Description Use the following command to permanently, or for a single occurrence,
authenticate client SSL certificates. To set the depth to which the
authenticity of the certificate is inspected, use the keyword depth
followed by a number.
Example Use the following example to set the index and renegotiate variables
when a client establishes a connection with the ACOS device. After the
initial ssl handshake, the client authentication parameters will be
changed using the SSL::authenticate command. SSL::authenticate will require the
client to be authenticated once. SSL::authenticate depth 6 will verify the
client certificate until depth 6. After this, when we renegotiate, if the
certificate used for client authentication has depth more than 6, the
handshake should fail. If the SSL handshake is successful the "SSL
authenticate invalid CLIENTSSL_DATA: FAIL" message would be printed
in the logs.
when CLIENT_ACCEPTED {
set do_reneg 1
set index 1
}
when CLIENTSSL_HANDSHAKE {
SSL::collect
if {$do_reneg} {
log "Normal handshake for SSL authenticate invalid
CLIENTSSL_DATA"
log "Index for SSL authenticate invalid CLIENTSSL_DATA:
$index"
incr index
set do_reneg 0
} else {
log "SSL authenticate is invalid CLIENTSSL_DATA: FAIL"
log "Index for SSL authenticate invalid CLIENTSSL_DATA:
$index"
incr index
}
482
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
when CLIENTSSL_DATA {
log "Start SSL authenticate invalid CLIENTSSL_DATA"
SSL::authenticate once
SSL::authenticate depth 6
SSL::cert mode require
SSL::renegotiate
SSL::release
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
SSL::cert
Description Use the following command to view information on SSL certificates.
Use this command to return the SSL certificate with the specified level
in the certificate chain. Level 0 is the first level. This command will
provide certificate information in DER format. In release 2.6.1-P2 or
earlier, this command will provide certificate information in text format.
483
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Use this command to return the issuer of the certificate with the
specified level.
SSL::cert mode [request | require | ignore | auto]
Use this command to set the certificate mode. This setting will override
the mode that is set in template.
Example Use the following example to log the client certificate at level 0. X509::text
is used to convert the binary into ASCII for verification.
when CLIENTSSL_HANDSHAKE {
log "SSL cert for CLIENTSSL_HANDSHAKE is [X509::text
[SSL::cert 0]]"
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
SSL::cipher
Description Use the following command to return information on SSL ciphers.
484
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to log the cipher name, cipher bits, and
cipher version used in the SSL handshake.
when CLIENTSSL_HANDSHAKE {
log "SSL cipher_name is [SSL::cipher name]"
log "SSL cipher_bit is [SSL::cipher bits]"
log "SSL cipher_version is [SSL::cipher version]"
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
SSL::collect
Description Use the following command to collect SSL application data.
Syntax SSL::collect
485
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to collect the SSL application information
when the client SSL handshake completes.
when CLIENTSSL_HANDSHAKE {
SSL::collect
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_HANDSHAKE
• SERVERSSL_CLIENTHELLO_SEND
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERHELLO
SSL::disable
Description Use the following command to turn off server or client SSL.
NOTE: This command is only supported on HTTP virtual port 80 and is not
supported on HTTPS virtual ports or other port numbers.
Example Use the following example to disable SSL and server-side SSL.
when CLIENT_ACCEPTED {
SSL::disable
SSL::disable serverside
}
Valid Events
• CLIENT_ACCEPTED
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
486
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST
• HTTP_REQUEST_DATA
SSL::enable
Description Use the following command to turn on client or server SSL.
NOTE: This command is only supported on HTTP virtual port 80 and is not
supported on HTTPS virtual ports or other port numbers.
Example Use the following example to enable SSL and server-side SSL.
when CLIENT_ACCEPTED {
SSL::enable
SSL::enable serverside
}
Valid Events
• CLIENT_ACCEPTED
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
SSL::extensions
Description Use the following command to parse the SSL certificate extensions.
487
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Returns the byte array for the specified SSL certificate extension.
SSL::extensions -type <extension_type>
Returns the byte array for the specified SSL certificate extension type,
or an empty string if not found. Returns only the first instance if the
same extension type is present more than once.
SSL::extensions exists -type <extension_type>
Valid Events
• CLIENTSSL_CLIENTHELLO
• SERVERSSL_SERVERHELLO
• SERVERSSL_CLIENTHELLO_SEND
SSL::hostname
Description Gets the host name from the header of the client hello message. If the
host name does not exist, it returns as NULL value.
Syntax SSL::hostname
Example Refer the following example to get SSL::hostname from a tcp packet
When CLIENT_ACCEPTED {
TCP::collect
}
When CLIENT_DATA {
Log “[SSL::hostname]”
}
Valid Events
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_HANDSHAKE
• CLIENT_DATA
488
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
SSL::mode
Description Use the following command on the server or the client to discover
whether SSL has been enabled or disabled. This command will return 1,
if SSL is turned on, or 2, if SSL is turned off.
Syntax SSL::mode
NOTE: When the certificate mode is set with this command, it will override the
mode set in the SSL template.
Example Use the following example SSL::mode command to ignore the example-
client-ssl-template mode.
when CLIENT_ACCEPTED {
SSL::template example-client-ssl-template
}
when HTTP_REQUEST {
log "The SSL mode is [SSL::mode]."
}
Valid Events
• CLIENT_ACCEPTED
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• SERVER_CONNECTED
• SERVERSSL_HANDSHAKE
SSL::payload
Description Use this command to return SSL data that has been collected, or to
replace the collected payload with the information that is provided.
489
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Use this command to return the SSL content that has been collected.
SSL::payload <offset> <size>
Use this command to return the accumulated SSL content starting from
<offset>.
SSL::payload <length>
Use this command to return the collected payload with the given data.
Example Use the following example to log the length of the SSL payload.
when CLIENTSSL_CLIENTCERT {
SSL::collect 100
log "Start collecting SSL data"
}
when CLIENTSSL_DATA {
log "SSL payload length is CLIENTSSL_CLIENTCERT:
[SSL::payload length]"
}
Example Use the following example to capture the original SSL payload. Replace
the GET response of the request with data to get new payload. Replace
the 0 to 50 bytes of SSL payload with the new payload.
when CLIENTSSL_CLIENTCERT {
SSL::collect 100
log "Start collecting SSL data"
}
when CLIENTSSL_DATA {
set data [SSL::payload]
set len [SSL::payload length]
log "SSL payload length before replace = $len"
log "SSL payload data before replace = $data"
490
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to log the SSL payload until size 100 of the
total size.
when CLIENTSSL_CLIENTCERT {
SSL::collect 164
}
when CLIENTSSL_DATA {
log "SSL payload of size CLIENTSSL_CLIENTCERT is
[SSL::payload 100]"
}
Valid Events
• CLIENTSSL_DATA
• SERVERSSL_DATA
SSL::release
Description Use the following command to release the SSL collect mode. This will
stop SSL application information from being gathered.
Syntax SSL::release
Example Use the following example to release the data collected so that the
session can continue. If the release fails, then the session fails.
when CLIENTSSL_HANDSHAKE {
SSL::collect 120
}
when CLIENTSSL_CLIENTCERT {
SSL::collect 100
log "Start collecting SSL data"
}
when CLIENTSSL_DATA {
491
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENTSSL_DATA
• SERVERSSL_DATA
SSL::renegotiate
Description Only supported on devices with SSL Hardware. Use the following
command on the client after the SSL handshake has been completed to
mandate SSL renegotiation. Specify the disable keyword to prevent
client-side SSL renegotiation.
Example Use the following example to set the index and renegotiate variables
when a client establishes a connection with the ACOS device. After the
initial ssl handshake, the client authentication parameters will be
changed using the SSL::authenticate command. SSL::authenticate once will
require the client to be authenticated once. SSL::authenticate depth 6 will
verify the client certificate until depth 6. After this, when we
renegotiate, if the certificate used for client authentication has depth
more than 6, the handshake should fail. If the SSL handshake is
successful the "SSL authenticate invalid CLIENTSSL_DATA: FAIL"
message would be printed in the logs.
when CLIENT_ACCEPTED {
set do_reneg 1
set index 1
}
when CLIENTSSL_HANDSHAKE {
SSL::collect
if {$do_reneg} {
log "Normal handshake for SSL authenticate invalid
CLIENTSSL_DATA"
492
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
SSL::respond
Description Use the following command to send specific SSL data to the client in a
client-side event, or to the server in a server-side event. This command
is supported on HTTP2 (new proxy).
NOTE:
l This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
l This command is supported on HTTP2 (new proxy).
493
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to send your own response to the client
instead of the server response.
wwhen SERVERSSL_HANDSHAKE {
SSL::collect 100
log "Start collecting SSL data"
}
when SERVERSSL_DATA {
set data [SSL::payload]
if {$data contains "invite"} {
SSL::respond "HTTP/1.1 200 OK\r\n\r\n Session
active.\r\n"
} else {
SSL::respond "HTTP/1.1 404 OK\r\n\r\n Session page not
found.\r\n"
}
log "Sent SSL respond"
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• SERVERSSL_CLIENTHELLO_SEND
• SERVERSSL_DATA
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERHELLO
SSL::session invalidate
Description Use the following command after the SSL handshake to the client has
been completed to ensure that the same SSL Session ID for the client is
not used again.
494
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to invalidate the current SSL session so the
session id cannot be reused.
when HTTP_REQUEST {
log "ssl session invalidate for HTTP_REQUEST is :
[SSL::session invalidate]"
}
Valid Events
• CLIENTSSL_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
SSL::sessionid
Description Use the following command to return the current SSL session ID for the
client side only, not for the server side.
Syntax SSL::sessionid
Example Use the following example to log the SSL session id generated during
the SSL handshake.
wwhen HTTP_REQUEST {
log "SSL session id for current session is
[SSL::sessionid]"
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
495
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
SSL::template
Description Use the following command on the client or the server connection to
apply an SSL template.
Based on a client or server side, this command will apply the specified
SSL template.
SSL::template [clientside|serverside] <name>
NOTE: This command is only supported on the HTTP virtual port 80 and the
HTTPS port 443. Other port numbers are not supported.
Example Use the following example to apply templates when a client establishes
a connection.
when CLIENT_ACCEPTED {
SSL::template example-client-ssl-template
SSL::template serverside example-server-ssl-template
}
Valid Events
496
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST_SEND
• LB_SELECTED
• SERVER_CONNECTED
• SERVERSSL_HANDSHAKE
SSL::verify_result
Description Use the following command to either set the <result_code> for the
peer certification verification or retrieve the result code of the peer
certification verification.
Example Use the following example to log the SSL handshake status code and
the error string related to the code.
when CLIENTSSL_HANDSHAKE {
log "SSL verify_result CLIENTSSL_HANDSHAKE:status
code [SSL::verify_result] in the logs"
log "SSL::verify result [X509::verify_cert_error_
string [SSL::verify_result]]"
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
SSLI::bypass
Description Use the following command to bypass SSL inspection.
497
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Syntax SSLI::bypass
Valid Events
• SERVERSSL_SERVERCERT
SSLI::cache_cert
Description This command is used to disable or enable caching of server certificate.
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Valid Events
• SERVERSSL_SERVERCERT
498
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
SSLI::inspect
Description Use the following command to enable SSL inspection for the flow.
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Syntax SSLI::inspect
Inspects the flow and uses the alt key for signing.
Example Use the following example to inspect the flow and use the alt key for
signing:
when SERVERSSL_SERVERCERT {
if { [SSL::cert issuer 1] contains "a10-ssl.com" } {
log "SERVERSSL_SERVERCERT: inspect SSL"
SSLI::inspect use_alt_key
}
}
Valid Events
• SERVERSSL_SERVERCERT
SSLI::drop
Description Use the following command to drop the SSL connection.
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Syntax SSLI::drop
499
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when SERVERSSL_SERVERCERT {
if { [SSL::cert issuer 1] contains "Digi" } {
log "SERVERSSL_SERVERCERT: drop SSL"
SSLI::drop
}
}
Valid Events
• SERVERSSL_SERVERCERT
500
Statistics Commands
The following commands related to statistics are supported:
l STATS::clear
l STATS::get
501
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
STATS::clear
Description Clears statistics for a real server (node), virtual server, or service group
(pool).
Example
when HTTP_REQUEST {
if { [HTTP::uri] starts_with "/clearstats" } {
STATS::clear server rs1 80 tcp total-connection
STATS::clear virtual-server vip1 80 http total-
connection
STATS::clear pool example_service_group total-
connection
}
}
Valid Events
All
502
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
STATS::get
Description Retrieves statistics for a real server (node), virtual server, or service
group (pool).
The shared partition option applies the command to real servers in the
shared partition. By default, the STATS::get command acts only upon
the real servers located in the Role-Based Administration (RBA)
partition that contains the aFleX policy.
STATS::get virtual-server <vip-name| vipaddr>
[<port-num> <service-type>]
current-connection | total-connection | request-pkt |
response-pkt
[partition shared]
503
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
You can specify the virtual server by its name or VIP address (<vip-
name> or <vipaddr>).
Optionally, you can specify an individual port by its port number (0-
65535) and service type (tcp, udp, http, https, and so on). By default,
statistics for all the ports of the virtual server are returned.
The other options are the same as those for real servers.
STATS::get pool <pool-name> [member <ipaddr> <port-num>]
current-connection | total-connection | request-pkt |
response-pkt
[partition shared]
The other options are the same as those for real servers and virtual
servers.
Example The following policy will select a real server based on the current
connection counter:
when CLIENT_ACCEPTED {
set total1 [STATS::get server 192.168.10.10 current-
connection]
set total2 [STATS::get server 192.168.10.20 current-
connection]
if { $total1 > $total2 } {
node 192.168.10.20 80
} else {
node 192.168.10.10 80
}
}
Valid Events
All
504
Table Commands
You can use the following aFleX commands to manage a table of data entries:
l table add
l table append
l table delete
l table incr
l table keys
l table lifetime
l table lookup
l table replace
l table set
l table timeout
505
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Default Values
If <timeout> is not specified, the timeout is set to the default of 180 seconds.
If <lifetime> is not specified, the lifetime is set to “indefinite”.
Depending on the aFleX event used in the policy, you can track connections or
requests. The CLIENT_CONNECTED event represents TCP connections, whereas the
HTTP_REQUEST event represents every individual request.
The <lifetime> option sets the entry to expire after the specified period of time,
regardless of how many changes or lookups are performed on the entry.
An entry can have both a configured lifetime and timeout. The entry is removed from
the table for whichever expiration time comes first.
506
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
table add
Description Adds or returns the value for a specified key in the table.
Adds a key to the table with the specified <key> number and associated
<value>. Optionally, you can apply a <timeout> and <lifetime> to the
entry.
NOTE: If the key already exists, a key is not inserted and the existing value is
not returned. When a new key is added, the existing value is returned.
Valid Events
All.
table append
Description Appends a string to the value associated with the specified key
If -notouch is specified, then any existing entries for the key will not
have an updated timestamp.
NOTE: If the key does not exist, then no action is taken. This command returns
the value of the entry after the operation is complete.
Valid Events
All.
507
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
table delete
Description Deletes elements of a table.
Valid Events
All.
table incr
Description Increments the value associated with a key.
Increments the value associated with the <key>, in the specified table. If
you do not specify a value for <num>, 1 is used by default. If -notouch is
specified, then any existing entries for the key will not have an updated
timestamp.
NOTE: This command returns the entry’s value after the operation is complete.
If the specified key does not exist, then no action is taken.
Valid Events
All.
508
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
table keys
Description Returns a list of key and value pairs in the specified table.
Returns list of keys and value pairs (without updated timestamp), and
number of keys in the specified table.
table keys <name> -notouch
NOTE: A10 Networks does not recommend using this command frequently in
an aFleX policy. The table keys command provides useful debugging
capabilities, but can lower system performance when used repeatedly.
Valid Events
All.
table lifetime
Description Returns the lifetime for the specified key. This command returns -1 if no
lifetime is set for the specified key or the lifetime is indefinite.
509
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All.
table lookup
Description Returns the value associated with the specified key.
Returns the value associated with <key>. Any existing entries for the
key will not have an updated timestamp.
Valid Events
All.
table replace
Description Replaces the value in the table associated with the specified key or
value. If the specified key does not exist, no action is taken and an
empty string is returned.
Replaces the value in the table with the specified <key> or <value>.
Returns new value after replacement.
table replace <name> <key> <value> <timeout> <lifetime>
510
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Replaces the value with the specified <key> or <value> and applies a
<timeout> and <lifetime> to the entry. Returns new value after
replacement.
Valid Events
All.
table set
Description Sets a value in the table for an existing key. Adds a table and a key if
one does not already exist.
Sets the <value> of <key> and returns the entry’s value. Also applies a
<timeout> and <lifetime> to the entry.
Valid Events
All.
table timeout
Description Sets or returns the timeout for a specific key in a table.
511
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All.
Table Examples
The following aFleX script examples use table commands:
l Example 1 uses table commands to blacklist IP addresses that make large number
of DNS queries.
l Example 2 uses table commands to block IP addresses if there are large number of
failed login attempts.
l Example 3 shows an example of how to display and delete table commands.
Example 1
In this example, the aFleX script blacklists an IP addresses for 10 minutes (600
seconds) if traffic from the IP address makes more than 10 DNS queries per second. It
uses the lifetime for the $::HOLDTIME:
when RULE_INIT {
set ::MAXQUERY 10
set ::HOLDTIME 600
}
when DNS_REQUEST {
if { [table lookup "blacklist" [IP::client_addr]] != "" } {
log "The Blacklist for [IP::client_addr] expires in [table
lifetime "blacklist" -remaining [IP::client_addr]] seconds"
drop
return
512
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
if { [table lookup tmp_table [IP::client_addr]] == "" } {
table set tmp_table [IP::client_addr] 1 indef 1
log "The table entry created for [IP::client_addr]"
return
}
set count [table incr tmp_table [IP::client_addr]]
log "The DNS Query $count of $::MAXQUERY for [IP::client_addr]"
if { $count > $::MAXQUERY } {
table add "blacklist" $key "blocked" indef $::HOLDTIME
log "The Blacklist entry created for [IP::client_addr]"
table delete tmp_table $key
drop
return
}
}
Example 2
In this example, the aFleX script blocks an IP address for 10 minutes (600 seconds) if
there are 3 failed login attempts. It uses the timeout for the $::HOLDTIME:
when RULE_INIT {
set ::MAXTRIES 3
set ::HOLDTIME 600
set ::LOCATION "/welcome.cgi?p=failed"
}
when HTTP_REQUEST {
if { [table lookup "failedlogins" -notouch [IP::client_addr]] ==
$::MAXTRIES } {
HTTP::respond 200 content "You have been blocked, you can try
again in [table timeout "failedlogins" -remaining [IP::client_addr]]
seconds"
log "Login is blocked for [IP::client_addr] expires in [table
timeout "failedlogins" -remaining [IP::client_addr]] seconds"
}
}
when HTTP_RESPONSE {
if { [HTTP::header exists "Location"] } {
if { ([HTTP::header "Location"] ends_with $::LOCATION) } {
513
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example 3
In this example, the aFleX script presents all the entries in the table and gives the
option to delete a table. Show table contents with: http://<vip>/status:<table-name>.
Delete table contents with: http://<vip>/delete:<table-name>.
when HTTP_REQUEST {
set ACTION [getfield [HTTP::uri] ":" 1]
set TABLE [getfield [HTTP::uri] ":" 2]
if { $ACTION eq "/flush" } {
table delete $TABLE -all
HTTP::respond 200 content "Table $TABLE deleted... <a
href=\"/status:$TABLE\">Back to STATUS</a>" Content-Type "text/html"
} elseif { $ACTION eq "/status" } {
set response "<html><head><title>Contents of Table:
$TABLE</title></head>"
append response "<body><center><h1>Contents of Table:
$TABLE</h1><table border=\"1\" cellpadding=\"5\" cellspacing=\"0\">"
append response "<tr><th>Key</th><th>Value</th></tr>"
set i 0
foreach tr [table keys $TABLE] {
incr i
if { $i == 1 } {
append response "<tr><td>$tr</td>"
}
if { $i == 2 } {
append response "<td>$tr</td></tr>"
set i 0
514
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
}
append response "</table><p>DELETE TABLE: <a
href=\"/flush:$TABLE\">$TABLE</a></p>"
append response "</center></body></html>"
HTTP::respond 200 content $response Content-Type "text/html"
} else {
HTTP::respond 200 content "Usage is prohibited!"
}
}
515
TCP Commands
The following TCP commands are supported:
l TCP::client_port
l TCP::close
l TCP::collect
l TCP::local_port
l TCP::mss
l TCP::notify
l TCP::offset
l TCP::option
l TCP::payload
l TCP::release
l TCP::remote_port
l TCP::respond
l TCP::rtt
l TCP::server_port
516
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TCP::client_port
Description This command will return the TCP port/service number of the specified
client. It is equivalent to the command clientside { TCP::remote_
port } and client_port.
Syntax TCP::client_port
Example
when CLIENT_ACCEPTED {
log "Connection has been achieved here: [IP::client_addr]:
[TCP::client_port]"
}
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_AUTHORIZATION_INIT
• AAM_RELAY_INIT
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVERSSL_CLIENTHELLO_SEND
• SERVERSSL_DATA
517
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERCERT
• SERVERSSL_SERVERHELLO
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
TCP::close
Description This command will close the TCP connection.
NOTE: This command supports old SSL (N5) and new SSL (QAT, new N5, and
Software TLS1.3).
Syntax TCP::close
Example
when CLIENT_ACCEPTED {
if { [IP::addr [IP::client_addr] equals 192.168.7.0/24] }
{
TCP::close
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
518
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
TCP::collect
Description This command will cause TCP to start gathering the specified amount of
content data.
For information about using this command with generic TCP Proxy, see
Support for Generic TCP Proxy.
Example
when CLIENT_ACCEPTED {
TCP::collect 15
}
when CLIENT_DATA {
if { [TCP::payload 15] contains "internal" } {
pool service_group_internal
} else {
pool example_service_group
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_DATA
519
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVER_CONNECTED
• SERVER_DATA
Example
when CLIENT_ACCEPTED {
TCP::collect 1024
}
when CLIENT_DATA {
log "Here is the length of the payload: [TCP::payload
length]"
if { [TCP::payload 15] contains "internal" } {
pool service_group_internal
} else {
pool example_service_group
}
}
520
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TCP::collect
Example
when CLIENT_ACCEPTED {
TCP::collect
}
when CLIENT_DATA {
log "Here is the length of the payload: [TCP::payload
length]"
if { [TCP::payload 15] contains "internal" } {
pool service_group_internal
} else {
pool example_service_group
}
TCP::release
TCP::collect
}
521
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Upon receiving the ACK from the client, the ACOS device will select a real server and
send a SYN to the server.
The session flow will continue with the selected server.
When TCP::collect is used in an CLIENT_ACCEPTED event, the ACOS device will not
be able to start a connection with a back-end server after the client ACK.
In this situation, the aFleX collect operation must be completed and the CLIENT_DATA
event must be triggered. Before implementing these actions, ensure that the ACOS
device is on standby. After the collection of data is done, the ACOS device will select
a real server and forward its data.
The client will send SYN.
The ACOS device will send SYN-ACK.
The client will send ACK.
The client data is pushed.
When the collect operation is complete, trigger CLIENT_DATA event will occur and a
connection will be established to a selected server.
When the collect operation is not complete, client data will continue to be buffered
and will finally be forwarded to a server when collect operation is completed.
(completion defined by collect <length>)
522
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to set and log the TCP payload length. Check
if the payload contains a certain string and use the appropriate service
group for the content. Alternatively, use a different service group and
release it. This example shows the gathering of the first 1000 bytes of
data and triggering a DATA event using the following key commands:
• TCP::collect command using <length> option in CLIENT_
ACCEPTED event
• TCP::release command placed at the end of CLIENT_DATA event
when CLIENT_ACCEPTED {
TCP::collect 1000
}
when CLIENT_DATA {
set tcplen [TCP::payload length]
log "Here is the length : ($tcplen)"
if { [TCP::payload ] contains "ABC" } {
pool abc_service_group
} else {
pool web_service_group
}
TCP::release
}
NOTE:
• Ensure the correct <length> value, otherwise if the
TCP payload total is less than that specified by collect
<length>, the ACOS device does not forward the data
to the server.
• aFleX does not allow another use of the
TCP::collect command in the DAT event when
collect <length> is defined.
Example This example shows the gathering of the first three data packets
followed by the action of forwarding the data to the server by using
these commands:
523
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when CLIENT_ACCEPTED {
TCP::collect
set packet_count 0
}
when CLIENT_DATA {
incr packet_count
if { $packet_count >= 3 } {
log "Here is the length of the payload: [TCP::payload
length]"
if { [TCP::payload] contains "internal" } {
pool service_group_internal
} else {
pool example_service_group
}
TCP::release
}
}
Valid Events
The following events are valid for this use of the TCP::collect
command:
• CLIENT_ACCEPTED
• CLIENT_DATA
• SERVER_CONNECTED
• SERVER_DATA
TCP::local_port
Description This command will return the local TCP port/service number.
Syntax TCP::local_port
524
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example This example shows a cookie modification using the local port
information. If the port is 80, the cookie has "HttpOnly" added to it. If
the port is 443, "HttpOnly" and "Secure" is added to the cookie.
when RULE_INIT {
set ::DEBUG 0
}
when HTTP_REQUEST {
set PORT [TCP::local_port]
}
when HTTP_RESPONSE {
set current_time [TIME::clock seconds]
foreach cookie_name [HTTP::cookie names] {
if { [HTTP::cookie exists "$cookie_name"] } {
set new_cookie "$cookie_name=[HTTP::cookie value
"$cookie_name"]"
if { [HTTP::cookie expires "$cookie_name"] > $current_
time } {
set cookie_expires [clock format [HTTP::cookie expires
"$cookie_name"] -format {%a, %d %b %Y %H:%M:%S GMT} -gmt 1]
append new_cookie "; Expires=$cookie_expires" }
if { [HTTP::cookie domain "$cookie_name"] ne "" } {
append new_cookie "; Domain=[HTTP::cookie domain "$cookie_
name"]" }
if { [HTTP::cookie path "$cookie_name"] ne "" } { append
new_cookie "; Path=[HTTP::cookie path "$cookie_name"]" }
if { $PORT == 443 } { append new_cookie "; Secure" }
if { $PORT == 80 or $PORT == 443 } { append new_cookie
"; HttpOnly" }
if { ($::DEBUG == 1) } { log "Set-Cookie $new_cookie" }
HTTP::cookie remove "$cookie_name"
HTTP::header insert Set-Cookie "$new_cookie"
}
}
}
Valid Events
• AAM_AUTHENTICATION_INIT
525
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• AAM_AUTHORIZATION_CHECK
• AAM_AUTHORIZATION_INIT
• AAM_RELAY_INIT
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SERVERSSL_CLIENTHELLO_SEND
• SERVERSSL_DATA
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERCERT
• SERVERSSL_SERVERHELLO
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
526
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• WAF_RESPONSE_VIOLATION
TCP::mss
Description This command will return the maximum segment size (MSS) for a TCP
connection.
Syntax TCP::mss
Example
when CLIENT_ACCEPTED {
log "Here is the maximum segment size: [TCP::mss]"
}
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_AUTHORIZATION_INIT
• AAM_RELAY_INIT
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
527
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SERVERSSL_CLIENTHELLO_SEND
• SERVERSSL_DATA
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERCERT
• SERVERSSL_SERVERHELLO
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
TCP::notify
Description This command will notify the system that the end of a message has
been reached, and that the message is ready for load balancing.
Example This example shows how to use notify for load balancing messages
through TCP.
when CLIENT_ACCEPTED {
TCP::collect
}
when CLIENT_DATA {
log "Here is the payload: [TCP::payload] "
TCP::release
TCP::notify eom
log "Here is the payload after release: [TCP::payload]"
TCP::collect
}
Valid Events
528
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_DATA
• SERVER_DATA
TCP::offset
Description This command will return the position in the TCP data stream where
the collected TCP data began.
Syntax TCP::offset
Example
when CLIENT_ACCEPTED {
TCP::collect
}
when CLIENT_DATA {
if { [TCP::offset] > 1000 } {
TCP::release
}
}
Valid Events
• CLIENT_DATA
• SERVER_DATA
TCP::option
Description This command will retrieve, set, or unset the raw value of the specified
option kind from the TCP header.
529
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
530
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
531
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: For the following TCP option types, they cannot be set or unset: MSS,
SACK and Window Scale.
Example Use this example to get the value for different options set by client in
the TCP header.
when CLIENT_ACCEPTED {
log " TS = [TCP::option get 8]"
log " mss = [TCP::option get 2]"
log " wscale = [TCP::option get 3]"
log " SACK_permit = [TCP::option get 4]"
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
532
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TCP::payload
Description This command will return the accumulated TCP data content, or replace
the gathered payload with the specified data.
This will return the accumulated TCP data content start from <offset>.
TCP::payload length
This will return the amount of accumulated TCP data content in bytes.
TCP::payload <offset> <size> <data>
This will return the gathered payload with the specified data.
TCP::payload replace <offset> <size> <data>
This will replace the gathered payload with the specified data.
NOTE: Use of the TCP::payload replace command is only supported for TCP-
proxy, TCP, and FTP virtual ports.
NOTE: After TCP data has been released with the use of the TCP::release
command, it is no longer part of the TCP data payload, so it will not be
returned with the TCP::payload command.
Example
when CLIENT_ACCEPTED {
TCP::collect
}
when CLIENT_DATA {
if { [TCP::payload] contains "internal" } {
pool service_group_internal
} else {
pool service_group_tcp
}
}
533
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
TCP::release
Description This command will cause TCP to resume processing the connection and
flush collected data.
Syntax TCP::release
Example
when CLIENT_ACCEPTED {
TCP::collect
}
when CLIENT_DATA {
if { [TCP::offset] > 1000 } {
TCP::release
}
}
534
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example This example shows message load balancing to help determine the
proper payload.
when CLIENT_ACCEPTED {
TCP::collect
}
when CLIENT_DATA {
log "Here is the payload: [TCP::payload] "
TCP::release 20
TCP::notify eom
log "Here is the payload after release: [TCP::payload]"
TCP::collect
}
Valid Events
• CLIENT_DATA
• SERVER_DATA
TCP::remote_port
Description This command will return the remote TCP port/service number. It
replaces the remote_port command.
Syntax TCP::remote_port
Example
when SERVER_CONNECTED {
log "Here is the server remote TCP port: [TCP::remote_
port]"
}
Valid Events
535
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
TCP::respond
Description This command will send the specified data directly to the peer. It can
also be used to complete a protocol handshake.
NOTE:
l This command supports only old SSL (N5) and does not support new
SSL (QAT, new N5, and Software TLS1.3).
l This command will not work if applied to an HTTP/HTTPS virtual port.
This command with the <data> parameter will specify the data to send
to the peer.
NOTE: This command will not work if applied to an HTTP virtual port.
536
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
TCP::rtt
Description This command will return the smoothed round-trip time (RTT) estimate
for a TCP connection.
Syntax TCP::rtt
• Get the actual round-trip time in milliseconds by dividing the
returned value by 2.
• The RTT will take some time to converge.
Example
when HTTP_REQUEST {
set rtt [TCP::rtt]
}
when HTTP_RESPONSE {
if { $rtt < 1600 } {
log "Here is the round-trip time: $rtt for
[IP::client_addr] - without compress applied."
COMPRESS::disable
} else {
log "Here is the round-trip time: $rtt for
[IP::client_addr] - with compress applied."
COMPRESS::enable
COMPRESS::gzip level 3
}
}
537
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• AAM_AUTHENTICATION_INIT
• AAM_AUTHORIZATION_CHECK
• AAM_AUTHORIZATION_INIT
• AAM_RELAY_INIT
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_CLIENTHELLO
• CLIENTSSL_DATA
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_FAILED
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SERVERSSL_CLIENTHELLO_SEND
• SERVERSSL_DATA
• SERVERSSL_HANDSHAKE
• SERVERSSL_SERVERCERT
• SERVERSSL_SERVERHELLO
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
538
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
TCP::server_port
Description This command will return the TCP port/service number of the specified
server. It is the same as using the serverside { TCP::remote_port }
command and the obsolete variable server_port.
Syntax TCP::server_port
Example
when SERVER_CONNECTED {
log "Here is the server port: [TCP::server_port]"
}
Valid Events
• AAM_RELAY_INIT
• CLIENT_CLOSED
• CLIENT_DATA
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• LB_SELECTED
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
• SIP_REQUEST
• SIP_REQUEST_SEND
• SIP_RESPONSE
• WAF_RESPONSE_VIOLATION
539
Template Commands
The Template commands enable you to access individual configuration parameters
on a per template basis. The commands listed below allow you to check for the
existence of certain template types on a virtual server. Further, you can use these
commands to access configuration parameters for a template.
The following template commands are supported:
l TEMPLATE::cache
l TEMPLATE::client_ssl
l TEMPLATE::conn_reuse
l TEMPLATE::exists
l TEMPLATE::http
l TEMPLATE::server_ssl
l TEMPLATE::tcp
l TEMPLATE::udp
540
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TEMPLATE::cache
Description This command gets the value of the parameter for a RAM cache
template.
This command returns the value for the specified <setting> in the
designated RAM cache template. For the <setting> variable, you can
enter one of the following options:
• name
• accept_reload_req
• age
• default_policy_nocache
• disable_insert_age
• disable_insert_via
• max_cache_size
• max_content_size
• min_content_size
• policy
• remove_cookies
• replacement_policy
• verify_host
Example The following example logs the cache age value in the assigned
template.
when CACHE_REQUEST {
log "Cache age of URI [HTTP::uri] refreshed to
[TEMPLATE::cache age]"
}
Valid Events
All.
541
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TEMPLATE::client_ssl
Description This command gets the value of the parameter for the client SSL
template.
This command returns the value for the specified <setting> in the
designated client SSL template. For the <setting> parameter, enter one
of the following options:
• name
• ca_cert
• cert
• chain_cert
• cipher
• client_certificate
• close_notify
• crl
• key
• session_cache_size
• ssl_false_start_disable
Example The following example checks if a client-side SSL template exists on the
virtual port, and if the SSL template is found, then a log is generated
containing the template name.
when CLIENT_ACCEPTED {
if { [TEMPLATE::exists client_ssl] == 1 } {
log "The TEMPLATE exists and says YES.”
log "The TEMPLATE Client SSL name is
[TEMPLATE::client_ssl name]."
} else {
log "No, the client SSL Template is not configured."
}
542
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All.
TEMPLATE::conn_reuse
Description This command gets the value of the parameter for the connection reuse
template.
Example The following example checks if a connection reuse template exists and
if the current number of connections is greater than the limit per
server. If so, it forwards the traffic to a special service port.
when HTTP_REQUEST {
if { [TEMPLATE::exists conn_reuse] == 1 } {
set curr_conn [STATS::get server 192.168.1.1 80 tcp
current-connection]
if { $curr_conn > [TEMPLATE::conn_reuse limit-per-
server] } {
node 192.168.1.100 80
}
}
}
Valid Events
All.
543
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TEMPLATE::exists
Description This command determines whether a template is bound to a virtual
server. The command returns a “1” integer value if a template is
configured on the virtual server, and it returns a “0” integer value if the
template is not configured on the virtual server.
Example The following example checks if a Client SSL template has been applied
to the virtual server. If yes, then the command will return a “1” value,
and this will trigger ACOS to create a log message indicating that the
client SSL template is enabled.
when CLIENT_ACCEPTED {
544
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
if { [TEMPLATE::exists client_ssl] == 1 } {
log "The client SSL template is configured."
}
}
Example The following example checks if a Server SSL template has been applied
to the virtual server. If yes, then the command will return a “1” value,
and this will trigger ACOS to create a log message indicating that the
server SSL template is enabled.
when SERVER_CONNECTED {
if { [TEMPLATE::exists server_ssl] == 1 } {
log "The server SSL template is configured."
}
}
Valid Events
All.
TEMPLATE::http
Description This command gets the value of the parameter for the HTTP template.
This command returns the value for the specified <setting> for the
designated HTTP template. For the <setting> parameter, enter one of
the options listed below:
• name
• compress_level
• compress_content_type_excludes
• compress_uri_excludes
• compress_enable
• compress_min_size
• compress_content_type
• failover_url
545
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• host_switching
• insert_client_ip
• log_retry
• redirect_rewrite
• request_header_erase
• request_header_insert
• response_header_erase
• response_header_insert
• retry_on_5xx
• retry_on_5xx_per_req
• strict_transaction_switch
• term_11client_hdr_client_close
• url_hash_persist
• url_switching
Example The following example checks if an HTTP template exists. If so, it skips
the compression for the URI that contains the string “example” when
the compression level is 1.
when HTTP_REQUEST {
if { [TEMPLATE::exists http] == 1 } {
#skip low level compression for certain uri
if { [HTTP::uri] contains "example" } {
if { [TEMPLATE::http comparess_level] == 1 } {
COMPRESS::disable
}
}
}
}
Valid Events
All.
546
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TEMPLATE::server_ssl
Description This command gets the value of the parameter for the server SSL
template.
This command returns the value for the specified <setting> for the
designated Server SSL template. For the <setting> parameter, enter
one of the options listed below:
• name
• ca_cert
• cert
• cipher
• close_notify
• key
• version
Example The following example checks if a Server SSL template exists, then logs
all the listed settings, otherwise logs that it is not configured on the
virtual port.
when CLIENT_ACCEPTED {
if { [TEMPLATE::exists server_ssl] == 1 } {
log "*** Template server_ssl is configured on vport ***"
log "*** Name: [TEMPLATE::server_ssl name]***"
log "*** ca_cert: [TEMPLATE::server_ssl ca_cert]***"
log "*** cert: [TEMPLATE::server_ssl cert]***"
log "*** close_notify: [TEMPLATE::server_ssl close_
notify]***"
log "*** cipher: [TEMPLATE::server_ssl cipher]***"
log "*** version: [TEMPLATE::server_ssl version]***"
log "*** key: [TEMPLATE::server_ssl key]***"
} else {
log "template server_ssl is not configured on vport"
}
}
Valid Events
547
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
All.
TEMPLATE::tcp
Description This command gets the value of the parameter for the TCP template.
This command returns the value for the specified <setting> in the
designated TCP template. For the <setting> parameter, enter one of
the choices listed below:
• name
• force_delete_timeout
• half_close_idle_timeout
• idle_timeout
• initial_window_size
• reset_fwd
• reset_rev
Valid Events
All.
TEMPLATE::udp
Description This command gets the value of the parameter for the UDP template.
548
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
This command returns the value for the specified <setting> for the
designated UDP template. For the <setting> parameter, enter one of
the options below:
• name
• aging
• idle_timeout
• qos
• re_select_if_server_down
• stateless_conn_timeout
Valid Events
All.
549
Time Commands
The time commands are used to return and format the time.
The following time commands are supported:
l TIME::clock
l clock format
550
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
TIME::clock
Description This command returns the system time in seconds or milliseconds. This
command is recommended for use in SMP environments to facilitate
high-performance processing. The lowest resolution of the timer is 4
milliseconds.
Example The following example logs the time (in seconds), that the specified
client established a connection. This format argument (%T) indicates
the time will be displayed in the log as hours, minutes, and seconds.
when CLIENT_ACCEPTED {
log "The client [IP::client_addr] connected at [clock
format [TIME::clock seconds] -format {%T}]"
}
Valid Events
All.
clock format
Description This command formats the output of the TIME::clock command.
551
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example The following example logs the time (in seconds), that the specified
client established a connection. In this example, the time is displayed in
4-digit year, month, and day, followed by the hour, minute, and
seconds.
when CLIENT_ACCEPTED {
log "The client [IP::client_addr] connected at [clock
format [TIME::clock seconds]
-format {%Y/%m/%d at %H:%M:%S}]"
}
Valid Events
All.
Descriptor Returns
%% Inserts a “%.”
%a Weekday, abbreviated (Mon, Tues, Wed, etc.).
%A Weekday, unabbreviated (Monday, Tuesday, etc.).
%b Month, abbreviated (Jan, Feb, etc.).
%B Month, unabbreviated (January, February, etc.).
%c Locale specific date and time.
%C First two digits of the year (19, 20, etc).
%d Day of the month, with leading zero if necessary (01 - 31).
%D Date, in format “%m/%d/%y.”
%e Day of month, without leading zeros (1 - 31).
%g The ISO year (corresponding to the ISO week, “%V”), expressed as a
two-digit year-of-the-century, with leading zero if necessary.
%G The ISO year corresponding to the ISO week (%V), expressed as a
four-digit number.
%h Month name, abbreviated (Jan, Feb, etc.).
%H Hour, 24-hour format, with leading zeros if necessary (00-23).
552
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Descriptor Returns
%I Hour, 12-hour format, with leading zeros if necessary (01-12).
%j Day of the year, with leading zeros if necessary (000-366).
%k Hour, 24-hour format, no leading zeros (0-23).
%l Hour, 12-hour format, no leading zeros (1-12).
%m Month, as a number (01-12).
%M Minute (00-59).
%n Line break.
%p Displays AM or PM.
%r Time in a locale-specific "meridian" format. The "meridian" format in
the default "C" locale is "%I:%M:%S %p".
%R Time in hours and minutes (same as “%H:%M).
%s Number of seconds since the TIME::clock command was executed.
%S Seconds (00-59).
%t Tab.
%T Displays time in hours, minutes and seconds (same as “%H:%M:%S”).
%u Weekday, as a number (Monday=1, Sunday=7).
%U Week of the year, with Sunday as first day of the week (00-52).
%V Week of the year according to ISO rules (The week including January
4 is week 1).
%w Weekday, as a number (Sunday=0, Saturday=6).
%W Week of the year, with Monday as first day of the week (00-52).
%x Locale specific date format.
%X Locale specific 24-hour time format.
%y Last two digits of the year (00-99).
%Y Four-digit year (for example,1985)
%Z Time zone.
553
UDP Commands
The following link commands are supported:
l UDP::client_port
l UDP::local_port
l UDP::payload
l UDP::remote_port
l UDP::respond
l UDP::server_port
554
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
UDP::client_port
Description The following command returns the UDP port/service number for the
designated client. This command is equivalent to the command
clientside { UDP::remote_port }.
Syntax UDP::client_port
Example Use the following example when a client has established a connection if
the client port is UDP 123, then use the service group for UDP.
when CLIENT_ACCEPTED {
if { [UDP::client_port] == 123 } {
pool service_group_udp
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
UDP::local_port
Description The following command returns the local UDP port/service number.
Syntax UDP::local_port
Example Use the following example when a client has established a connection
to use service group for DNS if the local UDP port is 53. Otherwise, if
the local port is UDP 123, then use the service group for UDP. If
anything else, then drop.
when CLIENT_ACCEPTED {
if { [UDP::local_port] == 53 } {
555
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
pool service_group_dns
} elseif { [UDP::local_port] == 123 } {
pool service_group_udp
} else {
drop
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
UDP::payload
Description The following command returns the content or length of the current
UDP payload.
This option returns the length, in bytes, of the current UDP payload.
UDP::payload <offset> <size>
This option returns the content of the current UDP payload from
<offset>.
UDP::payload replace <offset> <size> <new_data>
556
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example Use the following example to use dns_service_group1 when the UDP
payload index from 12 through 20 contains the example string, else use
dns_service_group2.
when CLIENT_DATA {
if { [UDP::payload 12 20] contains "example string" } {
pool dns_service_group1
} else {
pool dns_service_group2
}
}
Example In the following example, the payload is emptied and then re-filled with
the data from the “packetdata” string that is sent to the server.
when CLIENT_DATA {
UDP::payload replace 0 [UDP::payload length] ""
# craft a string to hold data, 0x01 0x00 0x00 0x00 0x02 0x00
0x00 0x00 0x03 0x00 0x00 0x00
set packetdata [binary format i1i1i1 1 2 3 ]
UDP::payload replace 0 0 $packetdata
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
UDP::remote_port
Description The following command returns the remote UDP port/service number.
Syntax UDP::remote_port
Example Use the following example to use service_group_udp if the UDP remote
port equals 123.
557
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when CLIENT_ACCEPTED {
if { [UDP::remote_port] == 123 } {
pool service_group_udp
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
UDP::respond
Description The following command sends the specified data directly to the peer.
You can use this command to complete the protocol handshake.
Example Use the following example if the UDP payload contains one string and
you want to respond with another string.
when CLIENT_DATA {
if { [UDP::payload] contains "asd"] } {
UDP::respond "jkl"
}
}
Example Use the following example to compare the client address to the
network address, then drop if it matches, and send an error message to
the peer.
when CLIENT_DATA {
if { [IP::addr [IP::client_addr] equals 192.168.0.0] } {
UDP::drop
UDP::respond "Error: The client is not allowed\r\n"
558
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
}
}
Example Use the following example to initialize the data with the required
binary format and respond to the peer with it.
when CLIENT_ACCEPTED {
set packet [binary format S {0x0000}]
UDP::respond $packet
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
UDP::server_port
Description The following command returns the UDP port/service number of the
server. This command is equivalent to the command serverside {
UDP::remote_port }.
Syntax UDP::server_port
Example Use the following example if the UDP server port equals 123, then log it.
when SERVER_CONNECTED {
if { [UDP::server_port] == 123 } {
log "The Server Port is [UDP::server_port]."
}
}
Valid Events
• CLIENT_ACCEPTED
• CLIENT_CLOSED
• CLIENT_DATA
559
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• SERVER_CLOSED
• SERVER_CONNECTED
• SERVER_DATA
560
URI Commands
The following commands can be used to return URI information:
l URI::basename
l URI::decode
l URI::encode
l URI::path
l URI::query
561
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
URI::basename
Description The following command returns the basename portion for the
designated URI.
For example, given the URI /path/to/file.ext?=param=value,
URI::basename returns file.ext
Example Use the following example to log the basename portion of the URi for
an HTTP request.
when HTTP_REQUEST {
log "The URI Basename is [URI::basename [HTTP::uri]]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
URI::decode
Description This command returns a decoded version for a specified URI.
Example Decodes a known URL encoded string and logs the output.
when HTTP_REQUEST {
set d "wtf%20%30%31%32"
set e [URI::decode $d]
log "uri decode HTTP_REQUEST:$e"
}
Valid Events
• HTTP_REQUEST
562
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
URI::encode
Description The following command returns an encoded version of a designated
URI.
Example The following example encodes the URIs in HTTP requests and/or
responses such that the URI associated with the 404 redirect message is
encoded.
when HTTP_REQUEST {
set HOST [HTTP::host]
}
when HTTP_RESPONSE {
if { [HTTP::status] == 404 } {
HTTP::redirect http://backup.example.com/?q=
[URI::encode "redirected by $HOST"]
}
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
URI::path
Description The following command returns the path portion for a designated URI.
For example, if we specify the URI /path/to/file.ext?=param=value,
and then use the command URI::path, this will return the following
/path/to/.
563
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Example In the following example, an HTTP request will trigger the generation of
a log message containing the path portion for a designated URI.
when HTTP_REQUEST {
set uri [HTTP::uri]
log "$uri path=[URI::path $uri] depth=[URI::path $uri depth]"
}
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
URI::query
Description The following command returns the query string portion for a
designated URI.
For example, if we specify the URI /path/to/file.ext?=param=value,
the command URI::path returns param=value.
Example In the following example, an HTTP request will trigger the generation of
a log message containing the query parameter with value sent in the
URI.
when HTTP_REQUEST {
set query [URI::query [HTTP::uri]]
log "The query portion of the URI is [HTTP::uri]: $query"
}
564
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
565
URL Commands
The following category commands is supported:
l URL::reputation
566
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
URL::reputation
Description To get the URL reputation values.
NOTE:
• It only supports numeric values to do the operations
and the values returns a specific score (from 1-100).
• The require-web-category does not support the
HTTP2 connection.
• The require-web-category is only supported by HTTP_
REQUEST and HTTP_REQUEST_DATA events.
Example
when HTTP_REQUEST {
set host [HTTP::host]
log "Reputation : [URL::reputation $host require-web-
category]"
}
Valid Events
567
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
568
WAF Commands
The following Web Application Firewall (WAF) commands are supported:
l WAF::disable
l WAF::enable
l WAF::mode
l WAF::response_body
l WAF::template
l WAF::violation
569
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
WAF::disable
Description This command will disable WAF processing for the connection during
which the aFleX script is triggered.
Syntax WAF::disable
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_RESPONSE
• HTTP_RESPONSE_DATA
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
WAF::enable
Description This command will re-enable WAF processing for the connection during
which the aFleX script is triggered.
Syntax WAF::enable
Valid Events
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
570
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE_DATA
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
WAF::mode
Description This command will return the current deployment mode in which WAF
is configured (active, passive or learning).
Syntax WAF::mode
Example Use the following example whenever a WAF request is denied to log the
deployment mode, the name of the active template,the source IP of the
originator of the violation, the type of violation, the unique transaction
ID, the action taken for the violation, and the severity.
when WAF_REQUEST_DENY {
set mode [WAF::mode]
set template [WAF::template]
set srcip [WAF::violation src_ip]
set type [WAF::violation type]
set msg [WAF::violation message]
set id [WAF::violation id]
set action [WAF::violation action]
set severity [WAF::violation severity]
log "For WAF REQUEST DENY: mode=$mode
template=$template src ip=$srcip type=$type error msg=$msg
session id=$id action=$action severity=$severity"
}
Valid Events
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
571
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
WAF::response_body
Description This command will return the response body after WAF violation
occurs.
Valid Events
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
WAF::template
Description This command will return the name of the active WAF template.
Syntax WAF::template
Valid Events
• WAF_REQUEST_DENY
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
572
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
WAF::violation
Description This command will return or log information related to WAF violation
events.
This will return a value to indicate which action was taken with this
violation. The value returned will be one of the following strings:
• Allow - This action is triggered by a violation event when WAF is in
passive and learning deployment.
• Deny - This action is triggered by a violation event when WAF is in
active deployment mode.
• Mask - This action is triggered for the event WAF_RESPONSE_
VIOLATION only for selected features (ssn-mask, ccn-mask, pcre-
mask)
• Redirect - This action is triggered under violation events for
referer-check feature if WAF is in active deployment.
• Sanitize - This action is triggered for the WAF_REQUEST_VIOLATION
event for features that support "sanitize" (xss-check, sqlia-check)
and for the WAF_RESPONSE_VIOLATION event.
WAF::violation id
This will log a message with details about the specific violation.
WAF::violation severity
This will return the severity of triggering violation. One of the following
two severities will be returned:
• WAF_SEVERITY_HIGH
• WAF_SEVERITY_MED
573
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
NOTE: At this time, buff overflow is the only type of WAF violation that
returns WAF_SEVERITY_MED. All other violations return WAF_
SEVERITY_HIGH.
WAF::violation src_ip
This will return and log the type of violation that has occurred. At the
time of current release, the following string types are available:
String Types
bad-http-method form-check-value-too-long
black-list-check header-too-long
black-list-check-error hide-resp-code
botnet-check hide-resp-code-failure
botnet-check-error http-failure
botnet-check-ua-too-long http-sanity-failure
buf-overflow http-too-many-headers
cookie-encrypt learning-list
cookie-encrypt-failure missing-referer
cookie-encrypt-remove pcre-masked
cookie-encrypt-toomany post-too-large
cookie-parse_failure referer-check
cookie-too-long sqlia-check
cookie-too-many sqlia-check-error
filter-resp-header success
form-check url_blist_fail
form-check-name-empty url-check
form-check-name-incomplete url-path-too-long
form-check-name-too-long white-list-check
574
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
String Types
form-check-parse-failure white-list-check-error
form-check-url-decode-failure xss-check
form-check-value-incomplete xss-check-error
NOTE: These values are meant to be an example of the types of strings that
may display. Strings in this list may change or be removed, and new
strings may be added
Example Use the following example whenever a WAF request is denied to log the
deployment mode, the name of the active template,the source IP of the
originator of the violation, the type of violation, the details about the
violation, the unique transaction ID, the action taken for the violation,
and the severity.
when WAF_REQUEST_DENY {
set mode [WAF::mode]
set template [WAF::template]
set srcip [WAF::violation src_ip]
set type [WAF::violation type]
set msg [WAF::violation message]
set id [WAF::violation id]
set action [WAF::violation action]
set severity [WAF::violation severity]
log "For WAF REQUEST DENY: mode=$mode
template=$template src ip=$srcip type=$type error msg=$msg
session id=$id action=$action severity=$severity"
}
NOTE: For more information about WAF violations, see the Web Application
Firewall Guide.
Valid Events
• WAF_REQUEST_VIOLATION
• WAF_RESPONSE_VIOLATION
575
X509 Commands
The following link commands are supported:
l X509::extensions
l X509::hash
l X509::issuer
l X509::not_valid_after
l X509::not_valid_before
l X509::serial_number
l X509::signature_algorithm
l X509::subject
l X509::subject_public_key
l X509::subject_public_key_RSA_bits
l X509::subject_public_key_type
l X509::text
l X509::verify_cert_error_string
l X509::version
l X509::whole
576
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
X509::extensions
Description This command will return the X.509 extensions set on the specified
X.509 certificate. If an invalid certificate is supplied, a runtime TCL error
is generated.
when CLIENTSSL_CLIENTCERT {
log "The X509 extensions for cert 0 are [X509::extensions
[SSL::cert 0]]."
}
Valid Events
All.
X509::hash
Description This will return the MD5 (default) or SHA1 hash (fingerprint) of the
specified X.509 certificate.
NOTE: X509::hash no longer returns a text string but the actual hash value as
a Byte array. To return a text string, use the binary scan command. See
the Example 2 below.
Example Use the following example to log the hash for the specified certificate
when complete client request header (method, URI, version, and all
headers, not including the body) is parsed.
Example 1
when HTTP_REQUEST {
577
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
All.
X509::issuer
Description The command will return the issuer of the X.509 certificate.
Syntax X509::issuer
Example Use the following example to log the certificate issuer when an SSL
handshake on the client side is completed.
when CLIENTSSL_HANDSHAKE {
log "The X509 issuer for cert 0 is [X509::issuer
[SSL::cert 0]]."
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
578
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
X509::not_valid_after
Description This command will return the not-valid-after date of an X.509
certificate.
Syntax X509::not_valid_after
Example Use the following example to log the date when an SSL handshake on
the client side is completed.
when CLIENTSSL_HANDSHAKE {
log "The X509 is not valid after the date of cert 0
[X509::not_valid_after [SSL::cert 0]]."
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
X509::not_valid_before
Description This will return the not-valid-before date of an X.509 certificate.
Syntax X509::not_valid_before
Example Use the following example to log the date when an SSL handshake on
the client side is completed.
when CLIENTSSL_HANDSHAKE {
579
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
X509::serial_number
Description Returns the serial number of an X.509 certificate.
Syntax X509::serial_number
Example Use the following example to log the serial number when an SSL
handshake on the client side is completed.
when CLIENTSSL_HANDSHAKE {
log "The X509 serial number of cert 0 is [X509::serial_
number [SSL::cert 0]]."
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
580
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_RESPONSE_DATA
X509::signature_algorithm
Description This command returns the signature algorithm of the specified X.509
certificate.
Example Use the following example to log the signature algorithm when an SSL
handshake on the client side is completed.
when CLIENTSSL_HANDSHAKE {
log "The X509 signature algorithm of cert 0 is
[X509::signature_algorithm [SSL::cert 0]]"
}
Valid Events
All.
X509::subject
Description This command will return the subject of an X.509 certificate.
Syntax X509::subject
Example Use the following example to set the certificate subject & log it when an
SSL handshake on the client side is completed.
when CLIENTSSL_HANDSHAKE {
set subject [X509::subject [SSL::cert 0]]
log "The X509 subject of cert 0 is $subject."
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
581
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
X509::subject_public_key
Description This command will return the subject’s public key of the specified X.509
certificate.
Example Use the following example to log the public key when an SSL client
certificate is received.
when CLIENTSSL_CLIENTCERT {
log "The X509 subject public key for cert 0 is
[X509::subject_public_key [SSL::cert 0]]"
}
Valid Events
All.
X509::subject_public_key_RSA_bits
Description This command will return the size of the subject’s public RSA key of an
X.509 certificate. This command is only applicable when the public key
type is RSA. Otherwise, the command generates an error.
Example Use the following example to log the public key size when an SSL client
certificate is received.
582
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when CLIENTSSL_CLIENTCERT {
log "The X509 RSA public key size of cert 0 is
[X509::subject_public_key_RSA_bits [SSL::cert 0]]."
}
Valid Events
All.
X509::subject_public_key_type
Description This command will return the subject’s public key type of the specified
X.509 certificate. The returned value can be RSA, DSA, or unknown.
Example Use the following example to log the Public Key Algorithm value under
the Subject Public key info for the client certificate at level 0 sent by the
client for authentication.
when CLIENTSSL_CLIENTCERT {
log "x509 subject_public_key_type CLIENTSSL_
CLIENTCERT: [X509::subject_public_key_type [SSL::cert 0]]"
}
Valid Events
All.
X509::text
Description This command will return a certificate in human-readable (text) format.
Example Use the following example to log the human-readable certificate format
when an SSL client certificate is received.
583
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
when CLIENTSSL_CLIENTCERT {
log "The X509 readable text of cert 0 is [X509::text
[SSL::cert 0]]"
}
Valid Events
All.
X509::verify_cert_error_string
Description This command will return the error string as an OpenSSL X.509 error
string.
Syntax X509::verify_cert_error_string
Example Use the following example to log the error string and the result code
when an SSL handshake on the client side is completed.
when CLIENTSSL_HANDSHAKE {
log "The X509 verify result of the peer is [X509::verify_
cert_error_string [SSL::verify_result]]."
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
584
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
X509::version
Description This command will return the version number of an X.509 certificate.
Syntax X509::version
Example Use the following example to log the certificate version when an SSL
handshake on the client side is completed.
when CLIENTSSL_HANDSHAKE {
log "The X509 version of cert 0 is [X509::version
[SSL::cert 0]]."
}
Valid Events
• CLIENTSSL_CLIENTCERT
• CLIENTSSL_HANDSHAKE
• HTTP_REQUEST
• HTTP_REQUEST_DATA
• HTTP_REQUEST_SEND
• HTTP_RESPONSE
• HTTP_RESPONSE_CONTINUE
• HTTP_RESPONSE_DATA
X509::whole
Description This command will return the entire X.509 certificate in PEM format.
Example Use the following example to log the whole client certificate at level 0
sent to ACOSÆ for client authentication in text form.
when CLIENTSSL_CLIENTCERT {
log "x509 whole CLIENTSSL_CLIENTCERT: [X509::whole [SSL::cert
0]]"
}
Valid Events
585
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
aFleX Commands
All.
586
Deprecated and Disabled Commands
The aFleX scripting language previously supported some commands that are no
longer supported. In addition, though aFleX is based on Tcl, many Tcl commands
have been disabled for security reasons. See the following topics for lists of
deprecated and disabled commands:
l Deprecated aFleX Commands
l Disabled Tcl Commands
587
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Deprecated and Disabled Commands
client_ TCP::client_port
port
or
UDP::client_port
http_ HTTP::cookie
cookie
http_ HTTP::header
header
http_host HTTP::host
http_ HTTP::method
method
http_uri HTTP::uri
http_ HTTP::version
version
ip_ IP::protocol
protocol
ip_tos IP::tos
local_addr IP::local_addr
redirect HTTP::redirect
remote_ IP::remote_addr
addr
server_ IP::server_addr
588
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Deprecated and Disabled Commands
server_ TCP::server_port
port
or
UDP::server_port
use <command>
<command>
This represents any valid and supported aFleX command.
Please avoid use of “use” in front of any command. For the
names of valid commands, see aFleX Commands.
For a list of disabled Tcl commands, see Disabled Tcl Commands.
589
ACOS 6.0.0-P1 aFleX Scripting Language Reference Guide Feedback
Deprecated and Disabled Commands
For a list of previously support aFleX commands that have been deprecated, see
Deprecated aFleX Commands.
590
©2023 A10 Networks, Inc. All rights reserved. A10 Networks, the A10 Networks logo, ACOS, A10 Thunder,
Thunder TPS, A10 Harmony, SSLi and SSL Insight are trademarks or registered trademarks of A10 Networks, Inc. in
the United States and other countries. All other trademarks are property of their respective owners. A10
Networks assumes no responsibility for any inaccuracies in this document. A10 Networks reserves the right to
change, modify, transfer, or otherwise revise this publication without notice. For the full list of trademarks, visit:
Contact Us
www.a10networks.com/company/legal/trademarks/.