| Read from Network Socket | 
The Read from Network Socket action reads from a network socket for incoming data.
You can configure the properties for the Read from Network Socket action on the following tabs.
 Read from Network Socket Tab
Read from Network Socket Tab
            Network Socket
Read data from the original inbound integration connection: Specifies that the data is read from the same socket connection as the one that is specified by the parent network socket integration. Available only when the parent integration is a network socket integration.
Read with new connection: Specifies that the data is read from a new socket connection. Available only when the parent integration is a network socket integration. 
When the Read with new connection option is selected or when the parent integration method is something other than a network socket integration, you can define the network socket connection from which to read the data by using the following options:
Protocol: Specifies the socket protocol to use.
Port: Specifies the network address port.
Network Address:
Listen on all network interfaces: Specifies that the socket listens to all network addresses.
Listen on specific IP address (v4/v6): Specifies that the socket listens to only the IP address that you specify.
Communication Settings
Read Timeout: Specifies the amount of time to wait for the socket to read data.
Write Timeout: Specifies the amount of time to wait for the socket to write data. Available only when you select TCP as the protocol.
Connection Protocol
Send acknowledgement message when client connects: Specifies the message that is sent when the socket connection is made. Enter the message that you want in the input box. Alternatively, you can add a variable to specify the acknowledgment message. You can also add a special character to the value you have entered.
Write response message after reading data from the client connection: Specifies the message that is sent after the action runs. Enter the message that you want in the input box. Alternatively, you can add a variable to specify the response message. You can also add a special character to the value you have entered.
Data Options
Encoding: Specifies the method that is used to encode the message that is being read.
Stop Reading When: Specifies the condition under which the action stops reading the message.
Sequence of Characters is Received: Specifies that the action stops reading the message after a specified sequence of characters is received.
Characters: Specifies the sequence of characters that tells the action to stop reading the message.
Include sequence in input data contents: Specifies that the indicated sequence of characters is read as part of the data contents.
Number of Characters is Received: Specifies that the action stops reading the message after a specified number of characters is received.
Characters: Specifies the maximum number of characters that the action accepts in the message.
Port Becomes Idle: Specifies that the action stops reading the message after the port is idle for a specified period of time.
Time to Wait: Specifies the amount of time that the port can be idle before the action stops reading the message.
Socket is Disconnected: Specifies that the action stops reading the message when the socket becomes disconnected.
Content Type: Specifies the data content type. The action processes the contents of the message according to this format.
Data is contained in a SOAP message: Specifies that the action looks for the data to be contained in a SOAP message.
Response
Respond using new connection: Directs the action to respond by using the new specified connection.
Host Name: Specifies the DNS name of the remote host to which you want to connect.
IP Address (v4/v6): Specifies the IP address for the connection.
Port: Specifies the network address port.
Output
Save input data to variable: Specifies the variable to which you want to save the input of the action. Enter the variable that you want. Alternatively, you can add a variable.
 Action Tab
Action TabAction
Name: Specifies the name of the action. You can replace the default name by entering a new name in the field.
Description: Specifies a description for the action.
Run Action: Specifies how often you want to run the action.
Always: Specifies that the Integration Service runs the action each time it runs the integration.
Never: Specifies that the Integration Service does not run the action when it runs the integration.
Conditionally, based on variable: Specifies that the Integration Service runs the action only when a selected variable meets a specified condition. Use this option in situations in which there is only one condition that determines whether the action runs. After you select this option, you can create the conditional statement in the input box.
Variable: Specifies the variable that you want to use for the conditional statement. Enter the variable in the input box.  Click  to see a list of recently used variables or click More Variables to open the Insert Variable dialog.
 to see a list of recently used variables or click More Variables to open the Insert Variable dialog. 
[Relational Operator]: Specifies the relational operator to use for the conditional statement. Click the existing operator to display a list of additional operators, and then click the one that you want to use. For more information, refer to Relational Operators. The operators that are available in the list depend on whether you selected Text or Decimal for the Type option.
Value: Specifies the values to use for the conditional statement. To add a value, click  , click <enter a value>,  enter the value that you want, and then press
, click <enter a value>,  enter the value that you want, and then press Enter. To delete a value, use the secondary mouse button to click it, and then click Delete. Some operators, such as Is blank and Is not blank, do not require a value to be specified. In these situations, the Value field is not available. 
Type: Specifies whether the conditional statement is evaluating a text or decimal value.
Conditionally, based on expression: Specifies the conditions under which the Integration Service runs the action. Use this option for situations that require more than one conditional statement. When you select this option, you can create the conditional expression in the input box by creating the conditional statements that you want. You create and edit your conditional expression on the Tree View tab. Click the Text View tab to see a read-only text view of the conditional expression.
 Input box controls (Tree View tab)
Input box controls (Tree View tab)
[Conditional Joiner]: Specifies the conditional joiner for the conditional statements within the group. The default conditional joiner is And.
Click the existing conditional joiner to display a menu that enables you to configure your conditional expression in one of the following ways:
And, Or, NotAnd, NotOr: Click the conditional joiner in the list that you want to use for the conditional statements. For more information about the supported conditional joiners, refer to Conditional Joiners.
Add Condition: Click to add another conditional statement to the current group.
Add Group: Click to add a subgroup of conditional statements to the current group.
Remove Group: Click to delete the subgroup. Available when you open the menu from a subgroup.
Clear All: Click to delete all conditional statements (including subgroups). Available when you open the menu from the top-most group.
 : Adds a conditional statement to the group that is associated with that joiner.  Visible to the right of each conditional joiner in your expression.
: Adds a conditional statement to the group that is associated with that joiner.  Visible to the right of each conditional joiner in your expression.
 :  Deletes the  conditional statement. Visible to the right of an existing conditional statement when you point to the statement.
:  Deletes the  conditional statement. Visible to the right of an existing conditional statement when you point to the statement. 
Variable: Specifies the variable that you want to use for the conditional statement. Enter the variable in the input box.  Click  to see a list of recently used variables or click More Variables to open the Insert Variable dialog.
 to see a list of recently used variables or click More Variables to open the Insert Variable dialog.
[Relational Operator]: Specifies the relational operator to use for the conditional statement. Click the existing operator to display a list of additional operators, and then click the one that you want to use. For more information, refer to Relational Operators. The operators that are available in the list depend on whether you selected Text or Decimal for the Type option.
Value: Specifies the values to use for the conditional statement.  To add a value, click  , click <enter a value>,  enter the value that you want, and then press
, click <enter a value>,  enter the value that you want, and then press Enter. To delete a value, use the secondary mouse button to click it, and then click Delete. Some operators, such as Is blank and Is not blank, do not require a value to be specified. In these situations, the Value field is not available.
Type: Specifies whether the conditional statement is evaluating a text or decimal value.
User Account
Inherit from parent action: Specifies that the action inherits the user account credentials that are specified on the Actions property page. Alternatively, if the action is part of a Group action, it inherits the user account credentials that are specified on the immediate parent Group action’s property page.
Specify user credentials: Specifies that the action runs by using the credentials that are specified.
Error Handling and Diagnostics
Ignore errors and continue running actions: Specifies that if the action fails, the remaining actions continue to run. When this option is not selected and the action fails, the resulting behavior depends on several factors, as follows:
 The action is within a Group action
The action is within a Group action
If you specified Sequentially for the Execute Actions property on the Group action's Execution tab, no further actions within that Group action are run. No actions outside of this Group action are affected.
If you specified In Parallel for the Execute Actions property on the Group action's Execution tab, the errors are ignored, and the other actions within that Group action are run. No actions outside of this Group action are affected.
 The action is not within a Group action
The action is not within a Group action
If you specified Sequentially for the Execute Actions property on the Actions Execution tab, no further actions within the integration are run.
If you specified In Parallel for the Execute Actions property on the Actions Execution tab, the errors are ignored, and the other actions within the integration are run.
Retry if failed: Specifies that if the action fails, the Integration Service tries to run it again.
Maximum retries: Specifies the maximum number of times the Integration Service tries to run the action again. Available when the Retry if failed option is selected.
Retry interval: Specifies the length of time the Integration Service waits after the action fails before it tries to run the action again. Available when the Retry if failed option is selected.