Citrix ADC 12.1 NITRO API Reference

lsngroup

Configuration for LSN group resource.

Properties

(click to see Operations)

Name Data Type Permissions Description
groupname Read-write Name for the LSN group. Must begin with an ASCII alphanumeric or underscore (_) character, and must contain only ASCII alphanumeric, underscore, hash (#), period (.), space, colon (:), at (@), equals (=), and hyphen (-) characters. Cannot be changed after the LSN group is created. The following requirement applies only to the Citrix ADC CLI: If the name includes one or more spaces, enclose the name in double or single quotation marks (for example, “lsn group1” or ‘lsn group1’).
Minimum length = 1
Maximum length = 127
clientname Read-write Name of the LSN client entity to be associated with the LSN group. You can associate only one LSN client entity with an LSN group.You cannot remove this association or replace with another LSN client entity once the LSN group is created.
nattype Read-write Type of NAT IP address and port allocation (from the bound LSN pools) for subscribers:

Available options function as follows:

* Deterministic - Allocate a NAT IP address and a block of ports to each subscriber (of the LSN client bound to the LSN group). The Citrix ADC sequentially allocates NAT resources to these subscribers. The Citrix ADC ADC assigns the first block of ports (block size determined by the port block size parameter of the LSN group) on the beginning NAT IP address to the beginning subscriber IP address. The next range of ports is assigned to the next subscriber, and so on, until the NAT address does not have enough ports for the next subscriber. In this case, the first port block on the next NAT address is used for the subscriber, and so on. Because each subscriber now receives a deterministic NAT IP address and a block of ports, a subscriber can be identified without any need for logging. For a connection, a subscriber can be identified based only on the NAT IP address and port, and the destination IP address and port. The maximum number of LSN subscribers allowed, globally, is 1 million.

* Dynamic - Allocate a random NAT IP address and a port from the LSN NAT pool for a subscriber’s connection. If port block allocation is enabled (in LSN pool) and a port block size is specified (in the LSN group), the Citrix ADC allocates a random NAT IP address and a block of ports for a subscriber when it initiates a connection for the first time. The ADC allocates this NAT IP address and a port (from the allocated block of ports) for different connections from this subscriber. If all the ports are allocated (for different subscriber’s connections) from the subscriber’s allocated port block, the ADC allocates a new random port block for the subscriber.
Default value: DYNAMIC
Possible values = DYNAMIC, DETERMINISTIC
allocpolicy Read-write NAT IP and PORT block allocation policy for Deterministic NAT. Supported Policies are,
1: PORTS: Port blocks from single NATIP will be allocated to LSN subscribers sequentially. After all blocks are exhausted, port blocks from next NATIP will be allocated and so on.
2: IPADDRS(Default): One port block from each NATIP will be allocated and once all the NATIPs are over second port block from each NATIP will be allocated and so on.
To understand better if we assume port blocks of all NAT IPs as two dimensional array, PORTS policy follows “row major order” and IPADDRS policy follows “column major order” while allocating port blocks.
Example:
Client IPs: 2.2.2.1, 2.2.2.2 and 2.2.2.3
NAT IPs and PORT Blocks:
4.4.4.1:PB1, PB2, PB3,., PBn
4.4.4.2: PB1, PB2, PB3,., PBn
PORTS Policy:
2.2.2.1 => 4.4.4.1:PB1
2.2.2.2 => 4.4.4.1:PB2
2.2.2.3 => 4.4.4.1:PB3
IPADDRS Policy:
2.2.2.1 => 4.4.4.1:PB1
2.2.2.2 => 4.4.4.2:PB1
2.2.2.3 => 4.4.4.1:PB2.
Default value: IPADDRS
Possible values = PORTS, IPADDRS
portblocksize Read-write Size of the NAT port block to be allocated for each subscriber.

To set this parameter for Dynamic NAT, you must enable the port block allocation parameter in the bound LSN pool. For Deterministic NAT, the port block allocation parameter is always enabled, and you cannot disable it.

In Dynamic NAT, the Citrix ADC allocates a random NAT port block, from the available NAT port pool of an NAT IP address, for each subscriber. For a subscriber, if all the ports are allocated from the subscriber’s allocated port block, the ADC allocates a new random port block for the subscriber.

The default port block size is 256 for Deterministic NAT, and 0 for Dynamic NAT.
Default value: 0
Minimum value = 256
Maximum value = 65536
logging Read-write Log mapping entries and sessions created or deleted for this LSN group. The Citrix ADC logs LSN sessions for this LSN group only when both logging and session logging parameters are enabled.

The ADC uses its existing syslog and audit log framework to log LSN information. You must enable global level LSN logging by enabling the LSN parameter in the related NSLOG action and SYLOG action entities. When the Logging parameter is enabled, the Citrix ADC generates log messages related to LSN mappings and LSN sessions of this LSN group. The ADC then sends these log messages to servers associated with the NSLOG action and SYSLOG actions entities.

A log message for an LSN mapping entry consists of the following information:
* NSIP address of the Citrix ADC
* Time stamp
* Entry type (MAPPING or SESSION)
* Whether the LSN mapping entry is created or deleted
* Subscriber’s IP address, port, and traffic domain ID
* NAT IP address and port
* Protocol name
* Destination IP address, port, and traffic domain ID might be present, depending on the following conditions:
Destination IP address and port are not logged for Endpoint-Independent mapping<br> Only Destination IP address (and not port) is logged for Address-Dependent mapping
` Destination IP address and port are logged for Address-Port-Dependent mapping.
Default value: DISABLED
Possible values = ENABLED, DISABLED
sessionlogging Read-write Log sessions created or deleted for the LSN group. The Citrix ADC logs LSN sessions for this LSN group only when both logging and session logging parameters are enabled.

A log message for an LSN session consists of the following information:
* NSIP address of the Citrix ADC
* Time stamp
* Entry type (MAPPING or SESSION)
* Whether the LSN session is created or removed
* Subscriber’s IP address, port, and traffic domain ID
* NAT IP address and port
* Protocol name
* Destination IP address, port, and traffic domain ID.
Default value: DISABLED
Possible values = ENABLED, DISABLED
sessionsync Read-write In a high availability (HA) deployment, synchronize information of all LSN sessions related to this LSN group with the secondary node. After a failover, established TCP connections and UDP packet flows are kept active and resumed on the secondary node (new primary).

For this setting to work, you must enable the global session synchronization parameter.
Default value: ENABLED
Possible values = ENABLED, DISABLED
snmptraplimit Read-write Maximum number of SNMP Trap messages that can be generated for the LSN group in one minute.
Default value: 100
Minimum value = 0
Maximum value = 10000
ftp Read-write Enable Application Layer Gateway (ALG) for the FTP protocol. For some application-layer protocols, the IP addresses and protocol port numbers are usually communicated in the packet’s payload. When acting as an ALG, the Citrix ADC changes the packet’s payload to ensure that the protocol continues to work over LSN.

Note: The Citrix ADC also includes ALG for ICMP and TFTP protocols. ALG for the ICMP protocol is enabled by default, and there is no provision to disable it. ALG for the TFTP protocol is disabled by default. ALG is enabled automatically for an LSN group when you bind a UDP LSN application profile, with endpoint-independent-mapping, endpoint-independent filtering, and destination port as 69 (well-known port for TFTP), to the LSN group.
Default value: ENABLED
Possible values = ENABLED, DISABLED
pptp Read-write Enable the PPTP Application Layer Gateway.
Default value: DISABLED
Possible values = ENABLED, DISABLED
sipalg Read-write Enable the SIP ALG.
Default value: DISABLED
Possible values = ENABLED, DISABLED
rtspalg Read-write Enable the RTSP ALG.
Default value: DISABLED
Possible values = ENABLED, DISABLED
ip6profile Read-write Name of the LSN ip6 profile to associate with the specified LSN group. An ip6 profile can be associated with a group only during group creation.

By default, no LSN ip6 profile is associated with an LSN group during its creation. Only one ip6profile can be associated with a group.
Minimum length = 1
Maximum length = 127
ftpcm Read-write Enable the FTP connection mirroring for specified LSN group. Connection mirroring (CM or connection failover) refers to keeping active an established TCP or UDP connection when a failover occurs.
Default value: DISABLED
Possible values = ENABLED, DISABLED
groupid Read-only .
Minimum value = 1
__count Read-only count parameter

Operations

(click to see Properties)

Some options that you can use for each operations:

  • Getting warnings in response:NITRO allows you to get warnings in an operation by specifying the "warning" query parameter as "yes". For example, to get warnings while connecting to the Citrix ADC appliance, the URL is as follows:

    http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/login?warning=yes

    If any, the warnings are displayed in the response payload with the HTTP code "209 X-NITRO-WARNING".

  • Authenticated access for individual NITRO operations:NITRO allows you to logon to the Citrix ADC appliance to perform individual operations. You can use this option instead of creating a NITRO session (using the login object) and then using that session to perform all operations,

    To do this, you must specify the username and password in the request header of the NITRO request as follows:

    X-NITRO-USER:<username>

    X-NITRO-PASS:<password>

    Note:In such cases, make sure that the request header DOES not include the following:

    Cookie:NITRO_AUTH_TOKEN=<tokenvalue>

*Note:*

Mandatory parameters are marked in redand placeholder content is marked in <green>.

add

URL:http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup

HTTP Method:POST

Request Headers:

Cookie:NITRO_AUTH_TOKEN=<tokenvalue> Content-Type:application/json

Request Payload:

{"lsngroup":{ <b>"groupname":<String_value>, </b><b>"clientname":<String_value>, </b>"nattype":<String_value>, "allocpolicy":<String_value>, "portblocksize":<Double_value>, "logging":<String_value>, "sessionlogging":<String_value>, "sessionsync":<String_value>, "snmptraplimit":<Double_value>, "ftp":<String_value>, "pptp":<String_value>, "sipalg":<String_value>, "rtspalg":<String_value>, "ip6profile":<String_value>, "ftpcm":<String_value> }}

Response:

HTTP Status Code on Success: 201 Created HTTP Status Code on Failure: 4xx <string> (for general HTTP errors) or 5xx <string> (for Citrix ADC specific errors). The response payload provides details of the error

delete

URL:http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup/groupname_value<String>

HTTP Method:DELETE

Request Headers:

Cookie:NITRO_AUTH_TOKEN=<tokenvalue>

Response:

HTTP Status Code on Success: 200 OK HTTP Status Code on Failure: 4xx <string> (for general HTTP errors) or 5xx <string> (for Citrix ADC specific errors). The response payload provides details of the error

update

URL:http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup

HTTP Method:PUT

Request Headers:

Cookie:NITRO_AUTH_TOKEN=<tokenvalue> Content-Type:application/json

Request Payload:

{"lsngroup":{ <b>"groupname":<String_value>, </b>"portblocksize":<Double_value>, "logging":<String_value>, "sessionlogging":<String_value>, "sessionsync":<String_value>, "snmptraplimit":<Double_value>, "ftp":<String_value>, "pptp":<String_value>, "sipalg":<String_value>, "rtspalg":<String_value>, "ftpcm":<String_value> }}

Response:

HTTP Status Code on Success: 200 OK HTTP Status Code on Failure: 4xx <string> (for general HTTP errors) or 5xx <string> (for Citrix ADC specific errors). The response payload provides details of the error

unset

URL:http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup?action=unset

HTTP Method:POST

Request Headers:

Cookie:NITRO_AUTH_TOKEN=<tokenvalue> Content-Type:application/json

Request Payload:

{"lsngroup":{ <b>"groupname":<String_value>, </b>"portblocksize":true, "logging":true, "sessionlogging":true, "sessionsync":true, "snmptraplimit":true, "ftp":true, "pptp":true, "sipalg":true, "rtspalg":true, "ftpcm":true }}

Response:

HTTP Status Code on Success: 200 OK HTTP Status Code on Failure: 4xx <string> (for general HTTP errors) or 5xx <string> (for Citrix ADC specific errors). The response payload provides details of the error

get (all)

URL:http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup

Query-parameters:

attrs

http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup?attrs=property-name1,property-name2

Use this query parameter to specify the resource details that you want to retrieve.

filter

http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup?filter=property-name1:property-val1,property-name2:property-val2

Use this query-parameter to get the filtered set of lsngroup resources configured on Citrix ADC. Filtering can be done on any of the properties of the resource.

view

http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup?view=summary

Note:By default, the retrieved results are displayed in detail view (?view=detail).

pagination

http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup?pagesize=#no;pageno=#no

Use this query-parameter to get the lsngroup resources in chunks.

HTTP Method:GET

Request Headers:

Cookie:NITRO_AUTH_TOKEN=<tokenvalue> Accept:application/json

Response:

HTTP Status Code on Success: 200 OK HTTP Status Code on Failure: 4xx <string> (for general HTTP errors) or 5xx <string> (for Citrix ADC specific errors). The response payload provides details of the errorResponse Headers:

Content-Type:application/json

Response Payload:

{ "lsngroup": [ { "groupname":<String_value>, "clientname":<String_value>, "nattype":<String_value>, "allocpolicy":<String_value>, "portblocksize":<Double_value>, "logging":<String_value>, "sessionlogging":<String_value>, "sessionsync":<String_value>, "snmptraplimit":<Double_value>, "ftp":<String_value>, "pptp":<String_value>, "groupid":<Double_value>, "sipalg":<String_value>, "rtspalg":<String_value>, "ip6profile":<String_value>, "ftpcm":<String_value> }]}

get

URL:http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup/groupname_value<String>

Query-parameters:

attrs

http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup/groupname_value<String>?attrs=property-name1,property-name2

Use this query parameter to specify the resource details that you want to retrieve.

view

http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup/groupname_value<String>?view=summary

Note:By default, the retrieved results are displayed in detail view (?view=detail).

HTTP Method:GET

Request Headers:

Cookie:NITRO_AUTH_TOKEN=<tokenvalue> Accept:application/json

Response:

HTTP Status Code on Success: 200 OK HTTP Status Code on Failure: 4xx <string> (for general HTTP errors) or 5xx <string> (for Citrix ADC specific errors). The response payload provides details of the errorResponse Headers:

Content-Type:application/json

Response Payload:

{ "lsngroup": [ { "groupname":<String_value>, "clientname":<String_value>, "nattype":<String_value>, "allocpolicy":<String_value>, "portblocksize":<Double_value>, "logging":<String_value>, "sessionlogging":<String_value>, "sessionsync":<String_value>, "snmptraplimit":<Double_value>, "ftp":<String_value>, "pptp":<String_value>, "groupid":<Double_value>, "sipalg":<String_value>, "rtspalg":<String_value>, "ip6profile":<String_value>, "ftpcm":<String_value> }]}

count

URL:http://<Citrix-ADC-IP-address(NSIP)>/nitro/v1/config/lsngroup?count=yes

HTTP Method:GET

Request Headers:

Cookie:NITRO_AUTH_TOKEN=<tokenvalue> Accept:application/json

Response:

HTTP Status Code on Success: 200 OK HTTP Status Code on Failure: 4xx <string> (for general HTTP errors) or 5xx <string> (for Citrix ADC specific errors). The response payload provides details of the errorResponse Headers:

Content-Type:application/json

Response Payload:

{ "lsngroup": [ { "__count": "#no"} ] }
lsngroup