Payment Engine API Documentation
Payment Engine is a point of sale middleware solution that allows developers to work with a variety of payment terminals without the hassle of integrating and certifying each solution. The middleware is available as a cloud based solution.
- Cloud Middleware
- Connection Manager Pro
- Terminals
CLOUD REST API
The Payment Engine is a cloud based EMV middleware that point of sale developers can use to simplify their integration with various EMV capable payment terminals such as the Castles MP200.
API Overview
Endpoint URL
The base url for the production API is:
https://usaepay.com/api/v2/
The hostname "usaepay.com" can be swapped out for any of the other gateway hostnames (see the High Availability Guide. During development, "sandbox.usaepay.com" should be used. For more information on the development sandbox see the Sandbox Guide.
The "v2" refers the API version and can replaced with an endpoint key. The API limits the number of API calls allowed per minute and per day based on this key. Using "v2" is fine for development and smaller merchants, but could result in API rate limit errors for high traffic merchants. Larger merchants and developers should register their own software endpoint key in the Dev Portal. For more details, see the API Rate Limits section below.
There are other features available with developer registered endpoints including, restricting use of the end point by IP address and listing contact information for support. The endpoint keys are independent of the merchant API keys. An endpoint can be used with any merchant account.
API Endpoints Index
- Device Management
- POST paymentenge/devices
- GET paymentengine/devices/:devicekey:
- GET paymentengine/devices
- PUT paymentengine/devices/:devicekey:
- DELETE paymentengine/devices/:devicekey:
- PUT paymentengine/devices/:devicekey:/settings
- GET paymentengine/devices/:devicekey:/settings
- PUT paymentengine/devices/:devicekey:/terminal-config
- GET paymentengine/devices/:devicekey:/terminal-config
- POST paymentengine/devices/:devicekey:/kick
- Payment Requests
API Rate Limits
To prevent abuse, the API implements per minute and daily rate limits. The limits are counted per endpoint key and IP address. When using the default endpoint url, the limits are 45/minute and 5000/day. When the limit is exceeded, the API will return HTTP error code 429:
HTTP/1.1 429 API Rate Limit Exceed
The body of the response will be:
{"error":"API Rate Limit Exceed","errorcode":155}
Developers can utilize the "X-Rate-Limit" HTTP header to manage their API rate limit usage:
X-Rate-Limit: "8 of 45/min; 8 of 5000/day"
Higher limits are immediately available by self registering an endpoint in the Dev Portal. Further increases to the limits are granted on a case by case basis. Contact the integration support team for further information. To test the API Rate Limit feature, use the API endpoint "https://sandbox.usaepay.com/api/RATELIMT/". Your second request will be rate limited.
IP Access Restrictions
By default, API endpoints are available to clients on any IP address. Developers can edit their API endpoint to restrict calls from a set list of IP addresses. To test the IP access restriction, you can use the url "https://sandbox.usaepay.com/api/IPACCESS/". When access is blocked HTTP error code 401 will be returned:
HTTP/1.1 401 Access Denied
The body of the response will be:
{"error":"Access Denied","errorcode":156}
Authentication
Hash Example
var seed = random_value();
var prehash = apikey + seed + apipin;
var apihash = 's2/'+ seed + '/' + sha256(prehash);
Authorization Example
Authorization: Basic
OnMyL2YxYmFmMjE1OGQwNDQwYmI4N2U4OTRjOWU5MmQ4Mzk2L2ZhODgxNWNkYWMxZjY4M2VkNWQyY2Y5NmRhNmMzN2JlODRmNzNhNDA0ODYwNDU3YzNkZDdiNmM0NTc5NjA0YWY=
All API calls require an APIkey (sourcekey) and API hash. The API hash is built by hashing a random seed, the API key, and the private API pin.
The API key and API hash must be sent in a basic auth http header (base64 encode "apikey:apihash"):
Common Formats
Lists
Example
<?php
{
"type": "list",
"limit": 100,
"offset": 0,
"data": [
{...},
{...},
],
"total": 200
}
?>
All API endpoints that return multi objects use a standard list format:
Offset
To change the number of objects returned in the result set, pass a "limit" variable in the request url (example: /api/customers?limit=1000). To retrieve the next group of objects, pass in "offset" with the item # to start with. "0" is the first item. For example, if there are 21 customers you could pull them in three calls:
/api/customers?limit=10&offset=0
... 10 customers returned ...
/api/customers?limit=10&offset=10
... 10 customers returned ...
/api/customers?limit=10&offset=20
... 1 customer returned ...
Objects
Example
<?php
{
"key": "a8ai3k7i77tw",
"type": "customer",
"firstname": "John",
"lastname": "Doe",
...
}
?>
Single objects will all include a "key" (the primary public key for the object) and a "type" (the object type). For example:
Common Errors
Errorcode | Message | Troubleshooting |
---|---|---|
0 | Valid authentication required | Authorization header was missing. |
21002 | API authentication failed | Authentication was not successful. Possible reasons could include: using the wrong PIN, using a sourcekey from sandbox in production mode, or that the authentication header was malformed. |
Firewall Rules
The Payment Engine Gateway facilitates all communication between the point of sale software and the payment terminal. No direct communication happens between the point of sale and the terminal, and the terminal can be on a different network segment than the point of sale.
Payment Engine SDK
The point of sale software will need to be able to communicate with the payment gateway on port 443. This is an outbound connection and the ip address will depend on which URL is being used. Using the default url:
Host | Direction | IP | Port |
---|---|---|---|
www.usaepay.com | Outbound | 209.239.233.7 | 443 |
www.usaepay.com | Outbound | 64.0.146.7 | 443 |
www.usaepay.com | Outbound | 209.220.191.7 | 443 |
www.usaepay.com | Outbound | 65.132.197.7 | 443 |
If using the sandbox test environment:
Host | Direction | IP | Port |
---|---|---|---|
sandbox.usaepay.com | Outbound | 64.0.146.129 | 443 |
For a full list of all urls and associated IPs, see the high availability guide.
Stand Alone Payment Terminals
Stand alone payment terminals, such as the Castles MP200, establish a persistent outbound connection to the payment gateway. No incoming firewall rules are required.
Host | Direction | IP | Port |
---|---|---|---|
pos.usaepay.com | Outbound | 209.239.233.90 | 443 and 9011 |
pos.usaepay.com | Outbound | 64.0.146.90 | 443 and 9011 |
pos.usaepay.com | Outbound | 209.220.191.90 | 443 and 9011 |
pos.usaepay.com | Outbound | 65.132.197.90 | 443 and 9011 |
If using the sandbox test environment:
Host | Direction | IP | Port |
---|---|---|---|
pos.sb.usaepay.com | Outbound | 64.0.146.60 | 443 and 9011 |
Basic network services required:
- DNS Port 53
- NTP Port 123
Note: Currently, the payment engine software for stand alone terminals does not support static IP address assignment. DHCP is required.
Direct Payment Terminals
Direct payment terminals, such as the Ingenico Tetra devices, establish a persistent outbound connection to the payment gateway. No incoming firewall rules are required.
Host | Direction | IP | Port |
---|---|---|---|
direct.paymentengine.io | Outbound | 64.0.146.194 | 9021 |
direct.paymentengine.io | Outbound | 209.220.191.194 | 9021 |
direct.paymentengine.io | Outbound | 209.239.233.194 | 9021 |
If using the sandbox test environment:
Host | Direction | IP | Port |
---|---|---|---|
direct-sb.paymentengine.io | Outbound | 64.0.146.195 | 9021 |
direct-sb.paymentengine.io | Outbound | 209.220.191.195 | 9021 |
direct-sb.paymentengine.io | Outbound | 209.239.233.195 | 9021 |
Basic network services required:
- DNS Port 53
Connection Manager
For some Ingenico terminals, either Connection Manager or the Connection Manager Virtual Appliance is required to facilitate the connection to the terminal. Connection Manager is not required for standalone terminals such as the Castles MP200. The connection manager software or appliance will need to be able to make the following outbound connections:
Host | Direction | IP | Port |
---|---|---|---|
pos.usaepay.com | Outbound | 209.239.233.90 | 443 and 9011 |
pos.usaepay.com | Outbound | 64.0.146.90 | 443 and 9011 |
pos.usaepay.com | Outbound | 209.220.191.90 | 443 and 9011 |
pos.usaepay.com | Outbound | 65.132.197.90 | 443 and 9011 |
If using the sandbox test environment:
Host | Direction | IP | Port |
---|---|---|---|
pos.sb.usaepay.com | Outbound | 64.0.146.60 | 443 and 9011 |
Additionally, the appliance will need the following for software updates:
Host | Direction | IP | Port |
---|---|---|---|
downloads.paymentengine.io | Outbound | 209.239.233.186 | 443 |
The appliance also requires these basic network services:
- DNS Port 53
- NTP Port 123
Ingenico iSC
By default the Ingenico terminals listen on port 12000. Configure firewall rules to allow the connection manager to connect to the terminal on this port.
Cloud Demo Application
The quickest way to see how the Payment Engine rest API works is to try the demo app. It provides a simple web UI for registering a device and processing a payment. At the same time it keeps a log of the underlying rest calls that were made. These calls can be used for comparison when writing your own app.
Running the Demo App
Step 1: Payment Application Demo
To open the Payment Application Demo go to https://demo.paymentengine.io. You should get the screen below.
Step 2: Device/Terminal Simulator
When you are using the demo application, you can test using a terminal simulator OR you can use a real hardware device.
- To use the Castles MP200 terminal simulator, open a new tab and go to https://pos.usaepay.com/mp200 (pictured below). Please Note: If you are working in the sandbox environment you will need to use https://pos.sb.usaepay.com/mp200 instead.
- To use the demo app with a real hardware device, just boot your terminal and get it to the "Input Pairing Code" screen.
Step 3: Get Pairing Code
In the demo app tab, paste an API Key (source key) and PIN into the appropriate fields and click "Register". If you do not already have an API key, log into the merchant console and go the API Keys section of the Settings tab. If you will be using the simulator for testing, you will need a merchant account setup on the "testbed" platform. Please contact the integration support department for assistance. If you have entered a valid source key and PIN, you should see a window that looks like this:
Step 4: Enter Pairing Code on Terminal
Enter the pairing code that is displayed in demo app into the simulator (or real terminal) and then press the "Enter" button (or green button on the MP200):
If the code is entered correctly, you should get a welcome screen:
Step 5: Start Payment Request
In the demo app, enter a desired amount and click "Start Transaction":
A pop-up that tracks the progress of the payment on the terminal should appear:
Step 6: Present Payment on Terminal
If using a real device, follow the prompts on the terminal screen. If using the simulator click on one of the "Swipe Card", "Tap Card" or "Dip Card" buttons. A card selection menu will come up that allows you to select a particular card brand and response type, ie "Swipe Visa: Approved". Once you have selected your card, click on the bottom left button.
Step 7: View Transaction Result in the Demo App
Once the payment is complete, you should see the transaction result in the demo app:
Endpoints
API Index
- Device Management
- POST paymentenge/devices
- GET paymentengine/devices/:devicekey:
- GET paymentengine/devices
- PUT paymentengine/devices/:devicekey:
- DELETE paymentengine/devices/:devicekey:
- PUT paymentengine/devices/:devicekey:/settings
- GET paymentengine/devices/:devicekey:/settings
- PUT paymentengine/devices/:devicekey:/terminal-config
- GET paymentengine/devices/:devicekey:/terminal-config
- POST paymentengine/devices/:devicekey:/kick
- PUT /paymentengine/devices/:devicekey:/branding
- Payment Requests
Devices
POST devices
Endpoint
POST /api/v2/paymentengine/devices
Registers a payment terminal device. The device registration process associates a terminal with a merchant. Depending on the terminal_type, the process may require two steps.
For terminals running the payment engine standalone middleware such as the Castles MP200 a device pairing code is used. When a new terminal is first turned on, it will display a screen prompting for a pairing code. The point of sale software should use API resource to obtain a code. The pairing code is then entered into the terminal. If successful, the terminal should display a welcome idle screen and the API will show a status of "online" in GET /api/v2/paymentengine/devices/:devicekey:.
For security reasons, pairing codes are only valid for a few minutes. If the time limit has expired without the pairing code being entered on the terminal, the pairing code and associated device key are automatically removed.
Once a terminal is successfully paired, it will remain registered until deleted: there is no need to re-register a terminal when it reboots.
Request
Basic Request Example
curl --basic --user APIKEY:PINHASH \
-H "Content-Type: application/json" -X POST \
https://usaepay.com/api/v2/paymentengine/devices \
-d '{"name":"Register 1","terminal_type":"standalone"}'
Request with Settings and Terminal Config Example
curl --basic --user APIKEY:PINHASH \
-H "Content-Type: application/json" -X POST \
-d '{"name":"Register 1","terminal_type":"standalone","settings":{"timeout":30,"share_device":false,"enable_standalone":false,"sleep_battery_device":5,"sleep_battery_display":1,"sleep_powered_device":0,"sleep_powered_display":0},"terminal_config":{"enable_emv":true,"enable_debit_msr":true,"enable_tip_adjust":true,"enable_contactless":true}}' \
https://usaepay.com/api/v2/paymentengine/devices
POST/paymentengine/devices
Variable | Description | Required |
---|---|---|
terminal_type | Type of terminal being registered, currently the only option is 'standalone'. | X |
name | A name associated with the terminal. Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out. | |
%settings% | Device settings | |
%terminal_config% | Terminal configuration |
Response
Example Response
POST/paymentengine/devices
- The response is the standard GET device response.
Errors
Errorcode | Message | Troubleshooting |
---|---|---|
21113 | Required parameter terminal_type was not provided | Make sure to include the terminal_type parameter in your post body. |
21114 | Unsupported terminal type xxxxxxx | Make sure the terminal type is in the list of supported terminals (see above). |
GET devices/:devicekey:
Endpoint
GET /api/v2/paymentengine/devices/:devicekey:
Retrieve information about a device by its device key.
Request
Request Example
@GET/paymentengine/devices/:devicekey:@
curl --basic --user APIKEY:PINHASH \
https://usaepay.com/api/v2/paymentengine/devices/sa_CCpRfLbkYXNV9rVLdRGvPjwf6ytgN
Parameter Name | Type | Description |
---|---|---|
key | string | Unique device identifier |
Response
Response Example - Device Pending Registration
<?php
{
"type": "device",
"key": "sa_WKwzyQawBG0RMy0XpDGFXb6pXA23r",
"apikeyid": "ntC8nP31Moh0wtvYT",
"terminal_type": "standalone",
"status": "waiting for device pairing",
"name": "Register 1",
"pairing_code": 690520,
"expiration": "2019-10-29 11:59:28",
"settings": {
"timeout": 30,
"share_device": false,
"enable_standalone": false,
"sleep_battery_device": 5,
"sleep_battery_display": 1,
"sleep_powered_device": 0,
"sleep_powered_display": 0
},
"terminal_info": {
"make": "Castles",
"model": "VEGA3000",
"revision": "18043001-0055.00",
"serial": "011118170300198",
"key_pin": "FFFF5B04",
"key_pan": "FF908A"
},
"terminal_config": {
"enable_emv": true,
"enable_debit_msr": true,
"enable_tip_adjust": true,
"enable_contactless": true
}
}
?>
Response Example - Registered Device Example
@GET/paymentengine/devices/:devicekey:@
Parameter Name | Type | Description |
---|---|---|
type | string | Object type. This will always be device. |
key | string | Unique device identifier |
apikeyid | string | The id of API key (source key) associated with the device. |
terminal_type | string | Terminal type: "standalone" for payment engine cloud based terminal. |
status | string | Current device status |
name | Developer assigned device name. Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out. | |
%settings% | object | Device settings |
%terminal_info% | object | Details of terminal |
%terminal_config% | object | Terminal configuration |
pairing_code | If terminal type is 'standalone', this is the pairing code required to pair the payment device with the payment engine. | |
expiration | If terminal type is 'standalone', the expiration is the date/time that the pairing code is no longer valid. |
Errors
Errorcode | Message | Troubleshooting |
---|---|---|
21121 | Unknown devicekey xxxxxxx | Double check that the device key is valid. If the device status was still "waiting for device pairing," the request may have expired. |
GET devices
Endpoint
GET /api/v2/paymentengine/devices
Retrieves a list of devices registered to merchant.
Request
Request Example
curl --basic --user APIKEY:PINHASH \
https://usaepay.com/api/v2/paymentengine/devices
@GET/paymentengine/devices@
Request Parameters
Variable | Description | Default |
---|---|---|
limit | Max number of results to return | 20 |
offset | Number offset to start response | 0 |
Response
Response Example - No Devices Found
<?php
{
"type": "list",
"limit": 20,
"offset": 0,
"data": [],
"total": 0
}
?>
Response Example - Single Device
@GET/paymentengine/devices@
Response Parameters
- The response is in the standard list format.
Parameter Name | Type | Description |
---|---|---|
type | string | The type of object returned. Returns a list. |
limit | integer | The max number of items returned in each result set (see limit request param). |
offset | integer | The number of product categories skipped from the results. |
%data% | array | An array of product categories matching the request. |
PUT devices/key
PUT /api/v2/paymentengine/devices/:devicekey:
Updates an existing device. Parameters are only updated if they are present in the body.
Request
Basic Request Example
curl --basic --user APIKEY:PINHASH \
-X PUT \
-H "Content-Type: application/json" \
-d '{"name":"Testing","settings":{"share_device":true}}' \
https://usaepay.com/api/v2/paymentengine/devices/sa_1BTTI5Yys0G3gVQa6beYxM4K0hhjC
@PUT/paymentengine/devices/:devicekey:@
Request Parameters
Variable | Description |
---|---|
name | A name associated with the terminal. Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out. |
settings | Device settings |
terminal_config | Terminal configuration |
Device Settings
Variable | Description |
---|---|
timeout | Transaction timeout, how long to wait for transaction authorization to complete. |
notify_update | If true, device will be notified on all future updates |
notify_update_next | If true, device will be notified only on the next update. After notification, this is automatically set back to false. |
enable_standalone | Allows transactions to be initiated from terminal (if supported). |
share_device | If true, this allows the payment device to be used by other merchants. If false, only the merchant associated with the apikeyid may send transactions to device. |
sleep_battery_device | This is the amount of inactive time (in minutes) before the device enters full sleep if it is running on battery. If in full sleep, you will need to turn the device on again before processing. Wifi and Bluetooth pairing should persist, even after full sleep. Set to '0' to never sleep. |
sleep_battery_display | This is the amount of inactive time (in minutes) before the device enters display sleep if it is running on battery. If in display sleep, just send a transaction to the device or tap any button to wake the device. Set to '0' to never sleep. |
sleep_powered_device | This is the amount of inactive time (in minutes) before the device enters full sleep if it is plugged into power. If in full sleep, you will need to turn the device on again before processing. Wifi and Bluetooth pairing should persist, even after full sleep. Set to '0' to never sleep. |
sleep_powered_display | This is the amount of inactive time (in minutes) before the device enters display sleep if it is plugged into power. If in display sleep, just send a transaction to the device or tap any button to wake the device. Set to '0' to never sleep. |
Terminal configuration
Variable | Description |
---|---|
enable_emv | Enables EMV processing. |
enable_debit_msr | Enables PIN debit for swiped transactions. |
enable_tip_adjust | Allows EMV transaction amounts to be adjusted after authorization (to add tip). Disables PIN authentication. |
enable_contactless | Enables NFC reader. |
Response
- The response is the standard GET device response.
Response Example
@PUT/paymentengine/devices/:devicekey:@
DELETE devices/key
DELETE /api/v2/paymentengine/devices/:devicekey:
Removes terminal registration and un-registers the device referenced by devicekey. This will delete the device key and place the terminal back on the pairing code prompt screen.
Request
Request Example
@DELETE/paymentengine/devices/:devicekey:@
Response
Response Example
@DELETE/paymentengine/devices/:devicekey:@
PUT devices/key/settings
PUT /api/v2/paymentengine/devices/:devicekey:/settings
Updates the device settings. These settings change the behavior of the device. If a setting is not included in the request, it will not be updated.
Request
Request Example
curl --basic --user APIKEY:PINHASH \
-X POST \
-H "Content-Type: application/json" \
-d '{"share_device":true}' \
https://usaepay.com/api/v2/paymentengine/devices/sa_p7wyCLbGgGtPyDE12U9zHJy3pg6WO/settings
@PUT/paymentengine/devices/:devicekey:/settings@
Request Parameters
Variable | Description |
---|---|
timeout | Transaction timeout, how long to wait for transaction authorization to complete. |
enable_standalone | Allows transactions to be initiated from terminal (if supported). |
share_device | If set to true, this allows a device to be used by other merchants. If false, only the merchant associated with the apikeyid may send transactions to device. |
Response
Response Example
@PUT/paymentengine/devices/:devicekey:/settings@
The response is the standard GET device response.
GET devices/key/settings
Endpoint
GET /api/v2/paymentengine/devices/:devicekey:/settings
Retrieves the current device settings.
Request
Request Example
curl --basic --user APIKEY:PINHASH \
https://usaepay.com/api/v2/paymentengine/devices/sa_CCpRfLbkYXNV9rVLdRGvPjwf6ytgN/settings
@GET/paymentengine/devices/:devicekey:/settings@
Response
Response Example
@GET/paymentengine/devices/:devicekey:/settings@
Variable | Description |
---|---|
timeout | Transaction timeout, how long to wait for transaction authorization to complete. |
enable_standalone | Allows transactions to be initiated from terminal (if supported). |
share_device | If set to true, this allows a device to be used by other merchants. If false, only the merchant associated with the apikeyid may send transactions to device. |
PUT devices/key/terminal-config
PUT /api/v2/paymentengine/devices/:devicekey:/terminal-config
Updates the devices terminal config. This terminal config controls the devices transaction processing features including supported payment types. If a setting is not included in the request, it will not be updated.
Request
Request Example
curl --user APIKEY:PINHASH \
-X PUT \
-H "Content-Type: application/json" \
-d '{"enable_emv":false}' \
https://usaepay.com/api/v2/paymentengine/devices/sa_p7wyCLbGgGtPyDE12U9zHJy3pg6WO/terminal-config
@PUT/paymentengine/devices/:devicekey:/terminal-config@
Request Parameters
Variable | Description |
---|---|
enable_emv | Enables EMV processing. |
enable_debit_msr | Enables PIN debit for swiped transactions. |
enable_tip_adjust | Allows EMV transaction amounts to be adjusted after authorization (to add tip). Disables PIN authentication. |
enable_contactless | Enable NFC reader. |
Response
Response Example
@PUT/paymentengine/devices/:devicekey:/terminal-config@
The response is the standard GET device response.
GET devices/key/terminal-config
GET /api/v2/paymentengine/devices/:devicekey:/terminal-config
Retrieves the current terminal configuration.
Request
Request Example
curl --basic --user APIKEY:PINHASH \
https://usaepay.com/api/v2/paymentengine/devices/sa_CCpRfLbkYXNV9rVLdRGvPjwf6ytgN/terminal-config
@GET/paymentengine/devices/:devicekey:/terminal-config@
Response
Example Response
@GET/paymentengine/devices/:devicekey:/terminal-config@
Variable | Description |
---|---|
enable_emv | Enables EMV processing. |
enable_debit_msr | Enables PIN debit for swiped transactions. |
enable_tip_adjust | Allows EMV transactions amounts to be adjusted after authorization (to add tip). Disables PIN authentication. |
enable_contactless | Enables NFC reader. |
POST devices/key/kick
Endpoint
POST /api/v2/paymentengine/devices/:devicekey:/kick
Kicks the terminal offline. The terminal should automatically reconnect after a few seconds. This can help jump start a stuck terminal.
Request
Request Example
curl --user APIKEY:PINHASH \
-X POST \
https://usaepay.com/api/v2/paymentengine/devices/sa_p7wyCLbGgGtPyDE12U9zHJy3pg6WO/kick
@POST/paymentengine/devices/:devicekey:/kick@
Request Parameters
- -None-
Response
Response Example
@POST/paymentengine/devices/:devicekey:/kick@
The response is the standard GET device response.
PUT devices/key/branding
PUT /paymentengine/devices/:devicekey:/branding
Updates the branding to the Ingenico device.
Request
Request Example
{
"brand": "Package-Name"
}
Request Parameters
Variable | Description |
---|---|
brand | Name of the package you would like to load for branding the Ingenico device. |
Response
Response Example
true
Payment Requests
POST payrequests
POST /api/v2/paymentengine/payrequests
Starts a new payment request (transaction). This will cause the terminal to walk the customer through the payment processing screens:
- Swipe/dip/tap card.
- Choose credit/debit (if supported).
- Enter PIN (if necessary).
- Prompt for tip (if enabled).
- Approve amount.
- Capture signature (if enabled/supported).
A payment requestkey will be returned which can be used to track the customers progress on the terminal via GET /api/v2/paymentengine/payrequests/:requestkey:. When the process is complete, transaction details will be available.
Request
Minimal Payment Request Example
curl --basic --user APIKEY:PINHASH \
-X POST \
-H "Content-Type: application/json" \
-d '{"devicekey":"sa_1BTTI5Yys0G3gVQa6beYxM4K0hhjC","command":"cc:sale","amount":"8.88"}' \
https://usaepay.com/api/v2/paymentengine/payrequests
Line Items Example
{
"lineitems": [
{
"sku": "The SKU",
"name": "Prod Name",
"description": "Prod Desc",
"cost": "8.88",
"qty": 1
},
{
"sku": "The SKU 2",
"name": "Prod Name 2",
"description": "Prod Desc 2",
"cost": "1.98",
"qty": 2
}
]
}
Example AddOn Request
{
"amount": "52.10",
"custom_options": [
{
"display": "Donate to Charity?",
"denominations": [
{
"amount": "1.00",
"display": "$1.00"
},
{
"amount": "5.00",
"display": "$5.00"
},
{
"amount": "10.00",
"display": "$10.00"
},
{
"display": "Other",
"amount_other": true
}
],
"type": "AddOn",
"sku": "DONATION-12345"
}
],
"custom_flow": "options,amount,payment,result"
}
Example AddOn Response
{
"type": "request",
"status": "transaction complete",
"transaction": {
"type": "transaction",
"auth_amount": "57.10",
"lineitems": [
{
"sku": "subtotal",
"cost": "52.10",
"qty": 1
},
{
"sku": "DONATION-12345",
"cost": "5.00",
"qty": 1
}
],
"complete": true
}
}
Example Tip Request
{
"amount": "15",
"custom_options": [
{
"display": "Add a Tip?",
"denominations": [
{
"amount": "2.25",
"display": "$2.25"
},
{
"amount": "2.70",
"display": "$2.70"
},
{
"amount": "3.00",
"display": "$3.00"
},
{
"display": "Other",
"amount_other": true
}
],
"type": "Tip"
}
],
"custom_flow": "options,amount,payment,result"
}
Example Tip Response
{
"type": "request",
"status": "transaction complete",
"transaction": {
"type": "transaction",
"auth_amount": "17.25",
"amount_detail": {
"tip": "2.25",
"subtotal": "15.00"
},
"complete": true
}
}
@POST/paymentengine/payrequests@
Request Parameters
Parameter Name | Type | Description |
---|---|---|
devicekey | string | Device key. If device key is not specified, the device associated with current source key is used. |
command | string | This must be set to sale for a credit or debit card sale (Required) |
amount | double | Total transaction amount (Including tax, tip, shipping, etc.) (Required) |
Optional Paramters
Parameter Name | Type | Description |
---|---|---|
devicekey | string | Device key. If device key is not specified, the device associated with current source key is used. |
command | string | This must be set to sale for a credit or debit card sale (Required) |
amount | double | Total transaction amount (Including tax, tip, shipping, etc.) (Required) |
timeout | Time in seconds to wait for payment. Default is 180 seconds. See timeout handling below. | |
block_offline | By default, the payment engine will wait for an offline payment terminal to connect and then start the transaction, up to the timeout time limit. If "block_offline" is set to true, the payment request will return an error right away. | |
ignore_duplicate | Bypass duplicate detection/folding if it has been configured on the api key | |
save_card | Save card and return token | |
manual_key | If true, an option will be displayed to manually key the transaction. | |
prompt_tip | Customer will be prompted to leave a tip. |
Additional Transaction Parameters
In addition to the basic request parameters above, any of the transaction API parameters can also be passed through.
Parameter Name | Type | Description |
---|---|---|
%amount_detail% | object | Object containing a more detailed breakdown of the amount. Not required if amount is previously set. |
invoice | string | Custom Invoice Number to easily retrieve sale details. |
ponum | string | Customer's purchase order number. Required for level 3 processing. |
orderid | string | Merchant assigned order identifier. |
description | string | Public description of the transaction. |
comments | string | Private comment details only visible to the merchant. |
terminal | string | Terminal identifier (i.e. multilane) |
clerk | string | Clerk/Cashier/Server name |
%billing_address% | object | Object which holds the customer's billing address information. |
%shipping_address% | object | Object which holds the customer's shipping address information. |
string | Customer's email address | |
geolocation | Latitude and longitude of transaction location. | |
software | Software name and version (useful for troubleshooting). | |
%custom_fields% | array | Optional fields for storing custom data. |
%lineitems% | array | Array of line items attached to the transaction. Possible fields for each line item listed below. |
%custom_flow% | comma delimited string | Allows you to customize the order in which each payment screen is displayed on the device. Below are the parameters that can be included in the comma delimited string of the custom_flow parameter. Each of these parameters represents a screen which appears on the payment device. The payment and result screens are required. All others are optional. |
%custom_options% | array | A parameter for custom_flow: options. options must be listed FIRST in the "custom_flow" comma delimited string. See below for detail. |
Custom Flow
If you are using an Ingenico device, you also have to option to customize the flow of a transaction. The current default flow for transactions is: amount, payment, result.
Within the nested table are the parameters that can be included in the comma delimited string of the custom_flow parameter. Each of these parameters represents a screen which appears on the payment device. The payment and result screens are required. All others are optional.
Parameter | Description |
---|---|
options | Custom screen for add ons and tips. Must be FIRST in list. |
payment | Payment taking screen (must come before result). |
amount | Optional confirmation of amount (must come before result). |
result | Displays the transaction result. |
signature | Signature capture (must come after result). |
signature_required | Signature capture. If the signature is cancelled, then the transaction will be cancelled (must come after result). |
Custom Options
A parameter for custom_flow: options. options must be listed FIRST in the custom_flow comma delimited string. Custom options can be AddOn or Tip:
If AddOn option is selected it will be added to transaction as a lineitem and original amount will be a subtotal line item.
If Tip is selected amount will be added in amount_detail with the original amount as the subtotal.
Timeout Handling
Once a payment request is initiated, the payment engine does not require any further input from the point of sale software to complete the payment process. This can lead to confusion and potentially duplicate transactions if the point of sale software does not correctly poll the payment request. Consider the follow sequence of events:
- User starts the transaction on the point of sale software.
- The point of sale software starts polling the status of the request, but is configured to give up after 1 minute.
- User takes longer than 1 minute to swipe card.
- Payment engine successfully processes transaction, approval is shown on terminal.
- User returns to point of sale and sees an error indicating that the request timed out.
- User repeats the process and this time swipes the card in under a minute.
- Duplicate transaction is run and two charges are now in the batch, despite the point of sale only acknowledging one.
By default the payment engine will wait for 3 minutes (180 seconds) for the user to swipe, dip or tap their card. This can be configured by passing the "timeout" parameter. To prevent the above, the point of sale software should continue to poll the payment request for the full amount of time set in the timeout. When timeout is exceeded, the payment request status will change to "timeout".
Request Tokenization
In addition to processing the payment, a token will be generated that can be used for future payments.
Request Tokenization Example (cURL)
curl --basic --user APIKEY:PINHASH \
-H "Content-Type: application/json" \
-d '{"devicekey":"sa_1BTTI5Yys0G3gVQa6beYxM4K0hhjC","command":"cc:sale","amount":"8.88","save_card":true}' \
https://usaepay.com/api/v2/paymentengine/payrequests
Response
Response Example
@POST/paymentengine/payrequests@
Response Parameters
Parameter | Description |
---|---|
key | Request key |
expiration | The expiration is the date/time the request will expire and no longer be valid. |
status | The status of the request. |
Errors
Errorcode | Message | Troubleshooting |
---|---|---|
21121 | Unknown devicekey xxxxxxx | Double check that the device key is valid. If the device status was still "waiting for device pairing," the request may have expired. |
21143 | Request failed (Payment terminal battery too low) | Charge the terminal before processing any more transactions. The terminal does not have the power to complete the transaction. |
21144 | Transaction request has timed out. | Retry transaction, and complete before time out allotted (default is 180 seconds). Lengthen timeout parameter if necessary. |
21145 | Device is currently offline. | Verify terminal is connected to payment engine and try again. |
21146 | Device is currently processing another transaction. | Two requests were sent simultaneously. Wait until the first request is complete and try again. |
GET payrequests/key
GET /api/paymentengine/payrequests/:requestkey:
Gets the status of a pay requestkey.
Request
Request Example
curl --basic --user APIKEY:PINHASH \
https://usaepay.com/api/v2/paymentengine/payrequests/pr_TJtcst4SfmEbztWk6V4RmJL5HKMLO
@GET/paymentengine/payrequests/:requestkey:@
Request Parameters
- -None-
Response
Pending Payment Response Example
@GET/paymentengine/payrequests/:requestkey:@
Payment Approved (with tokenization) Example
{
"type": "request",
"key": "pr_YF0Rg5UARsFTN9AItsIKXIczmwIWN",
"status": "transaction complete",
"transaction": {
"type": "transaction",
"key": "kdbbjsn49jsjy3gm",
"refnum": "2226860110",
"is_duplicate": "N",
"result_code": "A",
"result": "Approved",
"authcode": "019930",
"error": "Approved",
"error_code": "00000",
"iccdata": "{\"8A\":\"3030\"}",
"proc_refnum": "",
"auth_amount": "5.00",
"avs": {
"result_code": "YYY",
"result": "Address: Match & 5 Digit Zip: Match"
},
"cvc": {
"result_code": "P",
"result": "Not Processed"
},
"signature_required": true,
"creditcard": {
"number": "4444xxxxxxxx1111",
"type": "V",
"cardholder": "DOE\/JOHN",
"entry_mode": "Chip Read",
"aid": "A0000000031010"
},
"trantype": "Credit Card Sale",
"complete": true
}
}
Parameter | Description |
---|---|
key | Request key |
expiration | The expiration is the date/time the request will expire and no longer be valid. |
status | The status of the request. Possible Values are: sending to device sent to device waiting for card dip changing interfaces customer see phone and tap again processing payment completing payment capturing signature signature capture error transaction complete canceled transaction canceled transaction failed timeout error |
transaction | Once the transaction has been processed, a transaction object will be added to the result. |
complete | Confirms if transaction is complete. Value will be: true or false. Please Note: A transaction object could be included in the response (signaling the transaction has been processed), and also receive complete:false. For example, if a Custom Flow is set and signature_required is included, the flag will show as complete:false until the signature has been captured. |
DELETE payrequests/key
DELETE /api/v2/paymentengine/payrequests/:requestkey:
Deletes/cancels a payment request.
Request
Request Example
@DELETE/paymentengine/payrequests/:requestkey:@
Request Parameters
- -None-
Response
Response Example
@DELETE/paymentengine/payrequests/:requestkey:@
Connection Manager Pro
About
This software is an enterprise version of the device manager tool available in USAePay’s virtual terminal. The Connection Manager Pro is ideal for companies that need to manage several EMV devices remotely. Users can log into USAePay’s developer portal, which is capable of handling thousands of EMV devices from multiple locations. This outstanding solution will allow developers to deploy multiple locations remotely by rebooting, restoring and re-pairing EMV devices.
To Login to the Developer Portal
To login to the developer portal, go to https://sandbox.usaepay.com/_developer/app/login. If you do not already have a developer login, simply click "Register for an account" to create one. You can login immediately after you have registered.
Devices
The Devices page of the Developer Portal page will show the list of devices you are currently managing. This list can contain devices over multiple merchant accounts. You can add devices that have already been registered or register the devices as you add them.
New Device vs. Registered Device
A new device is a device that has NOT been paired or registered in the Merchant Console Device Manager. If you are pairing a new device then it can be registered as a stand alone or a managed device. If you are going to connecting the device to the Virtual Appliance then the device will ALWAYS be a new device.
A registered device is one that has been paired or registered in the Merchant Console Device Manager.
Stand Alone vs. Managed Device
A stand alone device is one which you do not need a virtual appliance to manage. Castles MP200's will be stand alone device, and all registered devices will automatically be categorized as stand alone.
A managed device is one which you use one of the appliances to manage, like the Ingenico ISC480. Visit the Connection Manager for Windows and the Connection Manager Virtual Appliance pages for more information.
Adding a Device
Creating an API Key
If it is your first time adding devices to the Connection Manager Pro, you will need to make sure you have an API Key created to attach each device to. You can add more than one device to each API Key. If you are managing devices from multiple merchant accounts, then you will need to create an API Key for each merchant account, because the API Key is what links that device to that specific account.
Login to the merchant account and create an API Key/Source Key and PIN for your devices. Instructions for both the Legacy Console and Console 2 are listed below.
Legacy Console
- Go to the Settings tab, then the Source Keys sub tab, and click "Add Source".
- Enter required fields and click "Save". Required fields are listed below:
- Name- Name the source key for the payment device.
- PIN- Create a pin for this source key. This is NOT optional when creating for a payment device.
- The system will generate a source key and return to the main Source Keys page.
Console 2
- Go to the Settings tab, then the API Keys sub tab, and click "Add API Key".
- Enter required fields and click "Save". Required fields are listed below:
- Name- Name the API Key for the payment device.
- PIN- Create a pin for this API Key.
- The system will generate an API Key and return to the main API Keys page.
Add Device Info
- Click "+ Add Device" at the top of the page on the Devices tab.
- Enter ALL of the fields. Different kinds of devices will require different fields. If a field is not displayed then it is not required. Description of each field are below:
- Select New or Registered- See above for more information.
- Name of Device- Name the Device. Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out.
- Type- Choose Managed for devices being managed by an appliance and Stand Alone for all others. See above for more information.
- Source Key- Enter the API Key you created above.
- PIN- Enter the PIN associated with the API Key you created.
- Device Key- The unique device key listed in the Device Manager.
- Device Make- Click dropdown menu and select the make of the device you are connecting.
- Server Key- Select the Device Server that you would like to link this device to. If you are using an appliance, you will need to create this server before connecting devices. See the Device Servers section below for more information.
- Device IP- Enter IP address of the device you are connecting.
- Environment- Sandbox or Production. The environment must match the API Key environment.
- Click "Apply" or "Save" and and the portal will confirm the device was successfully connected.
- The device will be listed on the "Devices" page and in the Connection Manager Pro (see below). Repeat this process for all devices you wish to manage from the Connection Manager Pro.
Import Devices
The Connection Manager also allows you to add multiple devices to your device servers by uploading information for multiple devices in a CSV document. Below are the steps for uploading both a managed and standalone devices.
Prepare the File
First, you will need to prepare the document with your device information. It must be in .csv format. Below you will find descriptions of the fields the file could include and an example template. Please Note: Documents must include only the devices that have the same type (Stand Alone or Managed) and same make.
Field | Requirements | Description |
---|---|---|
Store | Optional | Store number associated with device. |
DBA | Optional | Name of merchant associated with device. |
device_name | Required for ALL | Merchant assigned terminal label. Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out. |
apikey | Required for ALL | API key device should be connected to. |
apipin | Required for ALL | API pin for the above api key. |
device_ip | Required for Managed | IP address associated with device. |
devicekey | Required for Standalone | Unique gateway assigned alphanumeric string. |
Device Import Templates:
Specify File Information
Once you have prepared the document, click the 'Import' button at the top of the 'Devices' page.
Next, specify if the file contains managed or stand alone devices, and the fields associated with that device type will populate.
Managed Devices
When importing managed devices you will have to specify the following fields:
- Select a Server Key- Select the Device Server that you would like to link this device to. If you are using an appliance, you will need to create this server before connecting devices. See the Device Servers section below for more information.
- Select Make- Select the make of the device you are connecting.
When complete click 'Upload CSV' button.
Stand Alone Devices
When uploading Stand Alone devices, you will only need to specify the Environment (Sandbox or Production). The environment must match the API Key environment.
When complete click 'Upload CSV' button.
Upload and View Errors
Choose the file you wish to upload and click 'Open' and the developer-portal will parse the data in the file.
Once the data is parsed, the portal will show the following fields:
- Total Attempted- The number of devices you attempted to import.
- Successfully Saved- The number of devices that were successfully added to the device list.
- Errors- The number of devices NOT added to the list due to an error.
If you will to view the errors in your upload click 'Download Import Results' button. You will see the same .csv file that you uploaded and with two additional columns added:
- Saved- If this column says 'TRUE' then the device was uploaded successfully. If the column says 'FALSE' then the device was not uploaded
- Reason- This will be 'n/a' for successfully uploaded devices. For unsuccessful devices, it will show all relevant errors.
Once uploaded, the devices will be listed in the Devices section of the Developer Portal.
Device Servers
If you are using an appliance, you will need to create this server and link it to the appliance before connecting any devices. Instructions for creating the server are shown below.
Adding Device Servers
- Go to Developer Portal, select the "Device Servers" tab on the lefthand side, and then click "+ Add Device Server" at the top of the page.
- Enter all fields:
- Name- Name your device server
- Pairing Code- The pairing code provided by the appliance.
- Select an Environment- Choices are, Sandbox or Production. NOTE: You must choose the same environment you selected in the appliance.
- Click "Apply" or "Save". The Device Server will be created.
Change Log
2017-08-25
- Added Import Devices feature.
Connection Manager Setup
The Connection Manager Pro Virtual Appliance is intended for large scale deployments. Appliances are managed through the developer portal web interface.
Requirements:
VMWare
Supported Devices:
Ingenico ISC480 (Other Ingenico Terminals running RBA 23.0.44 should also be compatible)
Installation:
Payment Engine Connection Manager Pro - VMWare OVA (Contact Integration Department for file)
Setup
The Connection Manager Pro will allow you to manage multiple devices at one time. Follow these steps to set up the Payment Engine Connection Manager Pro and connect your devices.
Login
To login to the developer portal, go to https://sandbox.usaepay.com/_developer/app/login.
If you do not already have a developer login, simply click "Register for an account" to create one. You can login immediately after you have registered.
Install
- Install the Payment Engine Connection Manager Pro - VMWare OVA (Contact Integration Department for file).
- When you open the program it will first prompt you to select an environment.
- Then you will select an IP Configuration.
- Next, the Connection Manager Pro will display a pairing key. This is the key you will use to connect the Connection Manager Pro to your developer portal.
Create Device Server
- Create Device Server in Developer Portal and Link to Connection Manager Pro
- Go to Developer Portal, select the "Device Servers" tab on the lefthand side, and then click "+ Add Device Server" at the top of the page.
- Enter all fields:
- Name- Name your device server
- Pairing Code- Enter the pairing code from the Connection Manager Pro
- Select an Environment- Choices are, Sandbox or Production. NOTE: You must choose the same environment you selected in the Connection Manager Pro.
- Click "Apply" or "Save". The Device Server will be created and the Connection Manager Pro will recognize the connection (see below).
Developer Portal
Connection Manager Pro
Create API Keys
Login to the merchant account and create an API Key/Source Key and PIN for your devices. Instructions for both the Legacy Console and Console 2 are listed below.
Legacy Console
- Go to the Settings tab, then the Source Keys sub tab, and click "Add Source".
- Enter required fields and click "Save". Required fields are listed below:
- Name- Name the source key for the payment device.
- PIN- Create a pin for this source key. This is NOT optional when creating for a payment device.
- The system will generate a source key and return to the main Source Keys page.
Console 2
- Go to the Settings tab, then the API Keys sub tab, and click "Add API Key".
- Enter required fields and click "Save". Required fields are listed below:
- Name- Name the API Key for the payment device.
- PIN- Create a pin for this API Key.
- The system will generate an API Key and return to the main API Keys page.
Add Device
- Add Device to Device Server
- In the developer portal, click on the Devices tab, then click "+ Add Device" at the top of the page.
- Enter ALL fields for the device you are connecting:
- Select New of Registered- Always select Add New Device. Selecting Add Already Registered Device will not allow you to classify this as a managed device and thus will not allow you to access it from the Connection Manager Pro.
- Name of Device- Name the Device. Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out.
- Select Type- Always select Managed. If you select Stand Alone this device will only be entered into the device manager, and you will NOT have access to this device through the Connection Manager Pro.
- Source Key- Enter the API Key you created above.
- PIN- Enter the PIN associated with the API Key you created.
- Select Device Make- Click dropdown menu and select the make of the device you are connecting.
- Select a Server Key- Select the Device Server that you linked to the Connection Manager Pro from the dropdown menu.
- Device IP- Enter IP address of the device you are connecting.
- Click "Apply" or "Save" and and the portal will confirm the device was successfully connected.
- The device will be listed on the "Devices" page and in the Connection Manager Pro(see below). Repeat this process for all devices you wish to manage from the appliance.
Developer Portal
Connection Manager Pro
Connection Manager Virtual Appliance
The Connection Manager Virtual Appliance is intended for large scale deployments of devices. Appliances are managed through the developer portal web interface.
Requirements:
VMWare
Supported Devices:
Ingenico ISC480 (Other Ingenico Terminals running RBA 23.0.44 should also be compatible)
Installation:
Payment Engine Connection Manager Pro - VMWare OVA (Contact Integration Department for file)
Set-Up:
The Connection Manager Virtual Appliance will allow you to manage multiple devices at one time. Follow these steps to set up the Virtual Appliance and connect your devices.
Install the Virtual Appliance
- Install the Payment Engine Connection Manager Pro - VMWare OVA (Contact Integration Department for file).
- When you open the program it will first prompt you to select an environment.
- Then you will select an IP Configuration.
- Next, the Connection Manager Virtual Appliance will display a pairing key. This is the key you will use to connect the appliance to your developer portal.
Link to Device Server to Virtual Appliance
- Create a Device Server in the Developer Portal. Descriptions of the necessary fields are listed below. (For more information, visit the Connection Manager Pro) page:
- Name- Name your device server.
- Pairing Code- Enter the pairing code provided by the the Connection Manager Virtual Appliance.
- Select an Environment- Choices are, Sandbox or Production. NOTE: You must choose the same environment you selected in the Connection Manager Virtual Appliance.
- Click "Apply" or "Save". The Device Server will be created and the Connection Manager Virtual Appliance will recognize the connection (see below).
Add Device to Device Server
Connect your devices to the device server in the Developer Portal. For more information, visit the Connection Manager Pro page. When a device has been added successfully, the Connection Manager Virtual Appliance will show the connected device like this:
Cloud Middleware SDKs
.Net 4.5+
The Middleware SDK for .NET is a collection of classes that implement the rest api for the payment engine cloud solution. It allows developers to quickly create applications in .Net that take advantage of the payment engine middleware.
- Download the latest release: paymentengine-dotnet-sdk-1.0.9.zip
- Sample Application: PaymentEngineDemoApp-v3.zip
Middleware Class
Middleware Constructor
Middleware Constructor (C#)
public Middleware(String apiKey, String pin, String host="api.paymentengine.io")
Constructor for the middleware class. To instantiate the middleware object, you will need an API Key and PIN which can be created in the merchant console. You also have the option of specifying the gateway host you would like to use.
Constructor Example (C#)
try
{
Middleware client = new Middleware("_hxEwTCy4UPSTp7sL5V69fa2Uu5Gzrfu", "1234", "sandbox.usaepay.com");
} catch(MiddlewareException ex) {
Console.WriteLine("Error instantiating middleware: " + ex.ToString());
}
Parameter | Type | Description |
---|---|---|
apiKey | String | The API Key (aka SourceKey) created in the merchant console. |
pin | String | API PIN set in the merchant console. |
host | String | Gateway host to use. Defaults to primary production gateway "api.paymentengine.io". For sandbox use "sandbox.usaepay.com" |
Exceptions
- Will throw a MiddlewareException.
Code | Message | Notes |
---|---|---|
Invalid API Key | The key parameter was not set to a valid api key. | |
An API Pin is required | The pin parameter must be set to the pin assigned to the api key. If no pin has been set for the api key, log into the merchant console and set one. | |
Invalid gateway hostname | The host parameter must be set to a valid hostname for the gateway. It is the hostname only, do not include https:// |
RegisterDevice
RegisterDevice Function Header (C#)
public void RegisterDevice(String TerminalName, Action<Device> callback, Action<MiddlewareException> onError, String RegistrationType="standalone")
Starts the registration process for a new terminal. The callback delegate will be called with a middleware device object that includes the "PairingCode" parameter. This code is entered by the user into the payment terminal to complete the pairing process. This method is only needed if the developer wishes to support registering new terminals. Alternately, terminals can be registered in the Device Manager section of the Merchant Console.
RegisterDevice Example (C#)
client.RegisterDevice("Register 1",(device) => {
Console.WriteLine("Pairing code: " + device.PairingCode);
Console.WriteLine("Device Key: " + device.DeviceKey);
}, (emw)=> {
Console.WriteLine("error: " + emw.Message);
});
Parameter | Type | Description |
---|---|---|
TerminalName | String | The name of the terminal chosen by the user/developer. This can be used to distinguish between multiple devices. |
callback | Action |
Delegate called when registration request is accepted and pairing code is available. |
onError | Action |
Delegate called if an error occurs. |
RegistrationType | String | Type of device registration. Defaults to "standalone". |
Exceptions
- The onError delegate will be called if an error occurs.
Code | Message | Notes |
---|
See also: Common Exceptions
LoadDeviceByKey
LoadDeviceByKey Function Header (C#)
public void LoadDeviceByKey(String DeviceKey, Action<Device> callback, Action<MiddlewareException> onError=null)
Loads a Device object for an existing DeviceKey. The DeviceKey is returned when registering the device with RegisterDevice. The DeviceKey is also available in the Device Manager screen under the Settings section of the merchant console.
LoadDeviceByKey Example (C#)
client.LoadDeviceByKey("sa_0nr0qWGWrEQzALVjFkTeptSWj9NnE", (x) => {
Device device = x;
Console.WriteLine("Device load: " + device.Name);
}, (emw)=> {
Console.WriteLine("error: " + emw.Message);
});
Parameter | Type | Description |
---|---|---|
DeviceKey | String | Key that uniquely identifies a device. |
callback | Action |
Delegate called when device has been loaded. |
onError | Action |
Delegate called if an error occurs. |
Exceptions
- Either throws a MiddlewareException or calls the onError delegate.
Code | Message | Notes |
---|---|---|
DeviceKey is required | A valid DeviceKey must be passed in the first parameter | |
21121 | Unknown device key ... | The DeviceKey did not match a device on the server |
See also: Common Exceptions
LoadDevices
LoadDevices Function Header (C#)
public void LoadDevices(Action<Device> callback, Action<MiddlewareException> onError=null)
Loads all Devices.
LoadDevices Example (C#)
client.LoadDevices((x) => {
Device device = x;
Console.WriteLine("Device load: " + device.Name);
}, (emw)=> {
Console.WriteLine("error: " + emw.Message);
});
Parameter | Type | Description |
---|---|---|
callback | Action |
Delegate called when each device has been loaded. |
onError | Action |
Delegate called if an error occurs. |
Exceptions
- Calls the onError delegate.
See also: Common Exceptions
LoadPaymentRequestByKey
LoadPaymentRequestByKey Function Header (C#)
public void LoadPaymentRequestByKey(String RequestKey, Action<PaymentRequest> callback, Action<MiddlewareException> onError)
Load an existing payment request by RequestKey.
Missing Example (C#)
ADD ME!
Parameter | Type | Description |
---|---|---|
RequestKey | String | Key that uniquely identifies an existing payment request. |
callback | Action |
Delegate called when payment request has been loaded. |
onError | Action |
Delegate called if an error occurs. |
Exceptions
- Throws a MiddlewareException
Code | Message | Notes |
---|---|---|
RequestKey is required | A valid RequestKey must be passed in the first parameter | |
99999 | Request not found | The RequestKey did not match a payment request on the server |
Device Class
Parameter | Type | Description |
---|---|---|
DeviceKey | String | Key that uniquely identifies a device. |
Name | String | Developer/merchant assigned device name |
Status | String | Current device status |
PairingCode | String | If device has not been paired yet, this parameter contains the pairing code needed to be entered on terminal to complete registration. |
PairingExpiration | DateTime | Date/Time that the pairing code will expire. The device will automatically be deleted if not paired by this time. |
Config | %TerminalConfig% | Terminal configuration. Controls the payment processing features, such as contactless payments, EMV and PIN debit. TerminalConfig |
Settings | %DeviceSettings% | Settings not related to payment processing, such as whether to allow sharing the device between multiple merchants. DeviceSettings |
Details | %DeviceDetails% | Contains details about the registered terminal, such as the model and serial number. DeviceDetails |
StartTransaction
StartTransaction Function Header (C#)
public PaymentRequest StartTransaction(Transaction Request, Action<String,TransactionResult> onTransactionComplete, Action<String> onStatusUpdate, Action<MiddlewareException> onError)
Sends a payment request to the terminal. Returns a PaymentRequest object that can be used to access the current status of the payment or cancel the transaction.
StartTransaction Example (C#)
TransactionRequest tran = new TransactionRequest()
{
Command = "cc:sale",
Amount = "10.00"
};
request = device.StartTransaction(tran,
(status, result) =>
{
Console.WriteLine("Status: " + status);
if(result != null)
{
Console.WriteLine("Transaction " + result.Result);
if (result.ResultCode.Equals("A")) Console.WriteLine(" AuthCode: " + result.AuthCode);
else Console.WriteLine(" Error: " + result.Error);
}
},
(status) =>
{
Console.WriteLine("Status: " + status);
},
(emw) =>
{
Console.WriteLine("Error: " + emw.Message);
},
);
Parameter | Type | Description |
---|---|---|
Request | %TransactionRequest% | Transaction details such as amount. TransactionRequest |
onTransactionComplete | Action |
Method that is called once the device has refreshed. Passes a String containing the current device status |
onStatusUpdate | Action |
Method that is called once the device has refreshed. Passes a String containing the current device status |
onError | Action |
Method that is called if an exception occurs. Note: this is only called for communication and library issues. If the transaction is declined, the customer cancels the transaction or any other processing related error occurs, onTransactionComplete will be called. |
ToJSON
ToJSON Example (C#)
String json = device.ToJSON();
Serializes a Device object to a JSON encoded string.
Refresh
Refresh Function Header (C#)
public void Refresh(Action<PaymentRequest> callback, Action<MiddlewareException> onError)
Refreshes device information and status.
Refresh Example (C#)
device.Refresh((x) =>
{
Console.WriteLine("Device status: " + device.Status);
}, (ex)=>{
Console.WriteLine("Error: " + ex.Message);
});
Parameter | Type | Description |
---|---|---|
callback | Action |
Method that is called once the device has refreshed. |
onError | Action |
Method that is called if an exception occurs. |
ResetPairing
ResetPairing Function Header (C#)
public void ResetPairing(Action<PairingCode> callback, Action<MiddlewareException> onError)
Unlinks the devicekey from the terminal and generates a new pairing code. The terminal will go back to the pairing screen and the device key can be then be paired to either the same terminal or a new one. This method allows for switching hardware terminals without needing to switch to a new devicekey.
ResetPairing Example (C#)
device.ResetPairing((x) =>
{
Console.WriteLine("Pairing reset, new pairing code: " + x);
}, (ex)=>{
Console.WriteLine("Error: " + ex.Message);
});
Parameter | Type | Description |
---|---|---|
callback | Action |
Method that is called once the device is reset, passes the new pairing code |
onError | Action |
Method that is called if an exception occurs. |
DeviceDetails Class
Parameter | Type | Description |
---|---|---|
Make | String | Device manufacturer |
Model | String | Model name of terminal |
Revision | String | Firmware version |
Serial | String | Serial number |
DeviceSettings Class
This object controls the settings of the payment engine device not related to payment acceptance. Payment acceptance settings are configured via the TerminalConfig.
Parameter | Type | Description |
---|---|---|
Timeout | int | Sets transaction timeout in seconds. |
EnableStandalone | bool | Allows transactions to be initiated by terminal. |
ShareDevice | bool | Allows terminal to be used by any API key including those belonging to other merchants. |
TerminalConfig Class
This object describes the requested terminal config. When processing a transaction, the merchants capabilities are also evaluated. Features that are requested and available to the merchant will be enabled on the terminal. For example: If EnableEMV is set to true, but the merchant is configured for a credit card processor that does not support EMV, then the card slot will not be enabled.
Parameter | Type | Description |
---|---|---|
EnableEMV | bool | Enable the smart card slot for EMV processing |
EnableDebitMSR | bool | Enable swiped PIN debit transactions |
EnableContactless | bool | Enable the contactless reader for NFC transactions |
TipAdjustAfterAuth | bool | Allow addition of tip after initial authorization. Disables PIN CVM and No CVM. |
PaymentRequest Class
Parameter | Type | Description |
---|---|---|
RequestKey | String | Unique key that identifies the payment request |
Status | String | The current status of the payment request |
Result | %TransactionResult% | Contains the payment details after a transaction has been completed, such as authorization code. TransactionResult |
Timeout | int | The maximum amount of time allowed for the customer to complete the payment on the terminal. When the timeout is reached, the payment will be canceled. |
CancelTransaction
CancelTransaction Function Header (C#)
public void CancelTransaction(Action<String>callback, Action<MiddlewareException> onError)
Cancels a payment request that is in progress.
CancelTransaction Example (C#)
request.CancelTransaction((x) =>
{
Console.WriteLine("Request cancelled: " + x);
}, (ex)=>
{
Console.WriteLine("Exception cancelling tran: " + ex.Message);
});
Parameter | Type | Description |
---|---|---|
callback | Action |
Delegate is called once the payment request has been canceled. |
onError | Action |
Delegate is called if an exception occurs. |
TransactionRequest Class
This object is passed to the StartTransaction method. The only required parameters are the "Command" and "Amount" fields. The DeviceKey is set automatically by the StartTransaction method and will be ignored if set manually.
Parameter | Type | Description |
---|---|---|
DeviceKey | String | Unique identifier for the terminal that the transaction will be sent to. |
Command | String | Payment command to run. Supported commands are: cc:sale, cc:authonly and cc:refund |
Amount | String | Amount to process payment for. This should be the final amount (unless choosing to allow terminal to prompt for tip and cashback). |
AmountDetail | %AmountDetail% | Detailed breakdown of the above total Amount. AmountDetail Class |
PoNum | String | Purchase order number, only required for corporate cards. |
Invoice | String | Invoice number, only first 10 digits are sent to platform |
OrderID | String | Order identifier, alpha numeric |
Description | String | Transaction description (visible to customer on receipt) |
Comments | String | Internal transaction comments (visible only to merchant) |
RestaurantTable | String | Table number |
Clerk | String | Clerk/Cashier name |
BillingAddress | %Address% | Billing address information |
ShippingAddress | %Address% | Shipping address information |
CustomerEmail | String | Customer email address |
CustomerID | String | Customer ID |
ClientIP | String | IP address of customer, useful if request is initiated from a server. |
GeoLocation | String | Latitude and longitude to record for transaction. Example: "40.7142700,-74.0059700" |
LineItems | LineItem[] | Array of line item details |
ManualKey | Boolean | Set to true to have the terminal prompt for manual card number entry instead of swipe/dip |
PromptTip | Boolean | Set to true to have the terminal prompt the customer for a tip amount. |
PromptCashBack | Boolean | Set to true to have the terminal prompt the customer for cash back. |
PromptSignature | Boolean | Set to false to prevent the terminal from capturing the customer signature. If the terminal supports signature capture, it will be on by default. |
CustomFlow | String | Optional string that controls the sequence of screens presented to the customer during payment. Leave blank to use the default flow. Example: "amount,payment,result" |
SaveCard | Boolean | Set to true to save the payment data to the customer record |
Timeout | Integer | Set the transaction timeout |
BlockOffline | Boolean | Set to true to have the request refused if the device is currently offline |
TransactionResult Class
This object is returned when the payment has been completed.
Parameter | Type | Description |
---|---|---|
TransactionKey | String | Unique identifier for transaction. Can be used to perform actions such as refund and void on a transaction. |
RefNum | String | Numeric sequential transaction reference number. Can be used with older gateway APIs. |
AuthAmount | String | Authorized amount returned from processor. |
AuthCode | String | AuthCode returned from processor. |
ProcRefNum | String | Processor generated transaction reference number (if available). |
Result | String | Result of transaction: Approved, Declined, Error or Partial Approval. |
ResultCode | String | Result code of transaction: A, D, E or P |
IsDuplicate | String | "Y" indicates that a duplicate transaction was detected, the transaction was folded, and the details from the original transaction was returned. |
Error | String | Error message if transaction was a decline or error |
ErrorCode | String | Gateway error code |
ProcRefNum | String | Backend processor reference number (if available) |
AVS | AvsResult | Result of address verification (if manually keyed) |
CVC | CvcResult | Result of card code verification (if manually keyed) |
CreditCard | CreditCard | Information about the credit card used |
Token | String | Reusable token to charge payment data in a new request |
Address Class
Parameter | Type | Description |
---|---|---|
FirstName | String | |
LastName | String | |
Company | String | |
Street | String | |
Street2 | String | |
City | String | |
State | String | |
PostalCode | String | |
Country | String | |
Phone | String | |
Fax | String |
AmountDetail Class
The amount class provides a break down of the total charge amount (the Amount field in the TransactionRequest class);
Parameter | Type | Description |
---|---|---|
Tax | String | Total tax amount |
NonTaxable | String | Set to "Y" to indicate that the transaction is non-taxable. |
Cash | String | For debit, amount of cashback |
Tip | String | Tip amount, only set if choosing not to prompt for tip on terminal |
Discount | String | Amount of order level discount |
Shipping | String | Shipping charges |
Duty | String | Duty charges (for level 3 processing) |
EnablePartialAuth | bool | Include this parameter to authorize partial funds when the full amount is not available. For example, if the total is $10 and the customer only has $5 in their account, $5 will be authorized. If not included in request, partial authorization defaults to disabled. |
AvsResult Class
Result of the Address Verification System. This only applies to manually keyed transactions. Swiped, dipped and contactless transactions will not typically receive a result.
Parameter | Type | Description |
---|---|---|
Result | String | String describing the address verification result. |
ResultCode | String | Short code representing result. |
CvcResult Class
Result of the card verification code match. This only applies to manually keyed transactions.
Parameter | Type | Description |
---|---|---|
Result | String | String describing the card verification code result. |
ResultCode | String | Short code representing result. |
CreditCard Class
Information about the credit card that was used to run the transaction .
Parameter | Type | Description |
---|---|---|
Type | String | Brand of card: Visa, Mastercard, Amex, Discover |
Number | String | The masked card number |
CardHolder | String | The card holder name (if available) |
EntryMode | String | How the payment method was entered: keyed, swiped, dipped, or tapped |
CategoryCode | String | The card category code (if available) |
AvsStreet | String | The avs street number if manually keyed |
AvsPostalCode | String | The avs postal code if manually keyed |
Verification | String | The method of customer verification (if available): signature, pin |
Signature | String | The base64 encoded PNG of the signature image (if available) |
MiddlewareException Class
Parameter | Type | Description |
---|---|---|
Message | String | Error message |
ErrorCode | String | If the error is a server side error, this parameter will be set to the gateway ErrorCode. |
Common Exceptions
- The following exceptions are common to most methods in the library.
ErrorCode | Message | Notes |
---|---|---|
21002 | API authentication failed | The api key or pin is incorrect. Also verify that the gateway host is the same as the one used to create the key. A sandbox key will not work in production. |
.Net Change Log
v1.0.9 - 2018-04-17
- Fixed Error Handling for Dropped Connections
- Added explicit default setting for TLS 1.2 support
v1.0.8 - 2017-08-25
- Default url changed from "www.usaepay.com" to "api.paymentengine.io"
- Added Timeout to the TransactionRequest class
- Added BlockOffline to the TransactionRequest class
- Added SaveCard to the TransactionRequest class
- Added Token to the TransactionResult class
v1.0.7 - 2017-08-15
- Added additional whitelisted domains
v1.0.6 - 2017-05-16
- Added Verification to the CreditCard class
- Added Signature to the CreditCard class
v1.0.5 - 2017-02-21
- Added AuthAmount to the TransactionResult class
- Added LoadDevices method to the Middleware class
v1.0.4 - 2017-02-15
- Added CustomFlow to the TransactionRequest class
v1.0.3 - 2017-02-03
- Added ResetPairing method on the Device class to allow switching terminals without needing a new device key
v1.0.2 - 2017-01-17
- Added onError delegate to all methods with background processing to fix exception handling
- Added CreditCard class to TransactionResult
- Added LoadPaymentRequestByKey to the Middleware class
v1.0.1 - 2017-01-11
- Changed to target to .Net 4.5
Sample Code: C# .net
Rest Authorization Header
To authenticate with the rest API, you will need to set the authorization header:
Example
WebRequest request = (WebRequest)WebRequest.Create(url);
request.ContentType = " application/json;charset=utf-8";
request.Headers["Authorization"] = BuildAuthHeader();
Helper functions for the above code:
Example
private static String BuildAuthHeader(String key, String pin)
{
// create seed for hash
String Seed = Guid.NewGuid().ToString();
// create hash of apikey, seed and pin
String Hash = GenerateHash(key + Seed + pin);
// assemble auth string, api key is the username, hash is the password
String authInfo = key + ":s2/" + Seed + "/" + Hash;
authInfo = "Basic " + Convert.ToBase64String(Encoding.Default.GetBytes(authInfo));
return authInfo;
}
private static String GenerateHash(string input)
{
// Create a new instance of the SHA256CryptoServiceProvider object.
SHA256 shaHasher = SHA256.Create();
// Convert the input string to a byte array and compute the hash.
byte[] data = shaHasher.ComputeHash(Encoding.Default.GetBytes(input));
// Create a new Stringbuilder to collect the bytes
// and create a string.
StringBuilder sBuilder = new StringBuilder();
// Loop through each byte of the hashed data
// and format each one as a hexadecimal string.
for (int i = 0; i < data.Length; i++)
{
sBuilder.Append(data[i].ToString("x2"));
}
// Return the hexadecimal string.
return sBuilder.ToString();
}
API Change Log
2018-03-19
- Added description for "device_name" on Device Management pages.
2018-01-08
- Added "amount_detail.enable_partialauth" to POST /payrequests.
- Added "complete" flag to GET /payrequests.
2017-08-28
- Added error codes for "timeout" to POST /payrequests.
2017-08-17
- Added description of Firewall Rules.
- Added new fields ("timeout", "block_offline", "manual_key", "prompt_tip") and descriptions to POST /payrequests.
- Added "lineitems" parameters and code example to POST /payrequests.
- Added "custom_fields" parameters and code example to POST /payrequests.
- Added Ingenico "custom_flow" parameters ("payment", "amount", "result", "signature", "signature_required") to POST /payrequests.
2017-01-17
- Initial Push of Pages including:
- General
- Device Management
- Payment Requests
Terminals
Castles MP200/MP200L
The MP200 combined with the PaymentEngine terminal software offers cutting edge payment acceptance solutions to a wide range of merchants. It can be used both as a mobile solution, paired via to Bluetooth to iOS or Android phones and tablets, and as a standalone wifi-based solution that can be integrated into virtually any desktop and browser based application.
Features
- 2.4" Color TFT LCD
- Connectivity: Bluetooth, Wifi, USB (Android only) and 2G/3G/4G (Optional)
- Payment Acceptance Types: Mag Swipe Reader, Smart Card Reader (EMV), NFC (Apple and Android Pay), Pin entry
- E2E encryption
- PCI PTS 4.x, EMV L1 L2
MP200 Main Menu
Settings
Connection Type | Manage Wifi | Rescan Wifi | Mode Select | Keypad Sound Off/On | Unpair |
---|---|---|---|---|---|
Wifi Bluetooth USB | Network name that you are currently connected to | Rescan all networks that are available to connect | Production or Sandbox | When you press the number “5” on the keypad the sound will turn off/on | This option is to unpair from the network that you are currently connected to |
Device Information
Mode | Build | Deployment | Device Key | Wi-Fi |
---|---|---|---|---|
Production or Sandbox | Current version that the device is running on | USAePay | Specific key associated with the device | Network that you are currently connected to |
Anatomy of the MP200
Pairing Device (iOS)
When using the MP200 with a iOS mobile application that implements the middleware library, the merchants mobile device will communicate with MP200 via a Bluetooth connection. The following steps must be followed to pair the MP200 with the iOS device. Note: If the Castles MP200 device is to be used with multiple phones/tablets then the MP200 device must be unpaired from any unused mobile devices.
- On the MP200 device press and hold the Bluetooth button until the device requests PIN
- Go to iPhone/iPad Settings-->Bluetooth-->Enable Bluetooth-->Select the MP200 device
- If you have multiple MP200 devices, find the last 4 digits of the S/N (serial number) on the back of the MP200. See below.
- In our case, we would select MP200-1793 from the iPhone/iPad.
- Once the device connects to the MP200, a PIN will pop up on the mobile device screen. See below.
- Enter the pin into the MP200.
- Wait until the MP200 displays a green check mark and "OK." On your phone/tablet you should see the MP200 is "Connected," as shown below.
Pairing Device (Payment Engine)
- On the MP200 device press and hold the Wi-Fi button until you hear the second beep sound.
- You will then be shown a list of available Wi-Fi networks that are in range of the MP200.
- Scroll to the network that you want to connect to and press the green key again.
- The device will then prompt you for the password for that network. Use the keys to enter letters and numbers by pressing the key repeatedly to scroll through the available characters for that key.
- When completed, give the device around thirty seconds to connect with the Wi-Fi network. The Wi-Fi indicator will change from a Wi-Fi symbol with an exclamation mark to showing the Wi-Fi signal strength.
Device Manager
- To access the Device Manager, click on ‘Settings’ from your side menu bar then select ‘Device Manager’ on the drop down menu.
- A source key must be added first to connect your device (CASTLES MP200). Go to ‘Settings’ from your side menu bar and then select ‘API Keys’ on the drop down menu. Click on 'Add API Key' to add a new source key.
- After a source key has been generated, return to the Device Manager section under Settings. Click on the 'Add' button to add a new Device. The following screen will appear to register device:
- Enter the Device’s Name and select the Source Key from the drop down menu as shown below. Please Note: Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out. Once the Device Name and Source Key have been selected, click on 'Register'. The Merchant Console will then generate a pairing code to pair your device to the Merchant Console. The CASTLES MP200 device will then ask you to enter the pairing code (shown in the Merchant Console):
- Once the pairing code has been entered, your device should be connected. The green icon in the top right of the box indicates that the device is connected.
- Device Options: Click on the device to view the device’s settings. The following page with the device’s information and options will appear:
- Now that a device is connected to your Merchant Console, the Simple Charge option will appear under the ‘Transactions’ section of the Console. When you click on Simple Charge in the side menu, you can either enter the information manually or use your device to process the card. Click on "Manual" to reveal the drop down menu and select from the devices connected. After all information has been entered, click on 'Process Charge' to process the transaction.
Firmware Change Log
Build 0054
Build 0053
Build 0052
Build 0051
- Improved server connection speed when on WiFi
- Image updates
- Improved stability
- CTPAY version 20170414
- Addressed debit PIN issue in certain cases
- Improved battery status reporting
- CTPAY version 20170322
- Improved stability
- Added [CANCEL] support during PIN entry
- Improved battery status reporting when charging via USB
- Added sleep mode support when charging
Build 0050
- Screen Timeout Updates
- Improved server connection speed when on WiFi
- Suspend / Sleep Improvements
- WiFi password support to 40 characters
Build 0049
- WiFi Support
Parameter Name | Type | Description |
---|---|---|
subtotal | double | This field is optional, but if it is sent, it must be consistent with the following equation: amount = subtotal - discount + shipping + duty + tax + tip. |
tax | double | The amount of tax collected. |
nontaxable | bool | Transaction is non taxable (Y/N) |
tip | double | Amount of tip collected. |
discount | double | Amount of discount applied to total transaction. |
shipping | double | Amount of shipping fees collected. |
duty | double | Amount of duty collected. |
enable_partialauth | bool | Enable partial amount authorization. If the available card balance is less than the amount request, the balance will be authorized and the POS must prompt the customer for another payment to cover the remainder. The result_code will be "P" and auth_amount will contain the partial amount that was approved. |
Parameter Name | Type | Description |
---|---|---|
company | string | Company or Organization Name |
firstname | string | First name associated with billing address |
lastname | string | Last name associated with billing address |
street | string | Primary street number/address information. (i.e. 1234 Main Street) |
street2 | string | Additional address information such as apartment number, building number, suite information, etc. |
city | string | Billing city |
state | string | Two-letter State abbreviation or full state name. |
postalcode | string | Zip code |
country | string | Three-letter country code. See full list here |
phone | string | The phone number associated with a billing address. The preferred format is to eliminate all non-numeric characters, but any standard formatting is accepted. |
fax | string | The fax number associated with a billing address. The preferred format is to eliminate all non-numeric characters, but any standard formatting is accepted. |
Parameter Name | Type | Description |
---|---|---|
1 | string | Optional fields for storing custom data. Character Limit: 255 |
2 | string | Optional fields for storing custom data. Character Limit: 255 |
3 | string | Optional fields for storing custom data. Character Limit: 255 |
... | ||
19 | string | Optional fields for storing custom data. Character Limit: 255 |
20 | string | Optional fields for storing custom data. Character Limit: 255 |
Parameter Name | Description | |
---|---|---|
options | Custom screen for add ons and tips. Must be FIRST in list. | |
payment | Payment taking screen (must come before result). | |
amount | Optional confirmation of amount (must come before result). | |
result | Displays the transaction result. | |
signature | Signature capture (must come after result). | |
signature_required | Signature capture. If the signature is cancelled, then the transaction will be cancelled (must come after result). |
Parameter Name | Type | Description |
---|---|---|
type | String | The type of option 'AddOn' or 'Tip' |
display | String | Text to be displayed on screen. ('AddOn' or 'Tip') |
sku | String | SKU to be used for any AddOn option selected. ('AddOn') |
denominations | array | Array of up to 4 options presented to the user. ('AddOn' or 'Tip') |
--- | --- | --- |
Parameter Name | Type - Description | |
display | String - Text to display for option. ('AddOn' or 'Tip') | |
sku | String - Option specific SKU to be used if option is selected. ('AddOn') | |
amount | String - Amount to add to transaction if option is selected. ('AddOn' or 'Tip') | |
amount_other | Boolean - Special Flag to trigger custom amount entry by user if selected. If set ignores amount field. ('AddOn' or 'Tip') | |
amount_min | String - Minimum amount to allow use to enter if amount_other. ('AddOn' or 'Tip') | |
amount_max | String - Maximum amount to allow use to enter if amount_other. ('AddOn' or 'Tip') |
Parameter Name | Type | Description |
---|---|---|
product_key | string | Gateway generated unique product identifier. Will only be included if the line item is a product from the database. |
name | string | Product name. (Required) |
cost | double | Cost of line item. (Required) |
qty | integer | Quantity of products. (Required) |
description | string | Line item description. |
sku | string | This is the product’s Stock Keeping Unit number. |
taxable | bool | Denotes if line item is taxable. |
tax_amount | currency | Tax amount that should be applied to line item price. |
tax_rate | string | Tax percentage that should be applied to line item amount. |
discount_rate | string | Discount percentage that should be applied to line item amount. |
discount_amount | double | Discount amount that should be applied to line item amount. |
location_key | string | Unique identifier for warehouse location. |
commodity_code | string | Commodity code for product. |
um | string | Unit of measure (Required for Level 3 processing) |
Parameter Name | Type | Description |
---|---|---|
timeout | Transaction timeout, how long to wait for transaction authorization to complete. | |
enable_standalone | Allows transactions to be initiated from terminal (if supported). | |
share_device | If true, this allows the payment device to be used by other merchants. If false, only the merchant associated with the apikeyid may send transactions to device. | |
notify_update | If true, device will be notified on all future updates | |
notify_update_next | If true, device will be notified only on the next update. After notification, this is automatically set back to false. | |
sleep_battery_device | This is the amount of inactive time (in minutes) before the device enters full sleep if it is running on battery. If in full sleep, you will need to turn the device on again before processing. Wifi and Bluetooth pairing should persist, even after full sleep. Set to '0' to never sleep. | |
sleep_battery_display | This is the amount of inactive time (in minutes) before the device enters display sleep if it is running on battery. If in display sleep, just send a transaction to the device or tap any button to wake the device. Set to '0' to never sleep. | |
sleep_powered_device | This is the amount of inactive time (in minutes) before the device enters full sleep if it is plugged into power. If in full sleep, you will need to turn the device on again before processing. Wifi and Bluetooth pairing should persist, even after full sleep. Set to '0' to never sleep. | |
sleep_powered_display | This is the amount of inactive time (in minutes) before the device enters display sleep if it is plugged into power. If in display sleep, just send a transaction to the device or tap any button to wake the device. Set to '0' to never sleep. |
Parameter Name | Type | Description |
---|---|---|
company | string | Company or Organization Name |
firstname | string | First name |
lastname | string | Last name |
street | string | Primary street number/address information. (i.e. 1234 Main Street) |
street2 | string | Additional address information such as apartment number, building number, suite information, etc... |
city | string | Shipping City |
state | string | Two-letter State abbreviation or full state name. |
postalcode | integer | Zip code |
country | string | Three-letter country code. See full list here |
phone | string | The phone number associated with a shipping address. The preferred format is to eliminate all non-numeric characters, but any standard formatting is accepted. |
Parameter Name | Type | Description |
---|---|---|
device_name | String | Name of device, should be "MP200". |
enable_emv | boolean | Enables EMV processing. |
enable_debit_msr | boolean | Enables PIN debit for swiped transactions. |
enable_tip_adjust | boolean | Allows EMV transaction amounts to be adjusted after authorization (to add tip). Disables PIN authentication. |
enable_contactless | boolean | Enables NFC reader. |
Parameter Name | Type | Description |
---|---|---|
make | Manufacturer | |
model | Device model | |
revision | Hardware version number | |
serial | Device serial number | |
key_pin | Device PIN encryption key. Only necessary if merchant will be processing transactions with a PIN. | |
key_pan | Device PAN encryption key. |
Constant | Description |
---|---|
FAIL_CVM | Indicates the CMV failed. |
NO_CVM_REQ | Indicates the CVM is not required. |
PIN_OFFLINE_ENCR | Indicates the PIN was verified offline and encrypted. |
PIN_OFFLINE_PLAIN | Indicates the PIN was verified offline in plaintext. |
PIN_ONLINE | Indicates the PIN was verified online. |
SIGNATURE_REQ | Indicates that a signature is required. |
Constant | Description |
---|---|
ALREADY_STARTED | |
BAD_SWIPE | MP200 received bad swipe. Transaction will be aborted, retry. |
GATEWAY_401_UNAUTHORIZED | |
GATEWAY_CONNECTION_ERROR | The connection to the gateway failed. |
GENERAL_EXCEPTION_CAUGHT | Exception from Exception class caught, stack trace printed, report this error. |
HANDLED | These errors go out to the user. |
INVALID_AMOUNT | The amount entered was invalid. |
INVALID_MAG_STRIPE | The transaction was terminated because a bad mag swipe was retried 3 times. |
INVALID_TERMINAL_CONFIG | |
INVALID_UPDATE_PARAMETER | |
LOW_BATTERY | Low battery, plug in the MP200. |
MP200_COMMAND_TIMEOUT | Command to MP200 timed out, transaction will abort, retry. |
NO_BT_DEVICE | No BT(bluetooth) device was found, check BT settings. |
NO_DEVICES_FOUND | |
NO_ERROR | |
NOT_CONNECTED | The device is not in the connected state to execute this function. |
NOT_ENOUGH_SPACE_FOR_UPDATE | Free up memory in the app cache directory. |
TIMEOUT_GATEWAY | Timeout has occurred between gateway. |
TRANSACTION_CANCEL_BUTTON | The transaction was cancelled by pressing the cancel button. |
TRANSACTION_CARD_ERROR | |
TRANSACTION_CARD_REMOVED | |
TRANSACTION_INVALID_PIN | Transaction was terminated because of an invalid PIN. |
TRANSACTION_REQUESTS_CHANGE_INTERFACE | This will also fire a delegate to change interface. |
UNHANDLED_ERROR | Unhandled Error, please report this. |
UNHANDLED_EXCEPTION | |
UNHANDLED_EXCEPTION_CAUGHT | |
UPDATE_COMPLETE | |
UPDATE_FAILED | An error occurred during the update process causing it to fail. |
USB_CONNECTION_CLOSED | USB Connection has been closed, reconnect. |
USER_INPUT_EXCEPTION |
Key | Description |
---|---|
command | Processing command, in this case it will be "adjust". |
amount | Total amount of the transaction including tips |
tip | The amount to tip |
refNum | The refNum of the transaction for which you are adjusting. |
Key | Description |
---|---|
command | Processing command, in this case it will be "capture". |
amount | Total amount of the transaction for which you are capturing the signature. |
refNum | The refNum of the transaction for which you are capturing the signature. |
signature | The base64Encoded string of the image. |
Key | Description |
---|---|
command | Processing command, in this case it will be "capture". |
amount | Total amount of the transaction for which you are capturing the signature. |
refNum | The refNum of the transaction for which you are capturing the signature. |
signature | The base64Encoded string of the image. |
Parameter Name | Description | |
---|---|---|
options | Custom screen for add ons and tips. Must be FIRST in list. | |
payment | Payment taking screen (must come before result). | |
amount | Optional confirmation of amount (must come before result). | |
result | Displays the transaction result. | |
signature | Signature capture (must come after result). | |
signature_required | Signature capture. If the signature is cancelled, then the transaction will be cancelled (must come after result). |
Parameter Name | Description | |
---|---|---|
options | Custom screen for add ons and tips. Must be FIRST in list. | |
payment | Payment taking screen (must come before result). | |
amount | Optional confirmation of amount (must come before result). | |
result | Displays the transaction result. | |
signature | Signature capture (must come after result). | |
signature_required | Signature capture. If the signature is cancelled, then the transaction will be cancelled (must come after result). |
Parameter Name | Type | Description |
---|---|---|
type | string | Object type. This will always be device. |
key | string | Unique device identifier |
apikeyid | string | The id of API key (source key) associated with the device. |
terminal_type | string | Terminal type: "standalone" for payment engine cloud based terminal. |
status | string | Current device status |
name | string | Developer assigned device name. Device name can contain letters, numbers, spaces, and dashes. All other characters will be filtered out. |
settings | object | Device settings |
terminal_info | object | Details of terminal |
terminal_config | object | Terminal configuration |
pairing_code | string | If terminal type is 'standalone', this is the pairing code required to pair the payment device with the payment engine. |
expiration | string | If terminal type is 'standalone', the expiration is the date/time that the pairing code is no longer valid. |
Parameter | Type | Description |
---|---|---|
FirstName | String | |
LastName | String | |
Company | String | |
Street | String | |
Street2 | String | |
City | String | |
State | String | |
PostalCode | String | |
Country | String | |
Phone | String | |
Fax | String |
Parameter Name | Type | Description |
---|---|---|
Tax | String | Total tax amount |
NonTaxable | String | Set to "Y" to indicate that the transaction is non-taxable. |
Cash | String | For debit, amount of cashback |
Tip | String | Tip amount, only set if choosing not to prompt for tip on terminal |
Discount | String | Amount of order level discount |
Shipping | String | Shipping charges |
Duty | String | Duty charges (for level 3 processing) |
EnablePartialAuth | bool | Include this parameter to authorize partial funds when the full amount is not available. For example, if the total is $10 and the customer only has $5 in their account, $5 will be authorized. If not included in request, partial authorization defaults to disabled. |
Parameter | Type | Description |
---|---|---|
DeviceKey | String | Unique identifier for the terminal that the transaction will be sent to. |
Command | String | Payment command to run. Supported commands are: cc:sale, cc:authonly and cc:refund |
Amount | String | Amount to process payment for. This should be the final amount (unless choosing to allow terminal to prompt for tip and cashback). |
AmountDetail | AmountDetail Class | Detailed breakdown of the above total Amount. |
PoNum | String | Purchase order number, only required for corporate cards. |
Invoice | String | Invoice number, only first 10 digits are sent to platform |
OrderID | String | Order identifier, alpha numeric |
Description | String | Transaction description (visible to customer on receipt) |
Comments | String | Internal transaction comments (visible only to merchant) |
RestaurantTable | String | Table number |
Clerk | String | Clerk/Cashier name |
BillingAddress | address | Billing address information |
ShippingAddress | address | Shipping address information |
CustomerEmail | String | Customer email address |
CustomerID | String | Customer ID |
ClientIP | String | IP address of customer, useful if request is initiated from a server. |
GeoLocation | String | Latitude and longitude to record for transaction. Example: "40.7142700,-74.0059700" |
LineItems | LineItem[] | Array of line item details |
ManualKey | Boolean | Set to true to have the terminal prompt for manual card number entry instead of swipe/dip |
PromptTip | Boolean | Set to true to have the terminal prompt the customer for a tip amount. |
PromptCashBack | Boolean | Set to true to have the terminal prompt the customer for cash back. |
PromptSignature | Boolean | Set to false to prevent the terminal from capturing the customer signature. If the terminal supports signature capture, it will be on by default. |
CustomFlow | String | Optional string that controls the sequence of screens presented to the customer during payment. Leave blank to use the default flow. Example: "amount,payment,result" |
SaveCard | Boolean | Set to true to save the payment data to the customer record |
Timeout | Integer | Set the transaction timeout |
BlockOffline | Boolean | Set to true to have the request refused if the device is currently offline |
Parameter | Type | Description |
---|---|---|
TransactionKey | String | Unique identifier for transaction. Can be used to perform actions such as refund and void on a transaction. |
RefNum | String | Numeric sequential transaction reference number. Can be used with older gateway APIs. |
AuthAmount | String | Authroized amount returned from processor. |
AuthCode | String | AuthCode returned from processor. |
ProcRefNum | String | Processor generated transaction reference number (if available). |
Result | String | Result of transaction: Approved, Declined, Error or Partial Approval. |
ResultCode | String | Result code of transaction: A, D, E or P |
IsDuplicate | String | "Y" indicates that a duplicate transaction was detected, the transaction was folded, and the details from the original transaction was returned. |
Error | String | Error message if transaction was a decline or error |
ErrorCode | String | Gateway error code |
ProcRefNum | String | Backend processor reference number (if available) |
AVS | AvsResult | Result of address verification (if manually keyed) |
CVC | CvcResult | Result of card code verification (if manually keyed) |
CreditCard | CreditCard | Information about the credit card used |
Token | String | Reuasable token to charge payment data in a new request |
Parameter | Type | Description |
---|---|---|
EnableEMV | bool | Enable the smart card slot for EMV processing |
EnableDebitMSR | bool | Enable swiped PIN debit transactions |
EnableContactless | bool | Enable the contactless reader for NFC transactions |
TipAdjustAfterAuth | bool | Allow addition of tip after initial authorization. Disables PIN CVM and No CVM. |
Parameter | Type | Description |
---|---|---|
Make | String | Device manufacturer |
Model | String | Model name of terminal |
Revision | String | Firmware version |
Serial | String | Serial number |
Parameter | Type | Description |
---|---|---|
Timeout | int | Sets transaction timeout in seconds. |
EnableStandalone | bool | Allows transactions to be initiated by terminal. |
ShareDevice | bool | Allows terminal to be used by any API key including those belonging to other merchants. |
IDictionary<string, object> request = new Dictionary<string, object>();
request\["batch_key"\]="Example_batch_key";
var response = USAePay.API.Batches.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="batch";
response\["key"\]="ft1m9m5p9wgd9mb";
response\["opened"\]="2019-01-28 17:02:22";
response\["status"\]="closed";
response\["closed"\]="2019-01-28 17:02:36";
response\["scheduled"\]="2019-01-28 17:02:36";
response\["total_amount"\]="3042.48";
response\["total_count"\]="29";
response\["sales_amount"\]="4755.48";
response\["sales_count"\]="18";
response\["voids_amount"\]="17.99";
response\["voids_count"\]="1";
response\["refunds_amount"\]="1713";
response\["refunds_count"\]="10";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="52";
request\["offset"\]="76";
request\["openedlt"\]="67";
request\["openedgt"\]="9";
request\["closedlt"\]="45";
request\["closedgt"\]="67";
request\["openedle"\]="48";
request\["openedge"\]="45";
request\["closedle"\]="21";
request\["closedge"\]="38";
var response = USAePay.API.Batches.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="batch";
dataItem\["key"\]="ft1m9m5p9wgd9mb";
dataItem\["batchnum"\]="2412";
dataItem\["opened"\]="2018-11-24 11:02:02";
dataItem\["closed"\]="2018-11-24 12:01:01";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="1";
IDictionary<string, object> request = new Dictionary<string, object>();
var response = USAePay.API.Batches.Current.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="batch";
response\["key"\]="ft1m9m5p9wgd9mb";
response\["opened"\]="2019-01-28 17:02:22";
response\["status"\]="closed";
response\["closed"\]="2019-01-28 17:02:36";
response\["scheduled"\]="2019-01-28 17:02:36";
response\["total_amount"\]="3042.48";
response\["total_count"\]="29";
response\["sales_amount"\]="4755.48";
response\["sales_count"\]="18";
response\["voids_amount"\]="17.99";
response\["voids_count"\]="1";
response\["refunds_amount"\]="1713";
response\["refunds_count"\]="10";
@GET/batches/:batch_key:/transactions@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["batch_key"\]="Example_batch_key";
request\["limit"\]="44";
request\["offset"\]="71";
request\["return_bin"\]="4";
var response = USAePay.API.Batches.Transactions.Get(request);
@GET/batches/:batch_key:/transactions@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="20";
response\["offset"\]="0";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="transaction";
dataItem\["key"\]="dnfwxwhz5kvnbgb";
dataItem\["refnum"\]="100061";
dataItem\["created"\]="2018-12-04 10:48:44";
dataItem\["trantype_code"\]="S";
dataItem\["trantype"\]="Credit Card Sale";
dataItem\["result_code"\]="A";
dataItem\["result"\]="Approved";
dataItem\["error_code"\]="12";
dataItem\["error"\]="Card Number was not between 13 and 16 digits";
dataItem\["authcode"\]="314407";
dataItem\["status_code"\]="P";
dataItem\["status"\]="Authorized (Pending Settlement)";
dataItem\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
dataItem\["creditcard"\]="creditcard";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
dataItem\["check"\]="check";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
dataItem\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
dataItem\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
dataItem\["batch"\]="batch";
dataItem\["amount"\]="50";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
dataItem\["amount_detail"\]="amount_detail";
dataItem\["ponum"\]="af416fsd5";
dataItem\["invoice"\]="98454685";
dataItem\["orderid"\]="98454685";
dataItem\["description"\]="Antique Pensieve";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
dataItem\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
dataItem\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
dataItem\["lineitems"\]="lineitems";
dataItem\["comments"\]="Powerful magical object. Use with caution.";
dataItem\["tranterm"\]="multilane";
dataItem\["clerk"\]="Madame Malkin";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
dataItem\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
dataItem\["customer"\]="customer";
dataItem\["customer_email"\]="noreply@gmail.com";
IDictionary<string, object> bin = new Dictionary<string, object>();
bin\["bin"\]="444455";
bin\["type"\]="Debit";
bin\["issuer"\]="Visa";
bin\["bank"\]="Chase Bank";
bin\["country"\]="US";
bin\["country_name"\]="United States";
bin\["country_iso"\]="CA";
bin\["location"\]="http://www.jpmorganchase.com";
bin\["phone"\]="USA";
bin\["category"\]="";
dataItem\["bin"\]="bin";
dataItem\["clientip"\]="Madame Malkin";
dataItem\["source_name"\]="Madame Malkin";
data.Add(dataItem);
IDictionary<string, object> dataItem2 = new Dictionary<string, object>();
dataItem2\["type"\]="transaction";
dataItem2\["key"\]="dnfwxwhz5kvnbgb";
dataItem2\["refnum"\]="100061";
dataItem2\["created"\]="2018-12-04 10:48:44";
dataItem2\["trantype_code"\]="S";
dataItem2\["trantype"\]="Credit Card Sale";
dataItem2\["result_code"\]="A";
dataItem2\["result"\]="Approved";
dataItem2\["error_code"\]="12";
dataItem2\["error"\]="Card Number was not between 13 and 16 digits";
dataItem2\["authcode"\]="314407";
dataItem2\["status_code"\]="P";
dataItem2\["status"\]="Authorized (Pending Settlement)";
dataItem2\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
dataItem2\["creditcard"\]="creditcard";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
dataItem2\["check"\]="check";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
dataItem2\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
dataItem2\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
dataItem2\["batch"\]="batch";
dataItem2\["amount"\]="50";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
dataItem2\["amount_detail"\]="amount_detail";
dataItem2\["ponum"\]="af416fsd5";
dataItem2\["invoice"\]="98454685";
dataItem2\["orderid"\]="98454685";
dataItem2\["description"\]="Antique Pensieve";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
dataItem2\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
dataItem2\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem3 = new Dictionary<string, object>();
lineitemsItem3\["name"\]="Antique Pensieve";
lineitemsItem3\["description"\]="See into your past...";
lineitemsItem3\["size"\]="Large";
lineitemsItem3\["color"\]="Bronze";
lineitemsItem3\["cost"\]="450.00";
lineitemsItem3\["list_price"\]="500.00";
lineitemsItem3\["qty"\]="1";
lineitemsItem3\["sku"\]="68453423";
lineitemsItem3\["commoditycode"\]="535";
lineitemsItem3\["discountamount"\]="0";
lineitemsItem3\["discountrate"\]="0";
lineitemsItem3\["taxable"\]="";
lineitemsItem3\["taxamount"\]="45.00";
lineitemsItem3\["taxclass"\]="NA";
lineitemsItem3\["taxrate"\]="10";
lineitemsItem3\["um"\]="EA";
lineitemsItem3\["category"\]="Antiques";
lineitemsItem3\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem3);
IDictionary<string, object> lineitemsItem4 = new Dictionary<string, object>();
lineitemsItem4\["name"\]="Antique Pensieve";
lineitemsItem4\["description"\]="See into your past...";
lineitemsItem4\["size"\]="Large";
lineitemsItem4\["color"\]="Bronze";
lineitemsItem4\["cost"\]="450.00";
lineitemsItem4\["list_price"\]="500.00";
lineitemsItem4\["qty"\]="1";
lineitemsItem4\["sku"\]="68453423";
lineitemsItem4\["commoditycode"\]="535";
lineitemsItem4\["discountamount"\]="0";
lineitemsItem4\["discountrate"\]="0";
lineitemsItem4\["taxable"\]="";
lineitemsItem4\["taxamount"\]="45.00";
lineitemsItem4\["taxclass"\]="NA";
lineitemsItem4\["taxrate"\]="10";
lineitemsItem4\["um"\]="EA";
lineitemsItem4\["category"\]="Antiques";
lineitemsItem4\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem4);
dataItem2\["lineitems"\]="lineitems";
dataItem2\["comments"\]="Powerful magical object. Use with caution.";
dataItem2\["tranterm"\]="multilane";
dataItem2\["clerk"\]="Madame Malkin";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
dataItem2\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
dataItem2\["customer"\]="customer";
dataItem2\["customer_email"\]="noreply@gmail.com";
IDictionary<string, object> bin = new Dictionary<string, object>();
bin\["bin"\]="444455";
bin\["type"\]="Debit";
bin\["issuer"\]="Visa";
bin\["bank"\]="Chase Bank";
bin\["country"\]="US";
bin\["country_name"\]="United States";
bin\["country_iso"\]="CA";
bin\["location"\]="http://www.jpmorganchase.com";
bin\["phone"\]="USA";
bin\["category"\]="";
dataItem2\["bin"\]="bin";
dataItem2\["clientip"\]="Madame Malkin";
dataItem2\["source_name"\]="Madame Malkin";
data.Add(dataItem2);
response\["data"\]="data";
response\["total"\]="1";
@GET/batches/current/transactions@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="93";
request\["offset"\]="70";
request\["return_bin"\]="85";
var response = USAePay.API.Batches.Current.Transactions.Get(request);
@GET/batches/current/transactions@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="20";
response\["offset"\]="0";
IList<IDictionary<string, object>> data23 = new List<IDictionary<string, object>>();
IDictionary<string, object> data23Item = new Dictionary<string, object>();
data23Item\["type"\]="transaction";
data23Item\["key"\]="dnfwxwhz5kvnbgb";
data23Item\["refnum"\]="100061";
data23Item\["created"\]="2018-12-04 10:48:44";
data23Item\["trantype_code"\]="S";
data23Item\["trantype"\]="Credit Card Sale";
data23Item\["result_code"\]="A";
data23Item\["result"\]="Approved";
data23Item\["error_code"\]="12";
data23Item\["error"\]="Card Number was not between 13 and 16 digits";
data23Item\["authcode"\]="314407";
data23Item\["status_code"\]="P";
data23Item\["status"\]="Authorized (Pending Settlement)";
data23Item\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
data23Item\["creditcard"\]="creditcard";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
data23Item\["check"\]="check";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
data23Item\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
data23Item\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
data23Item\["batch"\]="batch";
data23Item\["amount"\]="50";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
data23Item\["amount_detail"\]="amount_detail";
data23Item\["ponum"\]="af416fsd5";
data23Item\["invoice"\]="98454685";
data23Item\["orderid"\]="98454685";
data23Item\["description"\]="Antique Pensieve";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
data23Item\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
data23Item\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
data23Item\["lineitems"\]="lineitems";
data23Item\["comments"\]="Powerful magical object. Use with caution.";
data23Item\["tranterm"\]="multilane";
data23Item\["clerk"\]="Madame Malkin";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
data23Item\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
data23Item\["customer"\]="customer";
data23Item\["customer_email"\]="noreply@gmail.com";
IDictionary<string, object> bin = new Dictionary<string, object>();
bin\["bin"\]="444455";
bin\["type"\]="Debit";
bin\["issuer"\]="Visa";
bin\["bank"\]="Chase Bank";
bin\["country"\]="US";
bin\["country_name"\]="United States";
bin\["country_iso"\]="CA";
bin\["location"\]="http://www.jpmorganchase.com";
bin\["phone"\]="USA";
bin\["category"\]="";
data23Item\["bin"\]="bin";
data23Item\["clientip"\]="Madame Malkin";
data23Item\["source_name"\]="Madame Malkin";
data23.Add(data23Item);
IDictionary<string, object> data23Item2 = new Dictionary<string, object>();
data23Item2\["type"\]="transaction";
data23Item2\["key"\]="dnfwxwhz5kvnbgb";
data23Item2\["refnum"\]="100061";
data23Item2\["created"\]="2018-12-04 10:48:44";
data23Item2\["trantype_code"\]="S";
data23Item2\["trantype"\]="Credit Card Sale";
data23Item2\["result_code"\]="A";
data23Item2\["result"\]="Approved";
data23Item2\["error_code"\]="12";
data23Item2\["error"\]="Card Number was not between 13 and 16 digits";
data23Item2\["authcode"\]="314407";
data23Item2\["status_code"\]="P";
data23Item2\["status"\]="Authorized (Pending Settlement)";
data23Item2\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
data23Item2\["creditcard"\]="creditcard";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
data23Item2\["check"\]="check";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
data23Item2\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
data23Item2\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
data23Item2\["batch"\]="batch";
data23Item2\["amount"\]="50";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
data23Item2\["amount_detail"\]="amount_detail";
data23Item2\["ponum"\]="af416fsd5";
data23Item2\["invoice"\]="98454685";
data23Item2\["orderid"\]="98454685";
data23Item2\["description"\]="Antique Pensieve";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
data23Item2\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
data23Item2\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem3 = new Dictionary<string, object>();
lineitemsItem3\["name"\]="Antique Pensieve";
lineitemsItem3\["description"\]="See into your past...";
lineitemsItem3\["size"\]="Large";
lineitemsItem3\["color"\]="Bronze";
lineitemsItem3\["cost"\]="450.00";
lineitemsItem3\["list_price"\]="500.00";
lineitemsItem3\["qty"\]="1";
lineitemsItem3\["sku"\]="68453423";
lineitemsItem3\["commoditycode"\]="535";
lineitemsItem3\["discountamount"\]="0";
lineitemsItem3\["discountrate"\]="0";
lineitemsItem3\["taxable"\]="";
lineitemsItem3\["taxamount"\]="45.00";
lineitemsItem3\["taxclass"\]="NA";
lineitemsItem3\["taxrate"\]="10";
lineitemsItem3\["um"\]="EA";
lineitemsItem3\["category"\]="Antiques";
lineitemsItem3\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem3);
IDictionary<string, object> lineitemsItem4 = new Dictionary<string, object>();
lineitemsItem4\["name"\]="Antique Pensieve";
lineitemsItem4\["description"\]="See into your past...";
lineitemsItem4\["size"\]="Large";
lineitemsItem4\["color"\]="Bronze";
lineitemsItem4\["cost"\]="450.00";
lineitemsItem4\["list_price"\]="500.00";
lineitemsItem4\["qty"\]="1";
lineitemsItem4\["sku"\]="68453423";
lineitemsItem4\["commoditycode"\]="535";
lineitemsItem4\["discountamount"\]="0";
lineitemsItem4\["discountrate"\]="0";
lineitemsItem4\["taxable"\]="";
lineitemsItem4\["taxamount"\]="45.00";
lineitemsItem4\["taxclass"\]="NA";
lineitemsItem4\["taxrate"\]="10";
lineitemsItem4\["um"\]="EA";
lineitemsItem4\["category"\]="Antiques";
lineitemsItem4\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem4);
data23Item2\["lineitems"\]="lineitems";
data23Item2\["comments"\]="Powerful magical object. Use with caution.";
data23Item2\["tranterm"\]="multilane";
data23Item2\["clerk"\]="Madame Malkin";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
data23Item2\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
data23Item2\["customer"\]="customer";
data23Item2\["customer_email"\]="noreply@gmail.com";
IDictionary<string, object> bin = new Dictionary<string, object>();
bin\["bin"\]="444455";
bin\["type"\]="Debit";
bin\["issuer"\]="Visa";
bin\["bank"\]="Chase Bank";
bin\["country"\]="US";
bin\["country_name"\]="United States";
bin\["country_iso"\]="CA";
bin\["location"\]="http://www.jpmorganchase.com";
bin\["phone"\]="USA";
bin\["category"\]="";
data23Item2\["bin"\]="bin";
data23Item2\["clientip"\]="Madame Malkin";
data23Item2\["source_name"\]="Madame Malkin";
data23.Add(data23Item2);
response\["data23"\]="data23";
response\["total"\]="1";
IDictionary<string, object> request = new Dictionary<string, object>();
var response = USAePay.API.Batches.Current.Close.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="batch";
response\["key"\]="ft1m9m5p9wgd9mb";
response\["batchnum"\]="2412";
response\["opened"\]="2018-11-24 11:02:02";
response\["closed"\]="2018-11-24 12:01:01";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
var response = USAePay.API.Customers.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="customer";
response\["key"\]="nsds9yd1h5kb9y5h";
response\["custid"\]="123456";
response\["company"\]="Weasleys Wizard Wheezes";
response\["first_name"\]="George";
response\["last_name"\]="Weasley";
response\["description"\]="Mischief Managed.";
IList<IDictionary<string, object>> payment_methods = new List<IDictionary<string, object>>();
IDictionary<string, object> payment_methodsItem = new Dictionary<string, object>();
payment_methodsItem\["key"\]="x8KccrxeydHJ4MmT";
payment_methodsItem\["type"\]="customerpaymentmethod";
payment_methodsItem\["method_name"\]="Example method";
payment_methodsItem\["cardholder"\]="Testor Jones";
payment_methodsItem\["expiration"\]="0426"
payment_methodsItem\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
payment_methodsItem\["card_type"\]="Visa";
payment_methods.Add(payment_methodsItem);
IDictionary<string, object> payment_methodsItem1 = new Dictionary<string, object>();
payment_methodsItem1\["key"\]="x8KccrxeydHJ4MmT";
payment_methodsItem1\["type"\]="customerpaymentmethod";
payment_methodsItem1\["method_name"\]="Example method";
payment_methodsItem1\["cardholder"\]="Testor Jones";
payment_methodsItem1\["expiration"\]="0426"
payment_methodsItem1\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
payment_methodsItem1\["card_type"\]="Visa";
payment_methods.Add(payment_methodsItem1);
response\["payment_methods"\]="payment_methods";
IList<IDictionary<string, object>> billing_schedules = new List<IDictionary<string, object>>();
IDictionary<string, object> billing_schedulesItem = new Dictionary<string, object>();
billing_schedulesItem\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem2 = new Dictionary<string, object>();
rulesItem2\["type"\]="billingschedulerule";
rules.Add(rulesItem2);
billing_schedulesItem\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem);
IDictionary<string, object> billing_schedulesItem3 = new Dictionary<string, object>();
billing_schedulesItem3\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem4 = new Dictionary<string, object>();
rulesItem4\["type"\]="billingschedulerule";
rules.Add(rulesItem4);
IDictionary<string, object> rulesItem5 = new Dictionary<string, object>();
rulesItem5\["type"\]="billingschedulerule";
rules.Add(rulesItem5);
billing_schedulesItem3\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem3);
response\["billing_schedules"\]="billing_schedules";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="1";
request\["offset"\]="77";
var response = USAePay.API.Customers.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="customer";
dataItem\["key"\]="nsds9yd1h5kb9y5h";
dataItem\["custid"\]="123456";
dataItem\["company"\]="Weasleys Wizard Wheezes";
dataItem\["first_name"\]="George";
dataItem\["last_name"\]="Weasley";
dataItem\["address"\]="93 Diagon Alley";
dataItem\["address2"\]="Apartment 2";
dataItem\["city"\]="London";
dataItem\["state"\]="Greater London";
dataItem\["postalcode"\]="WC2H 0AW";
dataItem\["country"\]="Great Britain";
dataItem\["phone"\]="747-3733";
dataItem\["fax"\]="584-4537";
dataItem\["email"\]="noreply@mugglenet.com";
dataItem\["url"\]="https://www.pottermore.com/";
dataItem\["notes"\]="Born on April fools day.";
dataItem\["description"\]="Mischief Managed.";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="1";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custid"\]="123456";
request\["company"\]="Weasleys Wizard Wheezes";
request\["first_name"\]="George";
request\["last_name"\]="Weasley";
request\["description"\]="Mischief Managed.";
IList<IDictionary<string, object>> payment_methods = new List<IDictionary<string, object>>();
IDictionary<string, object> payment_methodsItem = new Dictionary<string, object>();
payment_methodsItem\["cardholder"\]="Fillius Flitwick";
payment_methodsItem\["expiration"\]="0426"
payment_methodsItem\["number"\]="4000100011112224";
payment_methodsItem\["pay_type"\]="cc";
payment_methods.Add(payment_methodsItem);
IDictionary<string, object> payment_methodsItem1 = new Dictionary<string, object>();
payment_methodsItem1\["cardholder"\]="Fillius Flitwick";
payment_methodsItem1\["expiration"\]="0426"
payment_methodsItem1\["number"\]="4000100011112224";
payment_methodsItem1\["pay_type"\]="cc";
payment_methods.Add(payment_methodsItem1);
request\["payment_methods"\]="payment_methods";
IList<IDictionary<string, object>> billing_schedules = new List<IDictionary<string, object>>();
IDictionary<string, object> billing_schedulesItem = new Dictionary<string, object>();
billing_schedulesItem\["amount"\]="8";
billing_schedulesItem\["enabled"\]="1";
IList<IDictionary<string, object>> rules69 = new List<IDictionary<string, object>>();
IDictionary<string, object> rules69Item = new Dictionary<string, object>();
rules69Item\["day_offset"\]="3";
rules69Item\["subject"\]="Day";
rules69.Add(rules69Item);
IDictionary<string, object> rules69Item2 = new Dictionary<string, object>();
rules69Item2\["day_offset"\]="3";
rules69Item2\["subject"\]="Day";
rules69.Add(rules69Item2);
billing_schedulesItem\["rules69"\]="rules69";
billing_schedules.Add(billing_schedulesItem);
IDictionary<string, object> billing_schedulesItem3 = new Dictionary<string, object>();
billing_schedulesItem3\["amount"\]="8";
billing_schedulesItem3\["enabled"\]="1";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["day_offset"\]="3";
rulesItem\["subject"\]="Day";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem4 = new Dictionary<string, object>();
rulesItem4\["day_offset"\]="3";
rulesItem4\["subject"\]="Day";
rules.Add(rulesItem4);
billing_schedulesItem3\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem3);
request\["billing_schedules"\]="billing_schedules";
var response = USAePay.API.Customers.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="customer";
response\["key"\]="nsds9yd1h5kb9y5h";
response\["custid"\]="123456";
response\["company"\]="Weasleys Wizard Wheezes";
response\["first_name"\]="George";
response\["last_name"\]="Weasley";
response\["description"\]="Mischief Managed.";
IList<IDictionary<string, object>> payment_methods = new List<IDictionary<string, object>>();
IDictionary<string, object> payment_methodsItem = new Dictionary<string, object>();
payment_methodsItem\["key"\]="x8KccrxeydHJ4MmT";
payment_methodsItem\["type"\]="customerpaymentmethod";
payment_methodsItem\["method_name"\]="Example method";
payment_methodsItem\["cardholder"\]="Testor Jones";
payment_methodsItem\["expiration"\]="0426"
payment_methodsItem\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
payment_methodsItem\["card_type"\]="Visa";
payment_methods.Add(payment_methodsItem);
IDictionary<string, object> payment_methodsItem1 = new Dictionary<string, object>();
payment_methodsItem1\["key"\]="x8KccrxeydHJ4MmT";
payment_methodsItem1\["type"\]="customerpaymentmethod";
payment_methodsItem1\["method_name"\]="Example method";
payment_methodsItem1\["cardholder"\]="Testor Jones";
payment_methodsItem1\["expiration"\]="0426"
payment_methodsItem1\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
payment_methodsItem1\["card_type"\]="Visa";
payment_methods.Add(payment_methodsItem1);
response\["payment_methods"\]="payment_methods";
IList<IDictionary<string, object>> billing_schedules = new List<IDictionary<string, object>>();
IDictionary<string, object> billing_schedulesItem = new Dictionary<string, object>();
billing_schedulesItem\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem2 = new Dictionary<string, object>();
rulesItem2\["type"\]="billingschedulerule";
rules.Add(rulesItem2);
billing_schedulesItem\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem);
IDictionary<string, object> billing_schedulesItem3 = new Dictionary<string, object>();
billing_schedulesItem3\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem4 = new Dictionary<string, object>();
rulesItem4\["type"\]="billingschedulerule";
rules.Add(rulesItem4);
IDictionary<string, object> rulesItem5 = new Dictionary<string, object>();
rulesItem5\["type"\]="billingschedulerule";
rules.Add(rulesItem5);
billing_schedulesItem3\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem3);
response\["billing_schedules"\]="billing_schedules";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
var response = USAePay.API.Customers.Delete(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["custid"\]="123456";
request\["company"\]="Weasleys Wizard Wheezes";
request\["first_name"\]="George";
request\["last_name"\]="Weasley";
request\["description"\]="Mischief Managed.";
IList<IDictionary<string, object>> payment_methods = new List<IDictionary<string, object>>();
IDictionary<string, object> payment_methodsItem = new Dictionary<string, object>();
payment_methodsItem\["cardholder"\]="Fillius Flitwick";
payment_methodsItem\["expiration"\]="0426"
payment_methodsItem\["number"\]="4000100011112224";
payment_methodsItem\["pay_type"\]="cc";
payment_methods.Add(payment_methodsItem);
IDictionary<string, object> payment_methodsItem1 = new Dictionary<string, object>();
payment_methodsItem1\["cardholder"\]="Fillius Flitwick";
payment_methodsItem1\["expiration"\]="0426"
payment_methodsItem1\["number"\]="4000100011112224";
payment_methodsItem1\["pay_type"\]="cc";
payment_methods.Add(payment_methodsItem1);
request\["payment_methods"\]="payment_methods";
IList<IDictionary<string, object>> billing_schedules = new List<IDictionary<string, object>>();
IDictionary<string, object> billing_schedulesItem = new Dictionary<string, object>();
billing_schedulesItem\["amount"\]="8";
billing_schedulesItem\["enabled"\]="1";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["day_offset"\]="3";
rulesItem\["subject"\]="Day";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem2 = new Dictionary<string, object>();
rulesItem2\["day_offset"\]="3";
rulesItem2\["subject"\]="Day";
rules.Add(rulesItem2);
billing_schedulesItem\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem);
IDictionary<string, object> billing_schedulesItem3 = new Dictionary<string, object>();
billing_schedulesItem3\["amount"\]="8";
billing_schedulesItem3\["enabled"\]="1";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem4 = new Dictionary<string, object>();
rulesItem4\["day_offset"\]="3";
rulesItem4\["subject"\]="Day";
rules.Add(rulesItem4);
IDictionary<string, object> rulesItem5 = new Dictionary<string, object>();
rulesItem5\["day_offset"\]="3";
rulesItem5\["subject"\]="Day";
rules.Add(rulesItem5);
billing_schedulesItem3\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem3);
request\["billing_schedules"\]="billing_schedules";
var response = USAePay.API.Customers.Put(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="customer";
response\["key"\]="nsds9yd1h5kb9y5h";
response\["custid"\]="123456";
response\["company"\]="Weasleys Wizard Wheezes";
response\["first_name"\]="George";
response\["last_name"\]="Weasley";
response\["description"\]="Mischief Managed.";
IList<IDictionary<string, object>> payment_methods = new List<IDictionary<string, object>>();
IDictionary<string, object> payment_methodsItem = new Dictionary<string, object>();
payment_methodsItem\["key"\]="x8KccrxeydHJ4MmT";
payment_methodsItem\["type"\]="customerpaymentmethod";
payment_methodsItem\["method_name"\]="Example method";
payment_methodsItem\["cardholder"\]="Testor Jones";
payment_methodsItem\["expiration"\]="0426"
payment_methodsItem\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
payment_methodsItem\["card_type"\]="Visa";
payment_methods.Add(payment_methodsItem);
IDictionary<string, object> payment_methodsItem1 = new Dictionary<string, object>();
payment_methodsItem1\["key"\]="x8KccrxeydHJ4MmT";
payment_methodsItem1\["type"\]="customerpaymentmethod";
payment_methodsItem1\["method_name"\]="Example method";
payment_methodsItem1\["cardholder"\]="Testor Jones";
payment_methodsItem1\["expiration"\]="0426"
payment_methodsItem1\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
payment_methodsItem1\["card_type"\]="Visa";
payment_methods.Add(payment_methodsItem1);
response\["payment_methods"\]="payment_methods";
IList<IDictionary<string, object>> billing_schedules = new List<IDictionary<string, object>>();
IDictionary<string, object> billing_schedulesItem = new Dictionary<string, object>();
billing_schedulesItem\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem2 = new Dictionary<string, object>();
rulesItem2\["type"\]="billingschedulerule";
rules.Add(rulesItem2);
billing_schedulesItem\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem);
IDictionary<string, object> billing_schedulesItem3 = new Dictionary<string, object>();
billing_schedulesItem3\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem4 = new Dictionary<string, object>();
rulesItem4\["type"\]="billingschedulerule";
rules.Add(rulesItem4);
IDictionary<string, object> rulesItem5 = new Dictionary<string, object>();
rulesItem5\["type"\]="billingschedulerule";
rules.Add(rulesItem5);
billing_schedulesItem3\["rules"\]="rules";
billing_schedules.Add(billing_schedulesItem3);
response\["billing_schedules"\]="billing_schedules";
IDictionary<string, object> request = new Dictionary<string, object>();
var response = USAePay.API.Customers.Enable.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
IDictionary<string, object> request = new Dictionary<string, object>();
var response = USAePay.API.Customers.Disable.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@GET/customers/:custkey:/billing_schedules/:billing_schedule_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
var response = USAePay.API.Customers.Billing_schedules.Get(request);
@GET/customers/:custkey:/billing_schedules/:billing_schedule_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem1 = new Dictionary<string, object>();
rulesItem1\["type"\]="billingschedulerule";
rules.Add(rulesItem1);
response\["rules"\]="rules";
@GET/customers/:custkey:/billing_schedules@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
var response = USAePay.API.Customers.Billing_schedules.Get(request);
@GET/customers/:custkey:/billing_schedules@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem1 = new Dictionary<string, object>();
rulesItem1\["type"\]="billingschedulerule";
rules.Add(rulesItem1);
dataItem\["rules"\]="rules";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="1";
@POST/customers/:custkey:/billing_schedules@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
IList<IDictionary<string, object>> CustomerSchedules = new List<IDictionary<string, object>>();
IDictionary<string, object> CustomerSchedulesItem = new Dictionary<string, object>();
CustomerSchedulesItem\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem1 = new Dictionary<string, object>();
rulesItem1\["type"\]="billingschedulerule";
rules.Add(rulesItem1);
CustomerSchedulesItem\["rules"\]="rules";
CustomerSchedules.Add(CustomerSchedulesItem);
request\["CustomerSchedules"\]="CustomerSchedules";
var response = USAePay.API.Customers.Billing_schedules.Post(request);
@POST/customers/:custkey:/billing_schedules@
IList<IDictionary<string, object>> response = new List<IDictionary<string, object>>();
IDictionary<string, object> responseItem = new Dictionary<string, object>();
responseItem\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem1 = new Dictionary<string, object>();
rulesItem1\["type"\]="billingschedulerule";
rules.Add(rulesItem1);
responseItem\["rules"\]="rules";
response.Add(responseItem);
@DELETE/customers/:custkey:/billing_schedules/:billing_schedule_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
var response = USAePay.API.Customers.Billing_schedules.Delete(request);
@DELETE/customers/:custkey:/billing_schedules/:billing_schedule_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@PUT/customers/:custkey:/billing_schedules/:billing_schedule_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
request\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem1 = new Dictionary<string, object>();
rulesItem1\["type"\]="billingschedulerule";
rules.Add(rulesItem1);
request\["rules"\]="rules";
var response = USAePay.API.Customers.Billing_schedules.Put(request);
@PUT/customers/:custkey:/billing_schedules/:billing_schedule_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="billingschedule";
IList<IDictionary<string, object>> rules = new List<IDictionary<string, object>>();
IDictionary<string, object> rulesItem = new Dictionary<string, object>();
rulesItem\["type"\]="billingschedulerule";
rules.Add(rulesItem);
IDictionary<string, object> rulesItem1 = new Dictionary<string, object>();
rulesItem1\["type"\]="billingschedulerule";
rules.Add(rulesItem1);
response\["rules"\]="rules";
@GET/customers/:custkey:/payment_methods/:paymethod_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["paymethod_key"\]="Example_paymethod_key";
var response = USAePay.API.Customers.Payment_methods.Get(request);
@GET/customers/:custkey:/payment_methods/:paymethod_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["key"\]="x8KccrxeydHJ4MmT";
response\["type"\]="customerpaymentmethod";
response\["method_name"\]="Example method";
response\["cardholder"\]="Testor Jones";
response\["expiration"\]="0426"
response\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
response\["card_type"\]="Visa";
@GET/customers/:custkey:/payment_methods@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
var response = USAePay.API.Customers.Payment_methods.Get(request);
@GET/customers/:custkey:/payment_methods@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["key"\]="x8KccrxeydHJ4MmT";
dataItem\["type"\]="customerpaymentmethod";
dataItem\["method_name"\]="Example method";
dataItem\["cardholder"\]="Testor Jones";
dataItem\["expiration"\]="0426"
dataItem\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
dataItem\["card_type"\]="Visa";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="1";
@POST/customers/:custkey:/payment_methods@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
IList<IDictionary<string, object>> CustomerPaymentMethodRequests = new List<IDictionary<string, object>>();
IDictionary<string, object> CustomerPaymentMethodRequestsItem = new Dictionary<string, object>();
CustomerPaymentMethodRequestsItem\["cardholder"\]="Fillius Flitwick";
CustomerPaymentMethodRequestsItem\["expiration"\]="0426"
CustomerPaymentMethodRequestsItem\["number"\]="4000100011112224";
CustomerPaymentMethodRequestsItem\["pay_type"\]="cc";
CustomerPaymentMethodRequests.Add(CustomerPaymentMethodRequestsItem);
request\["CustomerPaymentMethodRequests"\]="CustomerPaymentMethodRequests";
var response = USAePay.API.Customers.Payment_methods.Post(request);
@POST/customers/:custkey:/payment_methods@
IList<IDictionary<string, object>> response = new List<IDictionary<string, object>>();
IDictionary<string, object> responseItem = new Dictionary<string, object>();
responseItem\["key"\]="x8KccrxeydHJ4MmT";
responseItem\["type"\]="customerpaymentmethod";
responseItem\["method_name"\]="Example method";
responseItem\["cardholder"\]="Testor Jones";
responseItem\["expiration"\]="0426"
responseItem\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
responseItem\["card_type"\]="Visa";
response.Add(responseItem);
@DELETE/customers/:custkey:/payment_methods/:paymethod_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["paymethod_key"\]="Example_paymethod_key";
var response = USAePay.API.Customers.Payment_methods.Delete(request);
@DELETE/customers/:custkey:/payment_methods/:paymethod_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@PUT/customers/:custkey:/payment_methods/:paymethod_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["paymethod_key"\]="Example_paymethod_key";
request\["cardholder"\]="Fillius Flitwick";
request\["expiration"\]="0426"
request\["number"\]="40001000111^date:MMYY,+4Y4";
request\["pay_type"\]="cc";
var response = USAePay.API.Customers.Payment_methods.Put(request);
@PUT/customers/:custkey:/payment_methods/:paymethod_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["key"\]="x8KccrxeydHJ4MmT";
response\["type"\]="customerpaymentmethod";
response\["method_name"\]="Example method";
response\["cardholder"\]="Testor Jones";
response\["expiration"\]="0426"
response\["ccnum4last"\]="xxxxxxxxxxxxxx7779";
response\["card_type"\]="Visa";
@GET/customers/:custkey:/transactions@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
var response = USAePay.API.Customers.Transactions.Get(request);
@GET/customers/:custkey:/transactions@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="transaction";
dataItem\["key"\]="dnfwxwhz5kvnbgb";
dataItem\["refnum"\]="100061";
dataItem\["created"\]="2018-12-04 10:48:44";
dataItem\["trantype_code"\]="S";
dataItem\["trantype"\]="Credit Card Sale";
dataItem\["result_code"\]="A";
dataItem\["result"\]="Approved";
dataItem\["error_code"\]="12";
dataItem\["error"\]="Card Number was not between 13 and 16 digits";
dataItem\["authcode"\]="314407";
dataItem\["status_code"\]="P";
dataItem\["status"\]="Authorized (Pending Settlement)";
dataItem\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
dataItem\["creditcard"\]="creditcard";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
dataItem\["check"\]="check";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
dataItem\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
dataItem\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
dataItem\["batch"\]="batch";
dataItem\["amount"\]="50";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
dataItem\["amount_detail"\]="amount_detail";
dataItem\["ponum"\]="af416fsd5";
dataItem\["invoice"\]="98454685";
dataItem\["orderid"\]="98454685";
dataItem\["description"\]="Antique Pensieve";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
dataItem\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
dataItem\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
dataItem\["lineitems"\]="lineitems";
dataItem\["comments"\]="Powerful magical object. Use with caution.";
dataItem\["tranterm"\]="multilane";
dataItem\["clerk"\]="Madame Malkin";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
dataItem\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
dataItem\["customer"\]="customer";
dataItem\["customer_email"\]="noreply@gmail.com";
IDictionary<string, object> bin = new Dictionary<string, object>();
bin\["bin"\]="444455";
bin\["type"\]="Debit";
bin\["issuer"\]="Visa";
bin\["bank"\]="Chase Bank";
bin\["country"\]="US";
bin\["country_name"\]="United States";
bin\["country_iso"\]="CA";
bin\["location"\]="http://www.jpmorganchase.com";
bin\["phone"\]="USA";
bin\["category"\]="";
dataItem\["bin"\]="bin";
dataItem\["clientip"\]="Madame Malkin";
dataItem\["source_name"\]="Madame Malkin";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="42";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
request\["billing_rule_key"\]="Example_billing_rule_key";
var response = USAePay.API.Customers.Billing_schedules.Billing_schedule_rules.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="billingschedulerule";
@GET/customers/:custkey:/billing_schedules/:billing_schedule_key:/billing_schedule_rules@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
var response = USAePay.API.Customers.Billing_schedules.Billing_schedule_rules.Get(request);
@GET/customers/:custkey:/billing_schedules/:billing_schedule_key:/billing_schedule_rules@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="billingschedulerule";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="1";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
request\["billing_rule_key"\]="Example_billing_rule_key";
var response = USAePay.API.Customers.Billing_schedules.Billing_schedule_rules.Delete(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
request\["billing_rule_key"\]="Example_billing_rule_key";
request\["type"\]="billingschedulerule";
var response = USAePay.API.Customers.Billing_schedules.Billing_schedule_rules.Put(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="billingschedulerule";
@DELETE/customers/:custkey:/billing_schedules/:billing_schedule_key:/billing_schedule_rules/bulk@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["custkey"\]="Example_custkey";
request\["billing_schedule_key"\]="Example_billing_schedule_key";
IList<IDictionary<string, object>> Keys = new List<IDictionary<string, object>>(); Keys.Add("Example_delKey");
request\["Keys"\]="Keys";
var response = USAePay.API.Customers.Billing_schedules.Billing_schedule_rules.Bulk.Delete(request);
@DELETE/customers/:custkey:/billing_schedules/:billing_schedule_key:/billing_schedule_rules/bulk@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["invoice_key"\]="Example_invoice_key";
var response = USAePay.API.Invoices.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="invoice";
response\["status"\]="Q";
response\["invoice_number"\]="abc1234";
response\["invoice_date"\]="2019-10-02";
response\["due_date"\]="2020-10-11";
response\["nontaxable"\]="true";
response\["customer_email"\]="example@test.com";
IDictionary<string, object> customer_billing = new Dictionary<string, object>();
customer_billing\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_billing\["street"\]="123 Astronomy Tower";
customer_billing\["postalcode"\]="10005";
response\["customer_billing"\]="customer_billing";
IDictionary<string, object> customer_shipping = new Dictionary<string, object>();
customer_shipping\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_shipping\["street"\]="123 Astronomy Tower";
customer_shipping\["postalcode"\]="10005";
response\["customer_shipping"\]="customer_shipping";
response\["merchant_email"\]="Example@test.com";
response\["merchant_address"\]="123 Main St";
response\["merchant_phone"\]="111-222-3333";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
response\["lineitems"\]="lineitems";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="78";
request\["offset"\]="37";
var response = USAePay.API.Invoices.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="invoice";
dataItem\["status"\]="Q";
dataItem\["invoice_number"\]="abc1234";
dataItem\["invoice_date"\]="2019-10-02";
dataItem\["due_date"\]="2020-10-11";
dataItem\["nontaxable"\]="true";
dataItem\["customer_email"\]="example@test.com";
IDictionary<string, object> customer_billing = new Dictionary<string, object>();
customer_billing\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_billing\["street"\]="123 Astronomy Tower";
customer_billing\["postalcode"\]="10005";
dataItem\["customer_billing"\]="customer_billing";
IDictionary<string, object> customer_shipping = new Dictionary<string, object>();
customer_shipping\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_shipping\["street"\]="123 Astronomy Tower";
customer_shipping\["postalcode"\]="10005";
dataItem\["customer_shipping"\]="customer_shipping";
dataItem\["merchant_email"\]="Example@test.com";
dataItem\["merchant_address"\]="123 Main St";
dataItem\["merchant_phone"\]="111-222-3333";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
dataItem\["lineitems"\]="lineitems";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="42";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["invoice_number"\]="abc1234";
request\["due_date"\]="2020-10-11";
request\["nontaxable"\]="true";
request\["customer_email"\]="example@test.com";
IDictionary<string, object> customer_billing = new Dictionary<string, object>();
customer_billing\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_billing\["street"\]="123 Astronomy Tower";
customer_billing\["postalcode"\]="10005";
request\["customer_billing"\]="customer_billing";
IDictionary<string, object> customer_shipping = new Dictionary<string, object>();
customer_shipping\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_shipping\["street"\]="123 Astronomy Tower";
customer_shipping\["postalcode"\]="10005";
request\["customer_shipping"\]="customer_shipping";
request\["merchant_email"\]="Example@test.com";
request\["merchant_address"\]="123 Main St";
request\["merchant_phone"\]="111-222-3333";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
request\["lineitems"\]="lineitems";
var response = USAePay.API.Invoices.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="invoice";
response\["status"\]="Q";
response\["invoice_number"\]="abc1234";
response\["invoice_date"\]="2019-10-02";
response\["due_date"\]="2020-10-11";
response\["nontaxable"\]="true";
response\["customer_email"\]="example@test.com";
IDictionary<string, object> customer_billing = new Dictionary<string, object>();
customer_billing\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_billing\["street"\]="123 Astronomy Tower";
customer_billing\["postalcode"\]="10005";
response\["customer_billing"\]="customer_billing";
IDictionary<string, object> customer_shipping = new Dictionary<string, object>();
customer_shipping\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_shipping\["street"\]="123 Astronomy Tower";
customer_shipping\["postalcode"\]="10005";
response\["customer_shipping"\]="customer_shipping";
response\["merchant_email"\]="Example@test.com";
response\["merchant_address"\]="123 Main St";
response\["merchant_phone"\]="111-222-3333";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
response\["lineitems"\]="lineitems";
@DELETE/invoices/:invoice_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["invoice_key"\]="Example_invoice_key";
var response = USAePay.API.Invoices.Delete(request);
@DELETE/invoices/:invoice_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["invoice_key"\]="Example_invoice_key";
request\["invoice_number"\]="abc1234";
request\["due_date"\]="2020-10-11";
request\["nontaxable"\]="true";
request\["customer_email"\]="example@test.com";
IDictionary<string, object> customer_billing = new Dictionary<string, object>();
customer_billing\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_billing\["street"\]="123 Astronomy Tower";
customer_billing\["postalcode"\]="10005";
request\["customer_billing"\]="customer_billing";
IDictionary<string, object> customer_shipping = new Dictionary<string, object>();
customer_shipping\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_shipping\["street"\]="123 Astronomy Tower";
customer_shipping\["postalcode"\]="10005";
request\["customer_shipping"\]="customer_shipping";
request\["merchant_email"\]="Example@test.com";
request\["merchant_address"\]="123 Main St";
request\["merchant_phone"\]="111-222-3333";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
request\["lineitems"\]="lineitems";
var response = USAePay.API.Invoices.Put(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="invoice";
response\["status"\]="Q";
response\["invoice_number"\]="abc1234";
response\["invoice_date"\]="2019-10-02";
response\["due_date"\]="2020-10-11";
response\["nontaxable"\]="true";
response\["customer_email"\]="example@test.com";
IDictionary<string, object> customer_billing = new Dictionary<string, object>();
customer_billing\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_billing\["street"\]="123 Astronomy Tower";
customer_billing\["postalcode"\]="10005";
response\["customer_billing"\]="customer_billing";
IDictionary<string, object> customer_shipping = new Dictionary<string, object>();
customer_shipping\["company"\]="Hogwarts School of Witchcraft and Wizardry";
customer_shipping\["street"\]="123 Astronomy Tower";
customer_shipping\["postalcode"\]="10005";
response\["customer_shipping"\]="customer_shipping";
response\["merchant_email"\]="Example@test.com";
response\["merchant_address"\]="123 Main St";
response\["merchant_phone"\]="111-222-3333";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
IDictionary<string, object> lineitemsItem1 = new Dictionary<string, object>();
lineitemsItem1\["name"\]="Antique Pensieve";
lineitemsItem1\["description"\]="See into your past...";
lineitemsItem1\["size"\]="Large";
lineitemsItem1\["color"\]="Bronze";
lineitemsItem1\["cost"\]="450.00";
lineitemsItem1\["list_price"\]="500.00";
lineitemsItem1\["qty"\]="1";
lineitemsItem1\["sku"\]="68453423";
lineitemsItem1\["commoditycode"\]="535";
lineitemsItem1\["discountamount"\]="0";
lineitemsItem1\["discountrate"\]="0";
lineitemsItem1\["taxable"\]="";
lineitemsItem1\["taxamount"\]="45.00";
lineitemsItem1\["taxclass"\]="NA";
lineitemsItem1\["taxrate"\]="10";
lineitemsItem1\["um"\]="EA";
lineitemsItem1\["category"\]="Antiques";
lineitemsItem1\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem1);
response\["lineitems"\]="lineitems";
IDictionary<string, object> request = new Dictionary<string, object>();
IList<IDictionary<string, object>> Keys = new List<IDictionary<string, object>>(); Keys.Add("example_key");
request\["Keys"\]="Keys";
var response = USAePay.API.Invoices.Bulk.Delete(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
IDictionary<string, object> request = new Dictionary<string, object>();
var response = USAePay.API.Invoices.Defaults.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["merchant_email"\]="Example@test.com";
response\["merchant_address"\]="123 Main St";
response\["merchant_phone"\]="111-222-3333";
IDictionary<string, object> request = new Dictionary<string, object>();
var response = USAePay.API.Invoices.Nextnum.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
IDictionary<string, object> request = new Dictionary<string, object>();
var response = USAePay.API.Invoices.Columns.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
@POST/invoices/:invoice_key:/send@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["invoice_key"\]="Example_invoice_key";
var response = USAePay.API.Invoices.Send.Post(request);
@POST/invoices/:invoice_key:/send@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@POST/invoices/:invoice_key:/cancel@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["invoice_key"\]="Example_invoice_key";
var response = USAePay.API.Invoices.Cancel.Post(request);
@POST/invoices/:invoice_key:/cancel@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@GET/invoices/:invoice_key:/payments@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["invoice_key"\]="Example_invoice_key";
request\["limit"\]="86";
request\["offset"\]="12";
var response = USAePay.API.Invoices.Payments.Get(request);
@GET/invoices/:invoice_key:/payments@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="42";
IDictionary<string, object> request = new Dictionary<string, object>();
IList<IDictionary<string, object>> Keys = new List<IDictionary<string, object>>(); Keys.Add("Example_key");
request\["Keys"\]="Keys";
var response = USAePay.API.Invoices.Bulk.Send.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@GET/paymentengine/devices/:devicekey:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
var response = USAePay.API.Paymentengine.Devices.Get(request);
@GET/paymentengine/devices/:devicekey:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="device";
response\["key"\]="sa_WKwzyQawBG0RMy0XpDGFXb6pXA32r";
response\["apikeyid"\]="ntC8nP31Moh0wtvYT";
response\["terminal_type"\]="standalone";
response\["status"\]="ntC8nP31Moh0wtvYT";
response\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
response\["settings"\]="settings";
IDictionary<string, object> terminal_info = new Dictionary<string, object>();
terminal_info\["make"\]="Castle";
terminal_info\["model"\]="Vega3000";
terminal_info\["revision"\]="18043001-0055.00";
terminal_info\["serial"\]="011118170300198";
terminal_info\["key_pin"\]="FFFF5B04";
terminal_info\["key_pan"\]="FF908A";
response\["terminal_info"\]="terminal_info";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
response\["terminal_config"\]="terminal_config";
response\["pairing_code"\]="690520";
response\["expiration"\]="2019-10-29 11:59:28";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="55";
request\["offset"\]="100";
var response = USAePay.API.Paymentengine.Devices.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="device";
dataItem\["key"\]="sa_WKwzyQawBG0RMy0XpDGFXb6pXA32r";
dataItem\["apikeyid"\]="ntC8nP31Moh0wtvYT";
dataItem\["terminal_type"\]="standalone";
dataItem\["status"\]="ntC8nP31Moh0wtvYT";
dataItem\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
dataItem\["settings"\]="settings";
IDictionary<string, object> terminal_info = new Dictionary<string, object>();
terminal_info\["make"\]="Castle";
terminal_info\["model"\]="Vega3000";
terminal_info\["revision"\]="18043001-0055.00";
terminal_info\["serial"\]="011118170300198";
terminal_info\["key_pin"\]="FFFF5B04";
terminal_info\["key_pan"\]="FF908A";
dataItem\["terminal_info"\]="terminal_info";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
dataItem\["terminal_config"\]="terminal_config";
dataItem\["pairing_code"\]="690520";
dataItem\["expiration"\]="2019-10-29 11:59:28";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="42";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["terminal_type"\]="standalone";
request\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
request\["settings"\]="settings";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
request\["terminal_config"\]="terminal_config";
var response = USAePay.API.Paymentengine.Devices.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="device";
response\["key"\]="sa_WKwzyQawBG0RMy0XpDGFXb6pXA32r";
response\["apikeyid"\]="ntC8nP31Moh0wtvYT";
response\["terminal_type"\]="standalone";
response\["status"\]="ntC8nP31Moh0wtvYT";
response\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
response\["settings"\]="settings";
IDictionary<string, object> terminal_info = new Dictionary<string, object>();
terminal_info\["make"\]="Castle";
terminal_info\["model"\]="Vega3000";
terminal_info\["revision"\]="18043001-0055.00";
terminal_info\["serial"\]="011118170300198";
terminal_info\["key_pin"\]="FFFF5B04";
terminal_info\["key_pan"\]="FF908A";
response\["terminal_info"\]="terminal_info";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
response\["terminal_config"\]="terminal_config";
response\["pairing_code"\]="690520";
response\["expiration"\]="2019-10-29 11:59:28";
@DELETE/paymentengine/devices/:devicekey:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
var response = USAePay.API.Paymentengine.Devices.Delete(request);
@DELETE/paymentengine/devices/:devicekey:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@PUT/paymentengine/devices/:devicekey:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
request\["terminal_type"\]="standalone";
request\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
request\["settings"\]="settings";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
request\["terminal_config"\]="terminal_config";
var response = USAePay.API.Paymentengine.Devices.Put(request);
@PUT/paymentengine/devices/:devicekey:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="device";
response\["key"\]="sa_WKwzyQawBG0RMy0XpDGFXb6pXA32r";
response\["apikeyid"\]="ntC8nP31Moh0wtvYT";
response\["terminal_type"\]="standalone";
response\["status"\]="ntC8nP31Moh0wtvYT";
response\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
response\["settings"\]="settings";
IDictionary<string, object> terminal_info = new Dictionary<string, object>();
terminal_info\["make"\]="Castle";
terminal_info\["model"\]="Vega3000";
terminal_info\["revision"\]="18043001-0055.00";
terminal_info\["serial"\]="011118170300198";
terminal_info\["key_pin"\]="FFFF5B04";
terminal_info\["key_pan"\]="FF908A";
response\["terminal_info"\]="terminal_info";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
response\["terminal_config"\]="terminal_config";
response\["pairing_code"\]="690520";
response\["expiration"\]="2019-10-29 11:59:28";
@POST/paymentengine/payrequests@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="sa_YdebDV6I2q0MfWV8kPDvQkHEvUjpA";
request\["command"\]="sale";
request\["amount"\]="2.11";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
request\["amount_detail"\]="amount_detail";
request\["timeout"\]="150";
request\["block_offline"\]="true";
request\["ignore_duplicate"\]="true";
request\["save_card"\]="true";
request\["manual_key"\]="true";
request\["prompt_tip"\]="true";
request\["invoice"\]="123456";
request\["ponum"\]="987654321";
request\["orderid"\]="12345678";
request\["description"\]="sample description";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
request\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
request\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
request\["lineitems"\]="lineitems";
var response = USAePay.API.Paymentengine.Payrequests.Post(request);
@POST/paymentengine/payrequests@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="request";
response\["key"\]="pr_3mW7rstrdA0Sp32LW9MN3djCITAhx";
response\["expiration"\]="2020-07-08 16:40:48";
response\["status"\]="sent to device";
IDictionary<string, object> transaction = new Dictionary<string, object>();
transaction\["type"\]="transaction";
transaction\["key"\]="dnfwxwhz5kvnbgb";
transaction\["refnum"\]="100061";
transaction\["created"\]="2018-12-04 10:48:44";
transaction\["is_duplicate"\]="N";
transaction\["result_code"\]="A";
transaction\["result"\]="Approved";
transaction\["authcode"\]="314407";
transaction\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
transaction\["creditcard"\]="creditcard";
transaction\["invoice"\]="98454685";
transaction\["orderid"\]="4556432";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
transaction\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
transaction\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
transaction\["batch"\]="batch";
transaction\["auth_amount"\]="500.00";
transaction\["trantype"\]="Credit Card Sale";
transaction\["iccdata"\]="";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
transaction\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
transaction\["customer"\]="customer";
IDictionary<string, object> savedcard = new Dictionary<string, object>();
savedcard\["type"\]="Visa";
savedcard\["key"\]="tyet-xk8x-vpj4-7swq";
savedcard\["cardnumber"\]="4000xxxxxxxx2224";
transaction\["savedcard"\]="savedcard";
response\["transaction"\]="transaction";
response\["complete"\]="sent to device";
@GET/paymentengine/payrequests/:requestkey:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["requestkey"\]="Example_requestkey";
var response = USAePay.API.Paymentengine.Payrequests.Get(request);
@GET/paymentengine/payrequests/:requestkey:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="request";
response\["key"\]="pr_3mW7rstrdA0Sp32LW9MN3djCITAhx";
response\["expiration"\]="2020-07-08 16:40:48";
response\["status"\]="sent to device";
IDictionary<string, object> transaction = new Dictionary<string, object>();
transaction\["type"\]="transaction";
transaction\["key"\]="dnfwxwhz5kvnbgb";
transaction\["refnum"\]="100061";
transaction\["created"\]="2018-12-04 10:48:44";
transaction\["is_duplicate"\]="N";
transaction\["result_code"\]="A";
transaction\["result"\]="Approved";
transaction\["authcode"\]="314407";
transaction\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
transaction\["creditcard"\]="creditcard";
transaction\["invoice"\]="98454685";
transaction\["orderid"\]="4556432";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
transaction\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
transaction\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
transaction\["batch"\]="batch";
transaction\["auth_amount"\]="500.00";
transaction\["trantype"\]="Credit Card Sale";
transaction\["iccdata"\]="";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
transaction\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
transaction\["customer"\]="customer";
IDictionary<string, object> savedcard = new Dictionary<string, object>();
savedcard\["type"\]="Visa";
savedcard\["key"\]="tyet-xk8x-vpj4-7swq";
savedcard\["cardnumber"\]="4000xxxxxxxx2224";
transaction\["savedcard"\]="savedcard";
response\["transaction"\]="transaction";
response\["complete"\]="sent to device";
@DELETE/paymentengine/payrequests/:requestkey:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["requestkey"\]="Example_requestkey";
var response = USAePay.API.Paymentengine.Payrequests.Delete(request);
@DELETE/paymentengine/payrequests/:requestkey:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@GET/paymentengine/devices/:devicekey:/settings@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
var response = USAePay.API.Paymentengine.Devices.Settings.Get(request);
@GET/paymentengine/devices/:devicekey:/settings@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["timeout"\]="30";
response\["enable_standalone"\]="false";
response\["share_device"\]="false";
response\["notify_update"\]="true";
response\["notify_update_next"\]="true";
response\["sleep_battery_device"\]="5";
response\["sleep_battery_display"\]="3";
response\["sleep_powered_device"\]="10";
response\["sleep_powered_display"\]="8";
@PUT/paymentengine/devices/:devicekey:/settings@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
request\["timeout"\]="30";
request\["enable_standalone"\]="false";
request\["share_device"\]="false";
request\["notify_update"\]="true";
request\["notify_update_next"\]="true";
request\["sleep_battery_device"\]="5";
request\["sleep_battery_display"\]="3";
request\["sleep_powered_device"\]="10";
request\["sleep_powered_display"\]="8";
var response = USAePay.API.Paymentengine.Devices.Settings.Put(request);
@PUT/paymentengine/devices/:devicekey:/settings@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="device";
response\["key"\]="sa_WKwzyQawBG0RMy0XpDGFXb6pXA32r";
response\["apikeyid"\]="ntC8nP31Moh0wtvYT";
response\["terminal_type"\]="standalone";
response\["status"\]="ntC8nP31Moh0wtvYT";
response\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
response\["settings"\]="settings";
IDictionary<string, object> terminal_info = new Dictionary<string, object>();
terminal_info\["make"\]="Castle";
terminal_info\["model"\]="Vega3000";
terminal_info\["revision"\]="18043001-0055.00";
terminal_info\["serial"\]="011118170300198";
terminal_info\["key_pin"\]="FFFF5B04";
terminal_info\["key_pan"\]="FF908A";
response\["terminal_info"\]="terminal_info";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
response\["terminal_config"\]="terminal_config";
response\["pairing_code"\]="690520";
response\["expiration"\]="2019-10-29 11:59:28";
@GET/paymentengine/devices/:devicekey:/terminal-config@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
var response = USAePay.API.Paymentengine.Devices.Terminal-config.Get(request);
@GET/paymentengine/devices/:devicekey:/terminal-config@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["enable_emv"\]="true";
response\["enable_debit_msr"\]="true";
response\["enable_tip_adjust"\]="true";
response\["enable_contactless"\]="true";
@PUT/paymentengine/devices/:devicekey:/terminal-config@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
request\["enable_emv"\]="true";
request\["enable_debit_msr"\]="true";
request\["enable_tip_adjust"\]="true";
request\["enable_contactless"\]="true";
var response = USAePay.API.Paymentengine.Devices.Terminal-config.Put(request);
@PUT/paymentengine/devices/:devicekey:/terminal-config@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="device";
response\["key"\]="sa_WKwzyQawBG0RMy0XpDGFXb6pXA32r";
response\["apikeyid"\]="ntC8nP31Moh0wtvYT";
response\["terminal_type"\]="standalone";
response\["status"\]="ntC8nP31Moh0wtvYT";
response\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
response\["settings"\]="settings";
IDictionary<string, object> terminal_info = new Dictionary<string, object>();
terminal_info\["make"\]="Castle";
terminal_info\["model"\]="Vega3000";
terminal_info\["revision"\]="18043001-0055.00";
terminal_info\["serial"\]="011118170300198";
terminal_info\["key_pin"\]="FFFF5B04";
terminal_info\["key_pan"\]="FF908A";
response\["terminal_info"\]="terminal_info";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
response\["terminal_config"\]="terminal_config";
response\["pairing_code"\]="690520";
response\["expiration"\]="2019-10-29 11:59:28";
@POST/paymentengine/devices/:devicekey:/kick@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["devicekey"\]="Example_devicekey";
var response = USAePay.API.Paymentengine.Devices.Kick.Post(request);
@POST/paymentengine/devices/:devicekey:/kick@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="device";
response\["key"\]="sa_WKwzyQawBG0RMy0XpDGFXb6pXA32r";
response\["apikeyid"\]="ntC8nP31Moh0wtvYT";
response\["terminal_type"\]="standalone";
response\["status"\]="ntC8nP31Moh0wtvYT";
response\["name"\]="ntC8nP31Moh0wtvYT";
IDictionary<string, object> settings = new Dictionary<string, object>();
settings\["timeout"\]="30";
settings\["enable_standalone"\]="false";
settings\["share_device"\]="false";
settings\["notify_update"\]="true";
settings\["notify_update_next"\]="true";
settings\["sleep_battery_device"\]="5";
settings\["sleep_battery_display"\]="3";
settings\["sleep_powered_device"\]="10";
settings\["sleep_powered_display"\]="8";
response\["settings"\]="settings";
IDictionary<string, object> terminal_info = new Dictionary<string, object>();
terminal_info\["make"\]="Castle";
terminal_info\["model"\]="Vega3000";
terminal_info\["revision"\]="18043001-0055.00";
terminal_info\["serial"\]="011118170300198";
terminal_info\["key_pin"\]="FFFF5B04";
terminal_info\["key_pan"\]="FF908A";
response\["terminal_info"\]="terminal_info";
IDictionary<string, object> terminal_config = new Dictionary<string, object>();
terminal_config\["enable_emv"\]="true";
terminal_config\["enable_debit_msr"\]="true";
terminal_config\["enable_tip_adjust"\]="true";
terminal_config\["enable_contactless"\]="true";
response\["terminal_config"\]="terminal_config";
response\["pairing_code"\]="690520";
response\["expiration"\]="2019-10-29 11:59:28";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["product_key"\]="Example_product_key";
var response = USAePay.API.Products.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="product";
response\["key"\]="80v96p6rx2k6sktw";
response\["product_refnum"\]="2";
response\["name"\]="Botts Every Flavor Beans";
response\["price"\]="2.00";
response\["enabled"\]="True";
response\["taxable"\]="True";
response\["categoryid"\]="1238710";
response\["commodity_code"\]="3122";
response\["description"\]="Every flavor you can imagine and then some.";
response\["list_price"\]="3.00";
response\["manufacturer"\]="Jelly Belly";
response\["merch_productid"\]="EXA1234";
response\["physicalgood"\]="True";
response\["ship_weight"\]="1.2 oz";
response\["sku"\]="123456789";
response\["upc"\]="999999999";
response\["weight"\]="1.2 oz";
response\["wholesale_price"\]="3.22";
response\["created"\]="";
response\["modified"\]="";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="37";
request\["offset"\]="50";
var response = USAePay.API.Products.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="product";
dataItem\["key"\]="80v96p6rx2k6sktw";
dataItem\["product_refnum"\]="2";
dataItem\["name"\]="Botts Every Flavor Beans";
dataItem\["price"\]="2.00";
dataItem\["enabled"\]="True";
dataItem\["taxable"\]="True";
dataItem\["categoryid"\]="1238710";
dataItem\["commodity_code"\]="3122";
dataItem\["description"\]="Every flavor you can imagine and then some.";
dataItem\["list_price"\]="3.00";
dataItem\["manufacturer"\]="Jelly Belly";
dataItem\["merch_productid"\]="EXA1234";
dataItem\["physicalgood"\]="True";
dataItem\["ship_weight"\]="1.2 oz";
dataItem\["sku"\]="123456789";
dataItem\["upc"\]="999999999";
dataItem\["weight"\]="1.2 oz";
dataItem\["wholesale_price"\]="3.22";
dataItem\["created"\]="";
dataItem\["modified"\]="";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="42";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["name"\]="Botts Every Flavor Beans";
request\["price"\]="2.00";
request\["enabled"\]="True";
request\["taxable"\]="True";
request\["categoryid"\]="1238710";
request\["commodity_code"\]="3122";
request\["description"\]="Every flavor you can imagine and then some.";
request\["list_price"\]="3.00";
request\["manufacturer"\]="Jelly Belly";
request\["merch_productid"\]="EXA1234";
request\["physicalgood"\]="True";
request\["ship_weight"\]="1.2 oz";
request\["sku"\]="123456789";
request\["upc"\]="999999999";
request\["weight"\]="1.2 oz";
request\["wholesale_price"\]="3.22";
var response = USAePay.API.Products.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="product";
response\["key"\]="80v96p6rx2k6sktw";
response\["product_refnum"\]="2";
response\["name"\]="Botts Every Flavor Beans";
response\["price"\]="2.00";
response\["enabled"\]="True";
response\["taxable"\]="True";
response\["categoryid"\]="1238710";
response\["commodity_code"\]="3122";
response\["description"\]="Every flavor you can imagine and then some.";
response\["list_price"\]="3.00";
response\["manufacturer"\]="Jelly Belly";
response\["merch_productid"\]="EXA1234";
response\["physicalgood"\]="True";
response\["ship_weight"\]="1.2 oz";
response\["sku"\]="123456789";
response\["upc"\]="999999999";
response\["weight"\]="1.2 oz";
response\["wholesale_price"\]="3.22";
response\["created"\]="";
response\["modified"\]="";
@DELETE/products/:product_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["product_key"\]="Example_product_key";
var response = USAePay.API.Products.Delete(request);
@DELETE/products/:product_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["product_key"\]="Example_product_key";
request\["name"\]="Botts Every Flavor Beans";
request\["price"\]="2.00";
request\["enabled"\]="True";
request\["taxable"\]="True";
request\["categoryid"\]="1238710";
request\["commodity_code"\]="3122";
request\["description"\]="Every flavor you can imagine and then some.";
request\["list_price"\]="3.00";
request\["manufacturer"\]="Jelly Belly";
request\["merch_productid"\]="EXA1234";
request\["physicalgood"\]="True";
request\["ship_weight"\]="1.2 oz";
request\["sku"\]="123456789";
request\["upc"\]="999999999";
request\["weight"\]="1.2 oz";
request\["wholesale_price"\]="3.22";
var response = USAePay.API.Products.Put(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="product";
response\["key"\]="80v96p6rx2k6sktw";
response\["product_refnum"\]="2";
response\["name"\]="Botts Every Flavor Beans";
response\["price"\]="2.00";
response\["enabled"\]="True";
response\["taxable"\]="True";
response\["categoryid"\]="1238710";
response\["commodity_code"\]="3122";
response\["description"\]="Every flavor you can imagine and then some.";
response\["list_price"\]="3.00";
response\["manufacturer"\]="Jelly Belly";
response\["merch_productid"\]="EXA1234";
response\["physicalgood"\]="True";
response\["ship_weight"\]="1.2 oz";
response\["sku"\]="123456789";
response\["upc"\]="999999999";
response\["weight"\]="1.2 oz";
response\["wholesale_price"\]="3.22";
response\["created"\]="";
response\["modified"\]="";
@GET/products/categories/:category_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["category_key"\]="Example_category_key";
var response = USAePay.API.Products.Categories.Get(request);
@GET/products/categories/:category_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="product_category";
response\["key"\]="80v96p6rx2k6sktw";
response\["name"\]="Botts Every Flavor Beans";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="93";
request\["offset"\]="93";
var response = USAePay.API.Products.Categories.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="product_category";
dataItem\["key"\]="80v96p6rx2k6sktw";
dataItem\["name"\]="Botts Every Flavor Beans";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="42";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["name"\]="Botts Every Flavor Beans";
var response = USAePay.API.Products.Categories.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="product_category";
response\["key"\]="80v96p6rx2k6sktw";
response\["name"\]="Botts Every Flavor Beans";
@DELETE/products/categories/:category_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["category_key"\]="Example_category_key";
var response = USAePay.API.Products.Categories.Delete(request);
@DELETE/products/categories/:category_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["status"\]="success";
@PUT/products/categories/:category_key:@
IDictionary<string, object> request = new Dictionary<string, object>();
request\["category_key"\]="Example_category_key";
request\["name"\]="Botts Every Flavor Beans";
var response = USAePay.API.Products.Categories.Put(request);
@PUT/products/categories/:category_key:@
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="product_category";
response\["key"\]="80v96p6rx2k6sktw";
response\["name"\]="Botts Every Flavor Beans";
IDictionary<string, object> request = new Dictionary<string, object>();
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4000100011112224";
creditcard\["expiration"\]="0426"
request\["creditcard"\]="creditcard";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="9sddg0ccd915pdbq";
customer\["paymethod_key"\]="2n02pc6k26jkfkh1b";
request\["customer"\]="customer";
IList<IDictionary<string, object>> list = new List<IDictionary<string, object>>();
IDictionary<string, object> listItem = new Dictionary<string, object>();
listItem\["custkey"\]="9sddg0ccd915pdbq";
listItem\["paymethod_key"\]="2n02pc6k26jkfkh1b";
list.Add(listItem);
request\["list"\]="list";
var response = USAePay.API.Tokens.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="token";
response\["key"\]="p4xe-9ax3-26f4-pi6h";
IDictionary<string, object> token = new Dictionary<string, object>();
token\["type"\]="token";
token\["key"\]="p4xe-9ax3-26f4-pi6h";
token\["card_key"\]="p4xe-9ax3-26f4-pi6h";
token\["cardref"\]="p4xe-9ax3-26f4-pi6h";
token\["masked_card_number"\]="XXXXXXXXXXXX2226";
token\["card_type"\]="Visa";
response\["token"\]="token";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["cardref"\]="Example_cardref";
var response = USAePay.API.Tokens.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="token";
response\["key"\]="p4xe-9ax3-26f4-pi6h";
response\["card_key"\]="p4xe-9ax3-26f4-pi6h";
response\["cardref"\]="p4xe-9ax3-26f4-pi6h";
response\["masked_card_number"\]="XXXXXXXXXXXX2226";
response\["card_type"\]="Visa";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["trankey"\]="Example_trankey";
var response = USAePay.API.Transactions.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="transaction";
response\["key"\]="dnfwxwhz5kvnbgb";
response\["refnum"\]="100061";
response\["created"\]="2018-12-04 10:48:44";
response\["trantype_code"\]="S";
response\["trantype"\]="Credit Card Sale";
response\["result_code"\]="A";
response\["result"\]="Approved";
response\["error_code"\]="12";
response\["error"\]="Card Number was not between 13 and 16 digits";
response\["authcode"\]="314407";
response\["status_code"\]="P";
response\["status"\]="Authorized (Pending Settlement)";
response\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
response\["creditcard"\]="creditcard";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
response\["check"\]="check";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
response\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
response\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
response\["batch"\]="batch";
response\["amount"\]="50";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
response\["amount_detail"\]="amount_detail";
response\["ponum"\]="af416fsd5";
response\["invoice"\]="98454685";
response\["orderid"\]="98454685";
response\["description"\]="Antique Pensieve";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
response\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
response\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
response\["lineitems"\]="lineitems";
response\["comments"\]="Powerful magical object. Use with caution.";
response\["tranterm"\]="multilane";
response\["clerk"\]="Madame Malkin";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
response\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
response\["customer"\]="customer";
response\["customer_email"\]="noreply@gmail.com";
IDictionary<string, object> bin = new Dictionary<string, object>();
bin\["bin"\]="444455";
bin\["type"\]="Debit";
bin\["issuer"\]="Visa";
bin\["bank"\]="Chase Bank";
bin\["country"\]="US";
bin\["country_name"\]="United States";
bin\["country_iso"\]="CA";
bin\["location"\]="http://www.jpmorganchase.com";
bin\["phone"\]="USA";
bin\["category"\]="";
response\["bin"\]="bin";
response\["clientip"\]="Madame Malkin";
response\["source_name"\]="Madame Malkin";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["limit"\]="86";
request\["offset"\]="78";
request\["fuzzy"\]="32";
request\["filters"\]="exampleFilter";
var response = USAePay.API.Transactions.Get(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="list";
response\["limit"\]="0";
response\["offset"\]="20";
IList<IDictionary<string, object>> data = new List<IDictionary<string, object>>();
IDictionary<string, object> dataItem = new Dictionary<string, object>();
dataItem\["type"\]="transaction";
dataItem\["key"\]="dnfwxwhz5kvnbgb";
dataItem\["refnum"\]="100061";
dataItem\["created"\]="2018-12-04 10:48:44";
dataItem\["trantype_code"\]="S";
dataItem\["trantype"\]="Credit Card Sale";
dataItem\["result_code"\]="A";
dataItem\["result"\]="Approved";
dataItem\["error_code"\]="12";
dataItem\["error"\]="Card Number was not between 13 and 16 digits";
dataItem\["authcode"\]="314407";
dataItem\["status_code"\]="P";
dataItem\["status"\]="Authorized (Pending Settlement)";
dataItem\["proc_refnum"\]="18120443975126";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Minerva McGonnegall";
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="swiped";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_postalcode"\]="90006";
dataItem\["creditcard"\]="creditcard";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
dataItem\["check"\]="check";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
dataItem\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
dataItem\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="ft1m9m5p9wgd9mb";
batch\["batchrefnum"\]="12345678";
batch\["sequence"\]="2902";
dataItem\["batch"\]="batch";
dataItem\["amount"\]="50";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="40.00";
amount_detail\["tax"\]="10.00";
amount_detail\["enable_partialauth"\]="false";
dataItem\["amount_detail"\]="amount_detail";
dataItem\["ponum"\]="af416fsd5";
dataItem\["invoice"\]="98454685";
dataItem\["orderid"\]="98454685";
dataItem\["description"\]="Antique Pensieve";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["postalcode"\]="10005";
dataItem\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["company"\]="Hogwarts School of Witchcraft and Wizardry";
shipping_address\["street"\]="123 Astronomy Tower";
shipping_address\["postalcode"\]="10005";
dataItem\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["description"\]="See into your past...";
lineitemsItem\["size"\]="Large";
lineitemsItem\["color"\]="Bronze";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["list_price"\]="500.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["sku"\]="68453423";
lineitemsItem\["commoditycode"\]="535";
lineitemsItem\["discountamount"\]="0";
lineitemsItem\["discountrate"\]="0";
lineitemsItem\["taxable"\]="";
lineitemsItem\["taxamount"\]="45.00";
lineitemsItem\["taxclass"\]="NA";
lineitemsItem\["taxrate"\]="10";
lineitemsItem\["um"\]="EA";
lineitemsItem\["category"\]="Antiques";
lineitemsItem\["manufacturer"\]="The Ancients";
lineitems.Add(lineitemsItem);
dataItem\["lineitems"\]="lineitems";
dataItem\["comments"\]="Powerful magical object. Use with caution.";
dataItem\["tranterm"\]="multilane";
dataItem\["clerk"\]="Madame Malkin";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
dataItem\["receipts"\]="receipts";
IDictionary<string, object> customer = new Dictionary<string, object>();
customer\["custkey"\]="ksddgpqgpbs5zkmb";
customer\["custid"\]="10275538";
dataItem\["customer"\]="customer";
dataItem\["customer_email"\]="noreply@gmail.com";
IDictionary<string, object> bin = new Dictionary<string, object>();
bin\["bin"\]="444455";
bin\["type"\]="Debit";
bin\["issuer"\]="Visa";
bin\["bank"\]="Chase Bank";
bin\["country"\]="US";
bin\["country_name"\]="United States";
bin\["country_iso"\]="CA";
bin\["location"\]="http://www.jpmorganchase.com";
bin\["phone"\]="USA";
bin\["category"\]="";
dataItem\["bin"\]="bin";
dataItem\["clientip"\]="Madame Malkin";
dataItem\["source_name"\]="Madame Malkin";
data.Add(dataItem);
response\["data"\]="data";
response\["total"\]="42";
IDictionary<string, object> request = new Dictionary<string, object>();
request\["command"\]="sale";
request\["invoice"\]="98454685";
request\["ponum"\]="af416fsd5";
request\["description"\]="Antique Pensieve";
request\["comments"\]="Powerful magical object. Use with caution.";
request\["email"\]="brian@hogwarts.com";
request\["send_receipt"\]="1";
request\["ignore_duplicate"\]="1";
request\["merchemailaddr"\]="receipts@fandb.net";
request\["amount"\]="500.00";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["subtotal"\]="450.00";
amount_detail\["tax"\]="45.00";
amount_detail\["tip"\]="5.00";
amount_detail\["discount"\]="50.00";
amount_detail\["shipping"\]="50.00";
request\["amount_detail"\]="amount_detail";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["cardholder"\]="Hogwarts School of Witchcraft and Wizardry";
creditcard\["number"\]="4444333322221111";
creditcard\["expiration"\]="0426"
creditcard\["cvc"\]="123";
creditcard\["avs_street"\]="1234 Portkey Ave";
creditcard\["avs_zip"\]="12345";
request\["creditcard"\]="creditcard";
IDictionary<string, object> traits = new Dictionary<string, object>();
traits\["is_debt"\]="";
traits\["is_bill_pay"\]="";
traits\["is_recurring"\]="";
traits\["is_healthcare"\]="";
traits\["is_cash_advance"\]="";
request\["traits"\]="traits";
request\["custkey"\]="ksddgpqgpbs5zkmb";
IDictionary<string, object> billing_address = new Dictionary<string, object>();
billing_address\["firstname"\]="Albus";
billing_address\["lastname"\]="Dumbledore";
billing_address\["street"\]="123 Astronomy Tower";
billing_address\["street2"\]="Suite 1";
billing_address\["city"\]="Phoenix";
billing_address\["state"\]="CA";
billing_address\["postalcode"\]="10005";
billing_address\["country"\]="USA";
billing_address\["phone"\]="555-253-3673";
billing_address\["fax"\]="666-253-3673";
request\["billing_address"\]="billing_address";
IDictionary<string, object> shipping_address = new Dictionary<string, object>();
shipping_address\["firstname"\]="Aberforth";
shipping_address\["lastname"\]="Dumbledore";
shipping_address\["street"\]="987 HogsHead St";
shipping_address\["city"\]="Hogsmead";
shipping_address\["state"\]="WY";
shipping_address\["postalcode"\]="30005";
shipping_address\["country"\]="USA";
shipping_address\["phone"\]="555-253-3673";
request\["shipping_address"\]="shipping_address";
IList<IDictionary<string, object>> lineitems = new List<IDictionary<string, object>>();
IDictionary<string, object> lineitemsItem = new Dictionary<string, object>();
lineitemsItem\["product_key"\]="ds4bb5ckg059vdn8";
lineitemsItem\["name"\]="Antique Pensieve";
lineitemsItem\["cost"\]="450.00";
lineitemsItem\["qty"\]="1";
lineitemsItem\["tax_amount"\]="50.00";
lineitemsItem\["location_key"\]="dnyyjc8s2vbz8hb33";
lineitemsItem\["list_price"\]="500.00";
lineitems.Add(lineitemsItem);
request\["lineitems"\]="lineitems";
IDictionary<string, object> custom_fields = new Dictionary<string, object>();
custom_fields\["1"\]="Gryffindor";
custom_fields\["2"\]="Headmaster";
request\["custom_fields"\]="custom_fields";
var response = USAePay.API.Transactions.Post(request);
IDictionary<string, object> response = new Dictionary<string, object>();
response\["type"\]="transaction";
response\["key"\]="dnfwxwhz5kvnbgb";
response\["refnum"\]="100061";
response\["is_duplicate"\]="N";
response\["result_code"\]="A";
response\["result"\]="Approved";
response\["authcode"\]="314407";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["number"\]="4444xxxxxxxx1111";
creditcard\["cardholder"\]="Hogwarts School of Witchcraft and Wizardry";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="Card Not Present, Manually Keyed";
response\["creditcard"\]="creditcard";
response\["invoice"\]="98454685";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
response\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
response\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="0t1jyndn769q1vb";
batch\["batchrefnum"\]="409384";
batch\["sequence"\]="1";
response\["batch"\]="batch";
response\["auth_amount"\]="500.00";
response\["trantype"\]="Credit Card Sale";
IDictionary<string, object> receipts = new Dictionary<string, object>();
receipts\["customer"\]="Mail Sent Successfully";
receipts\["merchant"\]="Mail Sent Successfully";
response\["receipts"\]="receipts";
IDictionary<string, object> request_token_sale = new Dictionary<string, object>();
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["number"\]="dx0c3ns6xips28h3";
creditcard\["cvc"\]="123";
request_token_sale\["creditcard"\]="creditcard";
request_token_sale\["command"\]="sale";
request_token_sale\["invoice"\]="101";
request_token_sale\["ponum"\]="af416fsd5";
request_token_sale\["description"\]="Woolen Socks";
request_token_sale\["comments"\]="Best socks in the world.";
request_token_sale\["amount"\]="17.99";
var response = USAePay.API.Transactions.Post(request_token_sale);
IDictionary<string, object> response_token_sale = new Dictionary<string, object>();
response_token_sale\["type"\]="transaction";
response_token_sale\["key"\]="nnfkg4y0452kztm";
response_token_sale\["refnum"\]="100071";
response_token_sale\["is_duplicate"\]="N";
response_token_sale\["result_code"\]="A";
response_token_sale\["result"\]="Approved";
response_token_sale\["authcode"\]="329045";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["number"\]="4444xxxxxxxx7779";
creditcard\["cardholder"\]="Hogwarts School of Witchcraft and Wizardry";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="Card Not Present, Manually Keyed";
response_token_sale\["creditcard"\]="creditcard";
response_token_sale\["invoice"\]="101";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
response_token_sale\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
response_token_sale\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="0t1jyndn769q1vb";
batch\["batchrefnum"\]="409384";
batch\["sequence"\]="1";
response_token_sale\["batch"\]="batch";
response_token_sale\["auth_amount"\]="17.99";
response_token_sale\["trantype"\]="Credit Card Sale";
IDictionary<string, object> request_paymentkey_sale = new Dictionary<string, object>();
request_paymentkey_sale\["payment_key"\]="02zxfg87ty824";
request_paymentkey_sale\["command"\]="sale";
request_paymentkey_sale\["invoice"\]="101";
request_paymentkey_sale\["ponum"\]="af416fsd5";
request_paymentkey_sale\["description"\]="Woolen Socks";
request_paymentkey_sale\["comments"\]="Best socks in the world.";
request_paymentkey_sale\["amount"\]="17.99";
var response = USAePay.API.Transactions.Post(request_paymentkey_sale);
IDictionary<string, object> response_paymentkey_sale = new Dictionary<string, object>();
response_paymentkey_sale\["type"\]="transaction";
response_paymentkey_sale\["key"\]="nnfkg4y0452kztm";
response_paymentkey_sale\["refnum"\]="100071";
response_paymentkey_sale\["is_duplicate"\]="N";
response_paymentkey_sale\["result_code"\]="A";
response_paymentkey_sale\["result"\]="Approved";
response_paymentkey_sale\["authcode"\]="329045";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["number"\]="4444xxxxxxxx7779";
creditcard\["cardholder"\]="Hogwarts School of Witchcraft and Wizardry";
creditcard\["category_code"\]="A";
creditcard\["entry_mode"\]="Card Not Present, Manually Keyed";
response_paymentkey_sale\["creditcard"\]="creditcard";
response_paymentkey_sale\["invoice"\]="101";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
response_paymentkey_sale\["avs"\]="avs";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="N";
cvc\["result"\]="No Match";
response_paymentkey_sale\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="0t1jyndn769q1vb";
batch\["batchrefnum"\]="409384";
batch\["sequence"\]="1";
response_paymentkey_sale\["batch"\]="batch";
response_paymentkey_sale\["auth_amount"\]="17.99";
response_paymentkey_sale\["trantype"\]="Credit Card Sale";
IDictionary<string, object> request_check_sale = new Dictionary<string, object>();
request_check_sale\["command"\]="check:sale";
request_check_sale\["invoice"\]="101";
request_check_sale\["ponum"\]="af416fsd5";
request_check_sale\["description"\]="Wolfsbane Potion";
request_check_sale\["amount"\]="75.00";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
check\["number"\]="101";
check\["format"\]="WEB";
request_check_sale\["check"\]="check";
var response = USAePay.API.Transactions.Post(request_check_sale);
IDictionary<string, object> response_check_sale = new Dictionary<string, object>();
response_check_sale\["command"\]="check:sale";
response_check_sale\["invoice"\]="101";
response_check_sale\["ponum"\]="af416fsd5";
response_check_sale\["description"\]="Wolfsbane Potion";
response_check_sale\["amount"\]="75.00";
IDictionary<string, object> check = new Dictionary<string, object>();
check\["accountholder"\]="Remus Lupin";
check\["routing"\]="123456789";
check\["account"\]="324523524";
check\["account_type"\]="checking";
check\["number"\]="101";
check\["format"\]="WEB";
response_check_sale\["check"\]="check";
IDictionary<string, object> request_cash_sale = new Dictionary<string, object>();
request_cash_sale\["command"\]="cash:sale";
request_cash_sale\["amount"\]="5.00";
IDictionary<string, object> amount_detail = new Dictionary<string, object>();
amount_detail\["tax"\]="1.00";
amount_detail\["tip"\]="0.50";
request_cash_sale\["amount_detail"\]="amount_detail";
var response = USAePay.API.Transactions.Post(request_cash_sale);
IDictionary<string, object> response_cash_sale = new Dictionary<string, object>();
response_cash_sale\["type"\]="transaction";
response_cash_sale\["key"\]="3nft52wn1wy7rx8";
response_cash_sale\["refnum"\]="100077";
response_cash_sale\["is_duplicate"\]="N";
response_cash_sale\["result_code"\]="A";
response_cash_sale\["result"\]="Approved";
response_cash_sale\["authcode"\]="";
IDictionary<string, object> request_quicksale = new Dictionary<string, object>();
request_quicksale\["command"\]="quicksale";
request_quicksale\["trankey"\]="gnfkd12yhsr7mbs";
request_quicksale\["amount"\]="5.00";
var response = USAePay.API.Transactions.Post(request_quicksale);
IDictionary<string, object> response_quicksale_cc = new Dictionary<string, object>();
response_quicksale_cc\["type"\]="transaction";
response_quicksale_cc\["key"\]="mnfwvcf1thnvrgb";
response_quicksale_cc\["refnum"\]="100070";
response_quicksale_cc\["is_duplicate"\]="N";
response_quicksale_cc\["result_code"\]="A";
response_quicksale_cc\["result"\]="Approved";
response_quicksale_cc\["authcode"\]="328906";
IDictionary<string, object> avs = new Dictionary<string, object>();
avs\["result_code"\]="YYY";
avs\["result"\]="Address: Match & 5 Digit Zip: Match";
response_quicksale_cc\["avs"\]="avs";
IDictionary<string, object> creditcard = new Dictionary<string, object>();
creditcard\["category_code"\]="A";
response_quicksale_cc\["creditcard"\]="creditcard";
IDictionary<string, object> cvc = new Dictionary<string, object>();
cvc\["result_code"\]="P";
cvc\["result"\]="Not Processed";
response_quicksale_cc\["cvc"\]="cvc";
IDictionary<string, object> batch = new Dictionary<string, object>();
batch\["type"\]="batch";
batch\["key"\]="0t1jyndn769q1vb";
batch\["batchrefnum"\]="409384";
batch\["sequence"\]="1";
response_quicksale_cc\["batch"\]="batch";
response_quicksale_cc\["auth_amount"\]="5.00";
response_quicksale_cc\["trantype"\]="Credit Card Sale";
IDictionary<string, object> response_quicksale_check = new Dictionary<string, object>();
response_quicksale_check\["type"\]="transaction";
response_quicksale_check\["key"\]="5nfty0s5m91vb3b";
response_quicksale_check\["refnum"\]="100079";
response_quicksale_check\["is_duplicate"\]="N";
response_quicksale_check\["result_code"\]="A";
response_quicksale_check\["result"\]="Approved";
response_quicksale_check\["authcode"\]="TM9406";
response_quicksale_check\["proc_refnum"\]="18120443978215";
response_quicksale_check\["trantype"\]="Check Sale";
IDictionary<string, object> request_authonly = new Dictionary<string, object>();
request_authonly\["command"\]="authonly";
request_authonly\["invoice"\]="98454685";
request_authonly\["ponum"\]="af416fsd5";
request_authonly\["description"\]="Antique Pensieve";
request_authonly\["comments"\]="Powerful magical object. Use with caution.";
request_authonly\["email"\]="brian@hogwarts.com";
request_authonly\["send_receipt"\]="1";
request_authonly\["ignore_duplicate"\]="1"