TSYSBenefit Configuration
The component accepts one or more of the following configuration settings. Configuration settings are similar in functionality to properties, but they are rarely used. In order to avoid "polluting" the property namespace of the component, access to these internal properties is provided through the Config method.TSYSBenefit Configuration Settings
AllowPartialAuths: Indicates whether partial authorizations are to be supported.When this setting is True, if the card being authorized does not contain sufficient funds to cover the TransactionAmount, the card will not be declined. Instead, the transaction will be authorized for a lesser amount. The customer must then use another form of payment to make up the remainder. The total amount authorized by TSYS will be returned in the ResponseAuthorizedAmount configuration setting. For instance, if the TransactionAmount is $100.00, but the card only has a $50.00 balance, the card is charged for $50.00, and the ResponseAuthorizedAmount will be "50.00". The merchant may then collect the remaining $50 in cash, check, credit card, or any other acceptable form of payment. This setting is False by default. | |||||||||||||||||||||||||||||||||||||||||||||||
SurchargeAmount: The transaction fee amount charged to the customer to account for acquirer-assessed surcharge.This configuration setting is for informational purposes only and any surcharge amounts charged to the customer should be included in the
TransactionAmount.
The format of this field is 'annnnnnnn' where 'a' is either 'D' for debit or 'C' for credit. 'nnnnnnnn' is the numeric fee amount with the decimal implied. For example: 'D00000150' is a $1.50 transaction fee amount debited to the cardholder's account. Note: If an amount is only specified, the component will generate the format above by prepending a 'D' and the necessary number of 0's. | |||||||||||||||||||||||||||||||||||||||||||||||
AuthorizationIndicator: The type of authorization request.This field defines the type of authorization request and must be included on all MasterCard authorization request transactions.
Valid values are:
| |||||||||||||||||||||||||||||||||||||||||||||||
Retry: Set this to retry a failed transaction.If an authorization returns ambiguously or times out without receiving a response, you may send the same transaction over again with this Retry flag set to True. This will prevent you from double-charging your customers in the case of a communications error (only available for credit card transactions. Does not apply to Debit, Gift Card, or EBT transactions). | |||||||||||||||||||||||||||||||||||||||||||||||
SendExtendedAVS: Specifies whether to send extended AVS data.When set to 'True', AVS data will be sent in the extended AVS field for the transaction. ResponseCardholderVerification will contain the extended AVS verification results. When set to 'False' (default value), the CustomerAddress and CustomerZip values will be sent using the simple AVS data fields. | |||||||||||||||||||||||||||||||||||||||||||||||
ResponseStoreNumber: Check this field against the original Merchant StoreNumber.The value of this field is used to correctly match responses with transactions by comparing its value to that of the StoreNumber. This is particularly useful when making a multi-merchant or multi-store routing system. If the system that originally made the transaction receives a response where the ResponseStoreNumber is not identical to the StoreNumber the transaction should not be stored for batch settlement. This field is read-only. | |||||||||||||||||||||||||||||||||||||||||||||||
ResponseTerminalNumber: Check this field against the original Merchant TerminalNumber.The value of this field is used to correctly match responses with transactions by comparing its value to that of TerminalNumber. This is particularly useful when making a multi-terminal routing system within a merchant location. If the terminal that originally made the transaction receives a response where the ResponseTerminalNumber is not identical to the TerminalNumber, the transaction should not be stored for batch settlement. This field is read-only. | |||||||||||||||||||||||||||||||||||||||||||||||
ResponseCardholderVerification: Verification results for cardholder identification data (extended AVS).This response data is returned when SendExtendedAVS is set to 'True' and is only available for American Express and Discover cards.
This data is arranged in order of 5 bytes, one for each result of a cardholder identification data element:
The possible values for each byte are:
For Discover transactions, byte 3 will be populated with the following values:
| |||||||||||||||||||||||||||||||||||||||||||||||
Port: The port to which transactions are posted.This is port that this component connects to on the server. The default value for TSYS is 5003 for the live server, and 5004 for the test server. The default live server values for Heartland is 22341 for Authorization and 22342 for Settlement. The Heartland test server values are 12341 for Authorization and 12342 for Settlement. | |||||||||||||||||||||||||||||||||||||||||||||||
Server: The server to which transactions are posted.This is name of the server to which all transactions are posted. Do not use an IP address, use the actual name, as a server's IP address may change. The default (Live) TSYS server is "ssl2.vitalps.net", but you may use "ssltest.tnsi.com" for testing. The default (Live) Heartland server is "txns.secureexchange.net", but you may use "test.txns.secureexchange.net" for testing. Note that there are several BankIds and Numbers that will always run in test mode regardless of whether you are using the live server. See the included demos for examples. | |||||||||||||||||||||||||||||||||||||||||||||||
AuthenticationCode: An alphanumeric code provided to the POS user for input when authenticating a POS device.This field is used to specify the AuthenticationCode, assigned by TSYS, to authenticate a POS device (made via a call to ActivateTerminal). | |||||||||||||||||||||||||||||||||||||||||||||||
ActivateTerminal: Authenticates a POS device with TSYS.This is an action config which when called will authenticate a POS device with TSYS. Authentication is required when processing transactions using Voltage Encryption or Tokenization. An AuthenticationCode is required to be specified, as is Zip and/or ServicePhone, to perform authentication. After a POS device is successfully authenticated, GenKey will be populated. | |||||||||||||||||||||||||||||||||||||||||||||||
DeactivateTerminal: Deactivates a POS device with TSYS.This is an action config which when called will deactivate the POS device specified via GenKey with TSYS. | |||||||||||||||||||||||||||||||||||||||||||||||
GenKey: A randomly generated string of alphanumeric characters identifying the terminal.This field is used to specify retrieve or specify a GenKey value for a terminal. This field will be populated after a successful call to ActivateTerminal is made. The Genkey must be stored in the POS device, must be sent with every request to the TSYS Acquiring Solutions host after authentication (by setting this field), and will be checked against the terminal hierarchy. A GenKey value is required when processing transactions using Voltage Encryption or Tokenization. | |||||||||||||||||||||||||||||||||||||||||||||||
TsysETB: The Encryption Transmission Block TSYS uses to decrypt encrypted data.This field is used to specify the Base-64 encoded ETB (Encryption Transmission Block) used by TSYS to decrypt Voltage encrypted data. The value is retrieved from the POS device containing the Voltage encryption software. When specified, the transaction will be sent as a Voltage encrypted transaction. The encrypted card data will be specified as normal via the MagneticStripe or Number fields. | |||||||||||||||||||||||||||||||||||||||||||||||
UseConfirmationRequest: Indicates whether or not to send a Confirmation Request authorization transaction.When set to "True", a confirmation authorization transaction will be sent. In a confirmation request, TSYS will generate
the Retrieval Reference Number (RetrievalNumber) and the System Trace Audit Number (Trace).
When setting this property to "False" (default value), a NonConfirm authorization transaction will be sent. In these
transactions, a Retrieval Reference Number, System Trace Audit Number, Local Date, and Local Time are NOT generated by TSYS
and must be manually specified by the POS application. By default, the component will automatically generate these values for you.
However you can override them by setting the following properties: LocalRetrievalNumber, LocalDate,
, and LocalTime. Note the System Trace Audit Number is required to be the last 6 characters of the
LocalRetrievalNumber and thus the component will automatically obtain and send this value for you.
Note: This setting is only valid for Debit and EBT/Benefit transactions. | |||||||||||||||||||||||||||||||||||||||||||||||
LocalRetrievalNumber: Specifies the Retrieval Reference Number to use in a NonConfirm authorization request.This property is used to specify the Retrieval Reference Number to use in a NonConfirm authorization request (when
UseConfirmationRequest = "False"). The specified value must contain a 12-character numeric value. It is
suggested that the first 4 characters be the Julian date (yddd) and the remaining 8 characters are a numeric transaction
identification number. If this value is set to "" (empty string), the component will generate a Retrieval Reference Number
for you when the authorization request is sent.
Note: This setting is only valid for Debit and EBT/Benefit transactions. | |||||||||||||||||||||||||||||||||||||||||||||||
LocalDate: Specifies the local transaction date to use in a NonConfirm authorization request.This property is used to specify the local transaction date to use in a NonConfirm authorization request (when
UseConfirmationRequest = "False"). The specified value must be in MMDDYY format. If "" (empty string)
is specified, the component will generate the local transaction date for you based on the current system time.
Note: This setting is only valid for Debit and EBT/Benefit transactions. | |||||||||||||||||||||||||||||||||||||||||||||||
LocalTime: Specifies the local transaction time to use in a NonConfirm authorization request.This property is used to specify the local transaction time to use in a NonConfirm authorization request (when
UseConfirmationRequest = "False"). The specified value must be in HHMMSS format. If "" (empty string)
is specified, the component will generate the local transaction time for you based on the current system time.
Note: This setting is only valid for Debit and EBT/Benefit transactions. | |||||||||||||||||||||||||||||||||||||||||||||||
Processor: Specifies the Processor you are connecting to.This field allows you to specify the processor that you are connecting to (thus allowing the component to
correctly generate the request and parse the response). The available values are:
Note that when set, this property will set the Server and Port to the default values for the specified processor. Additionally, this config must be set prior to setting Card to ensure the card data is formatted correctly. | |||||||||||||||||||||||||||||||||||||||||||||||
HeartlandEncryptionMode: Specifies the encryption mode to use in Heartland transactions.This field allows you to specify the Heartland E3 encryption mode used when processing Heartland transactions.
The available values are (descriptions describe the data that will be encrypted):
Note you will also need to set Processor to 1 (Heartland) and HeartlandKeyBlock if you wish to process Heartland E3 transactions. | |||||||||||||||||||||||||||||||||||||||||||||||
HeartlandDeviceId: Specifies a device ID to uniquely identify each terminal (card data entry device).The specified value must be 4 characters or less. Note that this value is required to comply with MasterCard's Authorization Data Accuracy Initiative. | |||||||||||||||||||||||||||||||||||||||||||||||
HeartlandKeyBlock: Specifies the key block used to encrypt the data.This field allows you to specify the key block that was used to encrypt the data specified by HeartlandEncryptionMode. This value will be obtained from an E3 magnetic stripe reader and is used by Heartland to decrypt the encrypted data. | |||||||||||||||||||||||||||||||||||||||||||||||
Timeout: A timeout for the component.If Timeout is set to a positive value, and an operation cannot be completed immediately, the component will retry the operation for a maximum of Timeout seconds.
The default value for Timeout is 30 (seconds). |
Base Configuration Settings
GUIAvailable: Tells the component whether or not a message loop is available for processing events.
In a GUI-based application, long-running blocking operations may cause the application to stop responding to input until the operation returns. The component will attempt to discover whether or not the application has a message loop and, if one is discovered, it will process events in that message loop during any such blocking operation.
In some non-GUI applications an invalid message loop may be discovered that will result in errant behavior. In these cases, setting GuiAvailable to false will ensure that the component does not attempt to process external events. | |
UseBackgroundThread: Whether threads created by the component are background threads.If set to True, when the component creates a thread the thread's IsBackground property will be explicitly set to True. By default this setting is False. | |
UseManagedSecurityAPI: Tells the component whether or not to use the system security libraries or a managed implementation.
By default the component will use the system security libraries to perform cryptographic functions. This means
calls to unmanaged code will be made. In certain environments this is not desirable. To use a completely managed security
implementation set this setting to True. Setting this to True tells the component to use the internal managed implementation
instead of using the system's security API.
Note that when this value is set the product's system dll is no longer required as a reference, as all unmanaged code is stored in this file. |