Processes a payment in the store for a given user's cart. This implementation
processes a request through PayPal Payflow Pro. The process(Map)
method manages the process of sending a request to Payflow Pro, and handling
the response appropriately. It follows these steps:
Figures out the transaction type (sale, authorize,
authorize/authenticate, or authorize/authenticate/sale) from the database
settings and the user's current state.
Builds the request to Payflow Pro as a Map, taking as
input the current user's state, and various database settings.
Converts the request into a url-encoded query string to pass as Payflow
Pro's "parmlist" parameter.
Initializes the connection to Payflow Pro and sends the request.
Handles any errors by setting "resultCode" appropriately in the
Map that is returned. If no response comes back from Payflow
Pro, a result code 10000 is used. If the Payflow Pro result code is not 0,
which also indicates an error, that code is used as this method's
"resultCode" and this method returns it.
If a successful response is received, checks if the transaction type for
the user is AA or AAS (authorize/authenticate, or
authorize/authenticate/sale), in which the response must be "authenticated".
This means the AVS and CSC responses are checked against what's defined as
acceptable in the Payflow Pro Advanced Settings in the administrator. Note
that if no CSC response is present, it is set to "X".
If the user is not deemed authenticated, a "resultCode" of 10001 is
If the user is authenticated and the transaction type in effect is AAS
(authorize/authenticate/sale), an immediate delayed capture on the previous
authorization is performed, using the same parameters. Any errors from this
second request are handled in the same way as above.
Assuming the transaction succeeds, a new record is written to the
sscPayment database table and a resultCode of 0 is returned.
parameters - A Map containing the values of the user's
submitted payment information.
A Map containing a least one key named
"resultCode", which contains a String parsable into an int,
representing the results of the processing. 0 for the resultCode
indicates success. Optionally, the Map may include
additional keys, such as "resultMessage", a string describing the
results of the processing.
public java.lang.String getTransAuthLevel()
public boolean levelMatchFound(java.lang.String cust,