This is the recommended means for Java developers to access the BlockChyp gateway and BlockChyp terminals. This SDK was designed to be compatible with the broadest possible range of Java point-of-sale systems. We've avoided some of the newer Java features we love like streams and generics in order to maintain compatibility all the way back to Java 1.6.
We've tried to avoid introducing classpath problems for you whenever possible. HTTP interaction is done using commons-httpclient-3.1 and we also use commons-lang, commons-io, and commons-codec. We're using the Bouncy Castle JCE provider for encryption services, but we don't use any Bouncy Castle specific classes so if you exclude this dependency you should still be fine with the standard Java stuff.
There are several techniques for getting your hands on the SDK. Most developers use a dependency management system like Maven.
The BlockChyp SDK is in Maven's Central Repository. Just add this snippet to your pom:
<dependency>
<groupId>com.blockchyp</groupId>
<artifactId>blockchyp-java</artifactId>
<version>2.20.1</version>
</dependency>
For the hipsters among you who've moved up to Gradle, try adding this snippet under dependencies in your Gradle build file.
compile group: 'com.blockchyp', name: 'blockchyp-java', version:'2.20.1'
You'll also need the Maven plugin turned on. Make sure your Gradle build has something like this in it:
apply plugin: 'maven'
The BlockChyp SDK has a pretty conventional Maven build with a single pom.xml and no weird repository dependencies. Just clone this repository
and run mvn package
to build a jar.
Once the BlockChyp SDK is in your classpath, you can start using it to run transactions. All interaction with BlockChyp is done via the BlockChypClient class.
Just instantiate the BlockChypClient class, add your credentials and start charging. Here's an example..
package com.blockchyp.examples;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.APICredentials;
import com.blockchyp.client.dto.AuthorizationRequest;
import com.blockchyp.client.dto.AuthorizationResponse;
public class HelloBlockChyp {
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials("APIKEY", "BEARER TOKEN", "SIGNING_KEY");
BlockChypClient client = new BlockChypClient(creds);
AuthorizationRequest request = new AuthorizationRequest();
request.setTerminalName("Test Terminal");
request.setAmount("50.00");
AuthorizationResponse response = client.charge(request);
if (response.isApproved()) {
System.out.println("Approved! Auth Code: " + response.getAuthCode());
}
}
}
The above code is sufficient for running a basic charge transaction against a terminal. You don't need to keep track of terminal IP addresses or anything like that. Our terminal routing system, which is essentially a DNS system for payment terminals on private networks, handles everything for you.
Don't worry. We've got you covered. The BlockChypClient was designed to be easy to use with Spring or other dependency injection frameworks. We're former Spring developers ourselves.
If you're still using XML based configuration for Spring, you'll need a snippet like this...
<?xml version = "1.0" encoding = "UTF-8"?>
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id="blockchypCredentials" class="com.blockchyp.client.dto.APICredentials">
<property name="apiKey" value="API_KEY_VALUE"/>
<property name="bearerToken" value="BEARER_TOKEN"/>
<property name="signingKey" value="SIGNING_KEY"/>
</bean>
<bean id="blockchypClient" class="com.blockchyp.client.BlockChypClient">
<property name="defaultCredentials" ref="blockchypCredentials"/>
</bean>
<bean id="blockchypSpringExample" class="com.blockchyp.examples.SpringExample">
<property name="blockchypClient" ref="blockchypClient"/>
</bean>
</beans>
This is pretty conventional Spring dependency injection. The example below shows the Java code behind the above example. If you're autowiring wherever possible, you can probably leave out the last bean definition from the XML sample above. Also note that APICredentials and BlockChypClient can also be initialized via constructors if you prefer constructor based dependency injection.
package com.blockchyp.examples;
import org.springframework.beans.factory.annotation.Autowired;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.AuthorizationRequest;
import com.blockchyp.client.dto.AuthorizationResponse;
public class SpringExample {
@Autowired
private BlockChypClient blockchypClient;
public boolean charge(String terminalName, String amount) throws Exception {
AuthorizationRequest request = new AuthorizationRequest();
request.setTerminalName("Test Terminal");
request.setAmount("50.00");
AuthorizationResponse response = blockchypClient.charge(request);
return response.isApproved();
}
}
We get it. You're over XML. We think XML's been unfairly maligned as a format for configuration, but we know we can't fight progress and we've stopped using it too.
Here's an example of how to do all of the above without XML.
package com.blockchyp.examples;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.APICredentials;
@Configuration
public class SpringConfigExample {
@Bean
public APICredentials blockchypCredentials() {
return new APICredentials("APIKEY", "BEARER TOKEN", "SIGNING_KEY");
}
@Bean
public BlockChypClient blockchypClient() {
return new BlockChypClient(blockchypCredentials());
}
}
We designed this SDK to work out of the box with no special configuration for those developers who never read this (most developers, we assume), but there are a few recommended best practices for production use.
By default, the Java SDK communicates with terminals without SSL or TLS. (Gateway communication is always TLS.) The reason for this is that BlockChyp terminals run on private networks where the standard root certificate authorities cannot be used and it's difficult, if not impossible, to add new root CA's in Java programmatically. We recommend you install our terminal root CA as a trusted CA and turn https on in your client. In order to provide some extra protection in situations where developers choose not to do this, the SDK uses transient credentials when communicating with terminals in order to prevent exposing real merchant credentials.
-----BEGIN CERTIFICATE-----
MIIFAjCCAuqgAwIBAgIBATANBgkqhkiG9w0BAQsFADAgMR4wHAYDVQQDDBVCbG9j
a0NoeXAgSW50ZXJuYWwgQ0EwIBcNMTgwMTAxMDAwMDA4WhgPNDc1NTExMjkwMDAw
MDhaMCAxHjAcBgNVBAMMFUJsb2NrQ2h5cCBJbnRlcm5hbCBDQTCCAiIwDQYJKoZI
hvcNAQEBBQADggIPADCCAgoCggIBANyWuVhDiqeCrHMxbTv5PN5UOZdR8n4PPwUV
z0dALnLS7Lkl9nnuBxUK5XFGsZHBQ3GqSsWgA0HBUAAkKY/hzDIY+mrKOTMFMhoF
SKmcNwmdt+NXuUtYwL5STsr1U/XnxcizsSEHcGP5LhIH16AY0XYMVzNTBXrylH7O
Hf/pPJaVbuywAkiyrEV+lTo1mVTOCucGoNRPogluuyfbBCUH9bWBajbjHWdyiX58
IV786JWkw5ogLXgDekrrzdVxQH1t2kN2PvXNHGOBlB0NL/QwKHxfbvgIu6EkyEXv
vSuFclgaM3x38zcEaIS8id/wZYkwZXAqquR5Hi5fqPILC1xmRF+zC1GH1uJ+gsQu
wqwaiwmD9Rcbm2ZOSVntQy5bCF7IzPlMHzMlt33dF9mZo9bJwFO1APdpeWy+Ooga
n1k/yS2EPnkAv+DiRpNf2it6n86+X7Z4C6QGgP5+rfc53uxeaF8gPLgXViaHHTZD
NflxaNjgKD0xAwB3Yhca8RQSjRPwKYk1FrbhTSAIidnwmA4jrV7juZ2RSWA99VzR
O68OmE/7NygxGgo995pPc+s6DO6IOnZvT2tSs0b2UmEKT51/cf93lv+phX/69hTC
ctMEYoIGNRAvcISA0lfTWHAbiRzMyagtuiRMttS7C+IshsgBrjHSHMsEYj8RhRnR
0FvmChUNAgMBAAGjRTBDMB0GA1UdDgQWBBSBl1rnpf7Omve8fXPl9EltnlcqGTAS
BgNVHRMBAf8ECDAGAQH/AgEBMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsF
AAOCAgEAkt9ywLJvM0TjEUjlC32niE8mNIPX5azHJ0++PlZ2Fc7ZKy4nntt2YErl
l4qEOB8ED2VaLQuxx0O9H2oh1QsMuxT3rQ4SDNmQVH9vUYJWgIkYjY1zKubEyktv
oZyi8xK5e0/ME//vU0ru6y0dmcFtDvpwm/JZPjoVKHK58JpCKH8xhVxQo7NxAIf8
Ow+fr58plDQP1CbfjO1gJpFg7lQ282rz9n0Ju2mXm3guclcx74mDJGlzGLGCJCnu
Qxta8Dv/Cg8+kNM36boORMChaoAgIerXL17EhyUh3ZsSaxEchqvCWtLv1+ekhGpF
A08xS33r1GgQV/cyunuz3czQ0Y/7UjKluo6sbS0RmVtAWJA/DhwXgQlHlFyROmhG
pcKXeLc7+LrBZxITVuQk8Mg9aceAnzBqjeTjQNPQJkOwqIFgDUXNNqvA5mhn/j25
u8CcDY/0p5C4tFQc1npgQwJZAwRGEvFmXVDgEZ8FFkzhn74oxI99Xs1HGc9zO/uP
GV0cahaj9xspMPMBe5Q2mNhVca6+RIZPSIcVbsgYy+2QDBep7NpraQgG7V0f2XTu
uLBaPXbY9PZLFklSSZOLXAuuOk0G57lfyVFRNAZ2R3uQdkDpx90Ti6PDWj9M6x1p
jD1XNpXvgH2k91jjsK67khN+4bWoFBsfrMYt6vgjtXyv0kf12y0=
-----END CERTIFICATE-----
Complete documentation can be found on our Developer Documentation Portal.
In order to test your integration with real terminals, you'll need a BlockChyp Developer Kit. Our kits include a fully functioning payment terminal with test pin encryption keys. Every kit includes a comprehensive set of test cards with test cards for every major card brand and entry method, including Contactless and Contact EMV and mag stripe cards. Each kit also includes test gift cards for our blockchain gift card system.
Access to BlockChyp's developer program is currently invite only, but you can request an invitation by contacting our engineering team at [email protected].
You can also view a number of long form demos and learn more about us on our YouTube Channel.
You don't want to read words. You want examples. Here's a quick rundown of the stuff you can do with the BlockChyp Java SDK and a few basic examples.
These are the core payment APIs used to execute and work with payment transactions in BlockChyp.
- API Credential Types: Merchant
- Required Role: Payment API Access
Our most popular transaction executes a standard authorization and capture. This is the most basic of basic payment transactions, typically used in conventional retail.
Charge transactions can use a payment terminal to capture a payment or use a previously enrolled payment token.
Terminal Transactions
For terminal transactions, make sure you pass in the terminal name using the terminalName
property.
Token Transactions
If you have a payment token, omit the terminalName
property and pass in the token with the token
property instead.
Card Numbers and Mag Stripes
You can also pass in PANs and Mag Stripes, but you probably shouldn't, as this will put you in PCI scope and the most common vector for POS breaches is keylogging. If you use terminals for manual card entry, you'll bypass any keyloggers that might be maliciously running on the point-of-sale system.
Common Variations
- Gift Card Redemption: There's no special API for gift card redemption in BlockChyp. Simply execute a plain charge transaction and if the customer swipes a gift card, our terminals will identify the gift card and run a gift card redemption. Also note that if for some reason the gift card's original purchase transaction is associated with fraud or a chargeback, the transaction will be rejected.
- EBT: Set the
CardType
field toCardType.EBT
to process an EBT SNAP transaction. Note that test EBT transactions always assume a balance of $100.00, so test EBT transactions over that amount may be declined. - Cash Back: To enable cash back for debit transactions, set the
CashBack
field. If the card presented isn't a debit card, theCashBack
field will be ignored. - Manual Card Entry: Set the
ManualEntry
field to enable manual card entry. Good as a backup when chips and MSR's don't work or for more secure phone orders. You can even combine theManualEntry
field with theCardType
field set toCardType.EBT
for manual EBT card entry. - Inline Tokenization: You can enroll the payment method in the token vault inline with a charge transaction by setting the
Enroll
field. You'll get a token back in the response. You can even bind the token to a customer record if you also pass in customer data. - Prompting for Tips: Set the
PromptForTip
field if you'd like to prompt the customer for a tip before authorization. Good for pay-at-the-table and other service related scenarios. - Cash Discounting and Surcharging: The
Surcharge
andCashDiscount
fields can be used together to support cash discounting or surcharge problems. Consult the Cash Discount documentation for more details. - Cryptocurrency The
Cryptocurrency
field can be used to switch the standard present card screen to a cryptocurrency screen. The field value can beANY
to enable any supported cryptocurrency or a single currency code such asBTC
for Bitcoin.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.AuthorizationRequest;
import com.blockchyp.client.dto.AuthorizationResponse;
public class ChargeExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
AuthorizationRequest request = new AuthorizationRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setAmount("55.00");
// Send the request
AuthorizationResponse response = client.charge(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
A preauthorization puts a hold on funds and must be captured later. This is used in scenarios where the final transaction amount might change. A common example is fine dining, where a tip adjustment is required before final settlement.
Another use case for preauthorization is e-commerce. Typically, an online order is preauthorized at the time of the order and then captured when the order ships.
Preauthorizations can use a payment terminal to capture a payment or use a previously enrolled payment token.
Terminal Transactions
For terminal transactions, make sure you pass in the terminal name using the terminalName
property.
Token Transactions
If you have a payment token, omit the terminalName
property and pass in the token with the token
property instead.
Card Numbers and Mag Stripes
You can also pass in PANs and Mag Stripes, but you probably shouldn't, as this will put you in PCI scope and the most common vector for POS breaches is key logging. If you use terminals for manual card entry, you'll bypass any key loggers that might be maliciously running on the point-of-sale system.
Cryptocurrency
Note that preauths are not supported for cryptocurrency.
Common Variations
- Manual Card Entry: Set the
ManualEntry
field to enable manual card entry. Good as a backup when chips and MSR's don't work or for more secure phone orders. You can even combine theManualEntry
field withCardType
set toCardType.EBT
for manual EBT card entry. - Inline Tokenization: You can enroll the payment method in the token vault in line with a charge transaction by setting the
Enroll
field. You'll get a token back in the response. You can even bind the token to a customer record if you also pass in customer data. - Prompting for Tips: Set the
PromptForTip
field if you'd like to prompt the customer for a tip before authorization. You can prompt for tips as part of a preauthorization, although it's not a very common approach. - Cash Discounting and Surcharging: The
Surcharge
andCashDiscount
fields can be used together to support cash discounting or surcharge problems. Consult the Cash Discount documentation for more details.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.AuthorizationRequest;
import com.blockchyp.client.dto.AuthorizationResponse;
public class PreauthExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
AuthorizationRequest request = new AuthorizationRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setAmount("27.00");
// Send the request
AuthorizationResponse response = client.preauth(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API allows you to capture a previously approved preauthorization.
You'll need to make sure you pass in the Transaction ID returned by the original preauth transaction so we know which transaction we're capturing. If you want to capture the transaction for the exact amount of the preauth, the Transaction ID is all you need to pass in.
You can adjust the total if you need to by passing in a new amount
. We
also recommend you pass in updated amounts for tax
and tip
as it can
sometimes reduce your interchange fees. (Level II Processing, for example.)
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CaptureRequest;
import com.blockchyp.client.dto.CaptureResponse;
public class CaptureExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CaptureRequest request = new CaptureRequest();
request.setTest(true);
request.setTransactionId("<ORIGINAL TRANSACTION ID>");
request.setAmount("32.00");
// Send the request
CaptureResponse response = client.capture(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
It's not ideal, but sometimes customers want their money back.
Our refund API allows you to confront this unpleasant reality by executing refunds in a few different scenarios.
The most fraud resistent method is to execute refunds in the context of a previous transaction. You should always keep track of the Transaction ID returned in a BlockChyp response. To refund the full amount of the previous transaction, just pass in the original Transaction ID with the refund requests.
Partial Refunds
For a partial refund, just pass in an amount along with the Transaction ID. The only rule is that the amount must be equal to or less than the original transaction. You can execute multiple partial refunds against the same original transaction as long as the total refunded amount doesn't exceed the original amount.
Tokenized Refunds
You can also use a token to execute a refund. Pass in a token instead of the Transaction ID and the desired refund amount.
Free Range Refunds
When you execute a refund without referencing a previous transaction, we call this a free range refund.
We don't recommend this type of refund, but it is permitted. If you absolutely insist on doing it, pass in a Terminal Name and an amount.
You can execute a manual or keyed refund by passing the ManualEntry
field
to a free range refund request.
Gift Card Refunds
Gift card refunds are allowed in the context of a previous transaction, but free range gift card refunds are not allowed. Use the gift card activation API if you need to add more funds to a gift card.
Store and Forward Support
Refunds are not permitted when a terminal falls back to store and forward mode.
Auto Voids
If a refund referencing a previous transaction is executed for the full amount before the original transaction's batch is closed, the refund is automatically converted to a void. This saves the merchant a little bit of money.
Cryptocurrency
Note that refunds are not supported for cryptocurrency. You must refund crypto transactions manually from your cryptocurrency wallet.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.RefundRequest;
import com.blockchyp.client.dto.AuthorizationResponse;
public class RefundExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
RefundRequest request = new RefundRequest();
request.setTransactionId("<PREVIOUS TRANSACTION ID>");
request.setAmount("5.00");
// Send the request
AuthorizationResponse response = client.refund(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
Mistakes happen. If a transaction is made by mistake, you can void it with this API. All that's needed is to pass in a Transaction ID and execute the void before the original transaction's batch closes.
Voids work with EBT and gift card transactions with no additional parameters.
Cryptocurrency
Note that voids are not supported for cryptocurrency. You must refund crypto transactions manually from your cryptocurrency wallet.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.VoidRequest;
import com.blockchyp.client.dto.VoidResponse;
public class VoidExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
VoidRequest request = new VoidRequest();
request.setTest(true);
request.setTransactionId("<PREVIOUS TRANSACTION ID>");
// Send the request
VoidResponse response = client.voidTx(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API allows you to retrieve card metadata.
Card metadata requests can use a payment terminal to retrieve metadata or use a previously enrolled payment token.
Terminal Transactions
For terminal transactions, make sure you pass in the terminal name using the terminalName
property.
Token Transactions
If you have a payment token, omit the terminalName
property and pass in the token with the token
property instead.
Card Numbers and Mag Stripes
You can also pass in PANs and Mag Stripes, but you probably shouldn't, as this will put you in PCI scope and the most common vector for POS breaches is keylogging. If you use terminals for manual card entry, you'll bypass any keyloggers that might be maliciously running on the point-of-sale system.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CardMetadataRequest;
import com.blockchyp.client.dto.CardMetadataResponse;
public class CardMetadataExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CardMetadataRequest request = new CardMetadataRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
// Send the request
CardMetadataResponse response = client.cardMetadata(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
Payment transactions require a stable network to function correctly and no network is stable all the time. Time out reversals are a great line of defense against accidentally double charging consumers when payments are retried during shaky network conditions.
We highly recommend developers use this API whenever a charge, preauth, or refund transaction times out. If you don't receive a definitive response from BlockChyp, you can't be certain about whether or not the transaction went through.
The best practice in this situation is to send a time out reversal request. Time out reversals check for a transaction and void it if it exists.
The only caveat is that developers must use the transactionRef
property (txRef
for the CLI) when executing charge, preauth, and refund transactions.
The reason for this requirement is that if a system never receives a definitive response for a transaction, the system would never have received the BlockChyp generated Transaction ID. We have to fall back to Transaction Ref to identify a transaction.
Cryptocurrency
Note that refunds are not supported for cryptocurrency. You must refund crypto transactions manually from your cryptocurrency wallet.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.AuthorizationRequest;
import com.blockchyp.client.dto.AuthorizationResponse;
public class ReverseExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
AuthorizationRequest request = new AuthorizationRequest();
request.setTransactionRef("<LAST TRANSACTION REF>");
// Send the request
AuthorizationResponse response = client.reverse(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API activates or adds value to BlockChyp gift cards. Just pass in the terminal name and the amount to add to the card. Once the customer swipes their card, the terminal will use keys on the mag stripe to add value to the card.
You don't need to handle a new gift card activation or a gift card recharge any differently. The terminal firmware will figure out what to do on its own while also returning the new balance for the gift card.
This is the part of the system where BlockChyp's blockchain DNA comes closest to the surface. The BlockChyp gift card system doesn't really use gift card numbers. This means they can't be stolen.
BlockChyp identifies cards with an elliptic curve public key instead. Gift card transactions are actually blocks signed with those keys. This means there are no shared secrets sent over the network. To keep track of a BlockChyp gift card, hang on to the public key returned during gift card activation. That's the gift card's elliptic curve public key.
We sometimes print numbers on our gift cards, but these are actually decimal encoded hashes of a portion of the public key to make our gift cards seem normal to normies. They can be used for balance checks and play a lookup role in online gift card authorization, but are of little use beyond that.
Voids and Reversals
Gift card activations can be voided and reversed just like any other BlockChyp transaction. Use the Transaction ID or Transaction Ref to identify the gift activation transaction as you normally would for voiding or reversing a conventional payment transaction.
Importing Gift Cards
BlockChyp does have the ability to import gift card liability from conventional gift card platforms. Unfortunately, BlockChyp does not support activating cards on third party systems. However, you can import your outstanding gift cards and customers can swipe them on the terminals like BlockChyp's standard gift cards.
No special coding is required to access this feature. The gateway and terminal firmware handle everything for you.
Third Party Gift Card Networks
BlockChyp does not currently provide any native support for other gift card platforms beyond importing gift card liability. We do have a white listing system that can be used to support your own custom gift card implementations. We have a security review process before we can allow a BIN range to be white listed, so contact [email protected] if you need to white list a BIN range.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.GiftActivateRequest;
import com.blockchyp.client.dto.GiftActivateResponse;
public class GiftActivateExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
GiftActivateRequest request = new GiftActivateRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setAmount("50.00");
// Send the request
GiftActivateResponse response = client.giftActivate(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API checks a gift or EBT card balance.
Gift Card Balance Checks
For gift cards, pass in a terminal name and the customer will be prompted to swipe a card on that terminal. The remaining balance will be displayed briefly on the terminal screen and the API response will include the gift card's public key and the remaining balance.
EBT Balance Checks
All EBT transactions require a PIN, so to check an EBT card balance,
you need to pass in the ebt
flag just like you would for a normal EBT
charge transaction. The customer will be prompted to swipe their card and
enter a PIN code. If everything checks out, the remaining balance on the
card will be displayed on the terminal for the customer and returned with the API response.
Testing Gift Card Balance Checks
Test gift card balance checks work no differently than live gift cards. You must activate a test gift card first to test balance checks. Test gift cards are real blockchain cards that live on our parallel test blockchain.
Testing EBT Gift Card Balance Checks
All test EBT transactions assume a starting balance of $100.00. As a result, test EBT balance checks always return a balance of $100.00.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.BalanceRequest;
import com.blockchyp.client.dto.BalanceResponse;
import com.blockchyp.client.dto.CardType;
public class BalanceExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
BalanceRequest request = new BalanceRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setCardType(CardType.EBT);
// Send the request
BalanceResponse response = client.balance(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API will close the merchant's batch if it's currently open.
By default, merchant batches will close automatically at 3 AM in their local time zone. The automatic batch closure time can be changed in the Merchant Profile or disabled completely.
If automatic batch closure is disabled, you'll need to use this API to close the batch manually.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CloseBatchRequest;
import com.blockchyp.client.dto.CloseBatchResponse;
public class CloseBatchExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CloseBatchRequest request = new CloseBatchRequest();
request.setTest(true);
// Send the request
CloseBatchResponse response = client.closeBatch(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API allows you to send an invoice to a customer and capture payment via a BlockChyp hosted payment page.
If you set the autoSend
flag, BlockChyp will send a basic invoice email
to the customer for you that includes the payment link. If you'd rather have
more control over the look of the email message, you can omit the autoSend
flag and send the customer email yourself.
There are a lot of optional parameters for this API, but at a minimum
you'll need to pass in a total, customer name, and email address. (Unless
you use the cashier
flag.)
Customer Info
Unless you're using the cashier
flag, you must specify a customer; either by
creating a new customer record inline or passing in an existing Customer ID or Customer Ref.
Line Item Level Data
It's not strictly required, but we strongly recommend sending line item level detail with every request. It will make the invoice look more complete and the data format for line item level data is the exact same format used for terminal line item display, so the same code can be used to support both areas.
Descriptions
You can also provide a free form description or message to display near the bottom of the invoice. Usually this is some kind of thank you note or instruction.
Terms and Conditions
You can include long form contract language with a request and capture terms and conditions accepted at the same time payment is captured.
The interface is identical to that used for the terminal based Terms and
Conditions API in that you can pass in content directly via tcContent
or via
a preconfigured template via tcAlias
. The Terms and Conditions log will also be updated when
agreement acceptance is incorporated into a send link request.
Auto Send
BlockChyp does not send the email notification automatically. This safeguard prevents real
emails from going out when you may not expect them If you want BlockChyp to send the email
for you, just add the autoSend
flag with all requests.
Cryptocurrency
If the merchant is configured to support cryptocurrency transactions, the payment page will display additional UI widgets that allowing customers to switch to a crypto payment method.
Tokenization
Add the enroll
flag to a send link request to enroll the payment method
in the token vault.
Add the enrollOnly
flag to enroll the payment method in the token vault without any immediate payment taking place. The payment link will ask the user for their payment information and inform them that they will not be charged immediately, but that their payment may be used for future transactions.
Cashier Facing Card Entry
BlockChyp can be used to generate internal/cashier facing card entry pages as well. This is designed for situations where you might need to take a phone order and don't have an available terminal.
If you pass in the cashier
flag, no email will be sent and you'll be able to
load the link in a browser or iframe for payment entry. When the cashier
flag
is used, the autoSend
flag will be ignored.
Note that cryptocurrency is not supported for cashier facing payment entry.
Payment Notifications
When a customer successfully submits payment, the merchant will receive an email notifying them that the payment was received.
Real Time Callback Notifications
Email notifications are fine, but you may want your system to be informed
immediately whenever a payment event occurs. By using the optional callbackUrl
request
property, you can specify a URL to which the Authorization Response will be posted
every time the user submits a payment, whether approved or otherwise.
The response will be sent as a JSON encoded POST request and will be the exact same format as all BlockChyp charge and preauth transaction responses.
Status Polling
If real time callbacks aren't practical or necessary in your environment, you can always use the Payment Link Status API described futher on.
A common use case for the send link API with status polling is curbside pickup. You could have your system check the Payment Link Status when a customer arrives to ensure it's been paid without necessarily needing to create background threads to constantly poll for status updates.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PaymentLinkRequest;
import com.blockchyp.client.dto.PaymentLinkResponse;
import com.blockchyp.client.dto.TransactionDisplayTransaction;
import com.blockchyp.client.dto.TransactionDisplayItem;
import com.blockchyp.client.dto.Customer;
public class SendPaymentLinkExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PaymentLinkRequest request = new PaymentLinkRequest();
request.setTransactionRef("<TX REF>");
request.setAmount("199.99");
request.setDescription("Widget");
request.setSubject("Widget invoice");
TransactionDisplayTransaction transaction = new TransactionDisplayTransaction();
transaction.setSubtotal("195.00");
transaction.setTax("4.99");
transaction.setTotal("199.99");
Collection items = new ArrayList();
TransactionDisplayItem items0 = new TransactionDisplayItem();
items0.setDescription("Widget");
items0.setPrice("195.00");
items0.setQuantity(1);
items.add(items0);
transaction.setItems(items);
request.setTransaction(transaction);
request.setAutoSend(true);
Customer customer = new Customer();
customer.setCustomerRef("Customer reference string");
customer.setFirstName("FirstName");
customer.setLastName("LastName");
customer.setCompanyName("Company Name");
customer.setEmailAddress("[email protected]");
customer.setSmsNumber("(123) 123-1231");
request.setCustomer(customer);
// Send the request
PaymentLinkResponse response = client.sendPaymentLink(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API will resend a previously created payment link. An error is returned if the payment link is expired, has been cancelled, or has already been paid.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.ResendPaymentLinkRequest;
import com.blockchyp.client.dto.ResendPaymentLinkResponse;
public class ResendPaymentLinkExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
ResendPaymentLinkRequest request = new ResendPaymentLinkRequest();
request.setLinkCode("<PAYMENT LINK CODE>");
// Send the request
ResendPaymentLinkResponse response = client.resendPaymentLink(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API cancels a payment link.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CancelPaymentLinkRequest;
import com.blockchyp.client.dto.CancelPaymentLinkResponse;
public class CancelPaymentLinkExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CancelPaymentLinkRequest request = new CancelPaymentLinkRequest();
request.setLinkCode("<PAYMENT LINK CODE>");
// Send the request
CancelPaymentLinkResponse response = client.cancelPaymentLink(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API allows you to check on the status of a payment link, including transaction data and the full history of attempted transactions.
This API is the preferred source of truth and best practice when you want to check on the status of a payment link (as opposed to Transaction Status). The Transaction Status API is not ideal because of ambiguity when there are multiple transactions associated with a single payment link.
You must pass the linkCode
value associated with the payment link. It is included in the response from BlockChyp when the payment link is originally created.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PaymentLinkStatusRequest;
import com.blockchyp.client.dto.PaymentLinkStatusResponse;
public class PaymentLinkStatusExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PaymentLinkStatusRequest request = new PaymentLinkStatusRequest();
request.setLinkCode("<PAYMENT LINK CODE>");
// Send the request
PaymentLinkStatusResponse response = client.paymentLinkStatus(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API returns the current status for any transaction. You can lookup a transaction by its BlockChyp assigned Transaction ID or your own Transaction Ref.
You should always use globally unique Transaction Ref values, but in the event that you duplicate Transaction Refs, the most recent transaction matching your Transaction Ref is returned.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TransactionStatusRequest;
import com.blockchyp.client.dto.AuthorizationResponse;
public class TransactionStatusExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TransactionStatusRequest request = new TransactionStatusRequest();
request.setTransactionId("<TRANSACTION ID>");
// Send the request
AuthorizationResponse response = client.transactionStatus(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API calculates the surcharge, cash discount, and total amounts for cash transactions.
If you're using BlockChyp's cash discounting features, you can use this endpoint to ensure the numbers and receipts for true cash transactions are consistent with transactions processed by BlockChyp.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CashDiscountRequest;
import com.blockchyp.client.dto.CashDiscountResponse;
public class CashDiscountExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CashDiscountRequest request = new CashDiscountRequest();
request.setAmount("100.00");
request.setCashDiscount(true);
request.setSurcharge(true);
// Send the request
CashDiscountResponse response = client.cashDiscount(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This endpoint allows developers to query the gateway for the merchant's batch history. The data will be returned in descending order of open date with the most recent batch returned first. The results will include basic information about the batch. Consider using the Batch Details API for more detail about a specific batch.
Limiting Results
This API will return a maximum of 250 results. Use the maxResults
property to
limit maximum results even further and use the startIndex
property to
page through results that span multiple queries.
For example, if you want the ten most recent batches, pass in a value of
10
for maxResults
. Also note that startIndex
is zero based. Use a value of 0
to
get the first batch in the dataset.
Filtering by Date Range
You can also filter results by date. Use the startDate
and endDate
properties to return only those batches opened between those dates.
You can use either startDate
and endDate
and you can use date filters
in conjunction with maxResults
and startIndex
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.BatchHistoryRequest;
import com.blockchyp.client.dto.BatchHistoryResponse;
public class BatchHistoryExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
BatchHistoryRequest request = new BatchHistoryRequest();
request.setMaxResults(250);
request.setStartIndex(0);
// Send the request
BatchHistoryResponse response = client.batchHistory(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API allows developers to pull down details for a specific batch, including captured volume, gift card activity, expected deposit, and captured volume broken down by terminal.
The only required request parameter is batchId
. Batch IDs are returned
with every transaction response and can be discovered using the Batch
History API.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.BatchDetailsRequest;
import com.blockchyp.client.dto.BatchDetailsResponse;
public class BatchDetailsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
BatchDetailsRequest request = new BatchDetailsRequest();
request.setBatchId("<BATCH ID>");
// Send the request
BatchDetailsResponse response = client.batchDetails(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This endpoint provides several different methods to sift through transaction history.
By default with no filtering properties, this endpoint will return the 250 most recent transactions.
Limiting Results
This API will return a maximum of 50 results in a single query. Use the maxResults
property
to limit maximum results even further and use the startIndex
property to
page through results that span multiple queries.
For example, if you want the ten most recent batches, pass in a value of
10
for maxResults
. Also note that startIndex
is zero based. Use a value of 0
to
get the first transaction in the dataset.
Filtering By Date Range
You can also filter results by date. Use the startDate
and endDate
properties to return only transactions run between those dates.
You can use either startDate
or endDate
and you can use date filters
in conjunction with maxResults
and startIndex
Filtering By Batch
To restrict results to a single batch, pass in the batchId
parameter.
Filtering By Terminal
To restrict results to those executed on a single terminal, pass in the terminal name.
Combining Filters
None of the above filters are mutually exclusive. You can combine any of the above properties in a single request to restrict transaction results to a narrower set of results.
Searching Transaction History
You can search transaction history by passing in search criteria with the
query
option. The search system will match the amount (requested and authorized),
last four of the card number, cardholder name, and the auth code.
Note that when search queries are used, terminalName or batch id filters are not supported.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TransactionHistoryRequest;
import com.blockchyp.client.dto.TransactionHistoryResponse;
public class TransactionHistoryExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TransactionHistoryRequest request = new TransactionHistoryRequest();
request.setMaxResults(10);
request.setBatchId("<BATCH ID>");
// Send the request
TransactionHistoryResponse response = client.transactionHistory(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
Returns a list of transaction refs of transactions queued on a terminal. Details about the transactions can be retrieved using the Transaction Status API.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.ListQueuedTransactionsRequest;
import com.blockchyp.client.dto.ListQueuedTransactionsResponse;
public class ListQueuedTransactionsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
ListQueuedTransactionsRequest request = new ListQueuedTransactionsRequest();
request.setTerminalName("Test Terminal");
// Send the request
ListQueuedTransactionsResponse response = client.listQueuedTransactions(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
Deletes one or all queued transactions from a terminal. If *
is passed as
a transaction ref, then the entire terminal queue will be cleared. An error is
returned if the passed transaction ref is not queued on the terminal.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.DeleteQueuedTransactionRequest;
import com.blockchyp.client.dto.DeleteQueuedTransactionResponse;
public class DeleteQueuedTransactionExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
DeleteQueuedTransactionRequest request = new DeleteQueuedTransactionRequest();
request.setTerminalName("Test Terminal");
request.setTransactionRef("*");
// Send the request
DeleteQueuedTransactionResponse response = client.deleteQueuedTransaction(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
These APIs support terminal management functions and additional terminal
features such as line item display, messages, and interactive prompts.
These features can be used to extend a point of sale system's functionality.
- API Credential Types: Merchant
- Required Role: Payment API Access
This simple test transaction helps ensure good communication with a payment terminal and is usually the first test you'll run in development.
It tests communication with the terminal and returns a positive response if everything is okay. It works the same way in local or cloud relay mode.
If you get a positive response, you've successfully verified all of the following:
- The terminal is online.
- There is a valid route to the terminal.
- The API Credentials are valid.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PingRequest;
import com.blockchyp.client.dto.PingResponse;
public class PingExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PingRequest request = new PingRequest();
request.setTerminalName("Test Terminal");
// Send the request
PingResponse response = client.ping(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This endpoint returns a terminal's routing and location information.
The result will indicate whether or not the terminal is in cloud relay mode and will return the local IP address if the terminal is in local mode.
The terminal will also return the public key for the terminal.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.LocateRequest;
import com.blockchyp.client.dto.LocateResponse;
public class LocateExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
LocateRequest request = new LocateRequest();
request.setTerminalName("Test Terminal");
// Send the request
LocateResponse response = client.locate(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API interrupts whatever a terminal may be doing and returns it to the idle state.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.ClearTerminalRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class ClearExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
ClearTerminalRequest request = new ClearTerminalRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
// Send the request
Acknowledgement response = client.clear(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API returns the current status of a payment terminal. This is typically used as a way to determine if the terminal is busy before sending a new transaction.
If the terminal is busy, idle
will be false and the status
field will return
a short string that indicates the transaction type currently in progress. The system
will also return the timestamp of the last status change in the since
field.
The cardInSlot
field in the response will indicates whether or not a card is currently in the card reader slot.
If the system is running a payment transaction and you wisely passed in a Transaction Ref, this API will also return the Transaction Ref of the in progress transaction.
The table below lists all possible status responses.
Status Code | Description |
---|---|
idle | The terminal is idle and ready for transactions. The default branding is being displayed. |
activate | The terminal is in the process of activating and pairing with the merchant account. |
balance | A balance check (EBT or Gift Card) is pending on the terminal. |
boolean-prompt | A boolean prompt (yes/no) operation is pending on the terminal. |
signature | A signature capture is pending. |
crypto | A cryptocurrency transaction is pending. |
enroll | A token vault enrollment operation is pending. |
gift-activate | A gift card activation operation is in progress. |
message | The terminal is displaying a custom message. |
charge | The terminal is executing a charge transaction. |
preauth | The terminal is executing a preauth transaction. |
refund | The terminal is executing a refund transaction. |
survey | The terminal is displaying post transaction survey questions. |
terms-and-conditions | The terminal is pending terms and conditions acceptance and signature. |
text-prompt | The terminal is awaiting response to a text input prompt. |
txdisplay | The terminal is displaying transaction and/or line item level details. |
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TerminalStatusRequest;
import com.blockchyp.client.dto.TerminalStatusResponse;
public class TerminalStatusExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TerminalStatusRequest request = new TerminalStatusRequest();
request.setTerminalName("Test Terminal");
// Send the request
TerminalStatusResponse response = client.terminalStatus(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This endpoint captures a written signature from the terminal and returns the image.
Unlike the Terms & Conditions API, this endpoint performs basic signature capture with no agreement display or signature archival.
Under the hood, signatures are captured in a proprietary vector format and
must be converted to a common raster format in order to be useful to most
applications. At a minimum, you must specify an image format using the
sigFormat
parameter. Currently, JPG and PNG are supported.
By default, images are returned in the JSON response as hex encoded binary.
You can redirect the binary image output to a file using the sigFile
parameter.
You can also scale the output image to your preferred width by
passing in a sigWidth
parameter. The image will be scaled to that
width, preserving the aspect ratio of the original image.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CaptureSignatureRequest;
import com.blockchyp.client.dto.CaptureSignatureResponse;
import com.blockchyp.client.dto.SignatureFormat;
public class CaptureSignatureExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CaptureSignatureRequest request = new CaptureSignatureRequest();
request.setTerminalName("Test Terminal");
request.setSigFormat(SignatureFormat.PNG);
request.setSigWidth(200);
// Send the request
CaptureSignatureResponse response = client.captureSignature(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API sends totals and line item level data to the terminal.
At a minimum, you should send total information as part of a display request,
including total
, tax
, and subtotal
.
You can also send line item level data and each line item can have a description
,
qty
, price
, and extended
price.
If you fail to send an extended price, BlockChyp will multiply the qty
by the
price
. However, we strongly recommend you precalculate all the fields yourself
to ensure consistency. For example, your treatment of floating-point multiplication
and rounding may differ slightly from BlockChyp's.
Discounts
You have the option to show discounts on the display as individual line items with negative values or you can associate discounts with a specific line item. You can apply any number of discounts to an individual line item with a description and amount.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TransactionDisplayRequest;
import com.blockchyp.client.dto.Acknowledgement;
import com.blockchyp.client.dto.TransactionDisplayTransaction;
import com.blockchyp.client.dto.TransactionDisplayItem;
import com.blockchyp.client.dto.TransactionDisplayDiscount;
public class NewTransactionDisplayExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TransactionDisplayRequest request = new TransactionDisplayRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
TransactionDisplayTransaction transaction = new TransactionDisplayTransaction();
transaction.setSubtotal("60.00");
transaction.setTax("5.00");
transaction.setTotal("65.00");
Collection items = new ArrayList();
TransactionDisplayItem items0 = new TransactionDisplayItem();
items0.setDescription("Leki Trekking Poles");
items0.setPrice("35.00");
items0.setQuantity(2);
items0.setExtended("70.00");
Collection discounts = new ArrayList();
TransactionDisplayDiscount discounts0 = new TransactionDisplayDiscount();
discounts0.setDescription("memberDiscount");
discounts0.setAmount("10.00");
discounts.add(discounts0);
items0.setDiscounts(discounts);
items.add(items0);
transaction.setItems(items);
request.setTransaction(transaction);
// Send the request
Acknowledgement response = client.newTransactionDisplay(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
Similar to New Transaction Display, this variant allows developers to update line item level data currently being displayed on the terminal.
This feature is designed for situations where you want to update the terminal display as items are scanned. You'll only have to send information to the terminal that's changed, which usually means the new line item and updated totals.
If the terminal is not in line item display mode and you invoke this endpoint, the first invocation will behave like a New Transaction Display call.
At a minimum, you should send total information as part of a display request,
including total
, tax
, and subtotal
.
You can also send line item level data and each line item can have a description
,
qty
, price
, and extended
price.
If you fail to send an extended price, BlockChyp will multiply the qty
by the
price
. However, we strongly recommend you precalculate all the fields yourself
to ensure consistency. For example, your treatment of floating-point multiplication and rounding
may differ slightly from BlockChyp's.
Discounts
You have the option to show discounts on the display as individual line items with negative values or you can associate discounts with a specific line item. You can apply any number of discounts to an individual line item with a description and amount.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TransactionDisplayRequest;
import com.blockchyp.client.dto.Acknowledgement;
import com.blockchyp.client.dto.TransactionDisplayTransaction;
import com.blockchyp.client.dto.TransactionDisplayItem;
import com.blockchyp.client.dto.TransactionDisplayDiscount;
public class UpdateTransactionDisplayExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TransactionDisplayRequest request = new TransactionDisplayRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
TransactionDisplayTransaction transaction = new TransactionDisplayTransaction();
transaction.setSubtotal("60.00");
transaction.setTax("5.00");
transaction.setTotal("65.00");
Collection items = new ArrayList();
TransactionDisplayItem items0 = new TransactionDisplayItem();
items0.setDescription("Leki Trekking Poles");
items0.setPrice("35.00");
items0.setQuantity(2);
items0.setExtended("70.00");
Collection discounts = new ArrayList();
TransactionDisplayDiscount discounts0 = new TransactionDisplayDiscount();
discounts0.setDescription("memberDiscount");
discounts0.setAmount("10.00");
discounts.add(discounts0);
items0.setDiscounts(discounts);
items.add(items0);
transaction.setItems(items);
request.setTransaction(transaction);
// Send the request
Acknowledgement response = client.updateTransactionDisplay(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API displays a message on the payment terminal.
Just specify the target terminal and the message using the message
parameter.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MessageRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class MessageExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MessageRequest request = new MessageRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setMessage("Thank you for your business.");
// Send the request
Acknowledgement response = client.message(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API prompts the customer to answer a yes or no question.
You can specify the question or prompt with the prompt
parameter and
the response is returned in the response
field.
This can be used for a number of use cases including starting a loyalty enrollment workflow or customer facing suggestive selling prompts.
Custom Captions
You can optionally override the "YES" and "NO" button captions by
using the yesCaption
and noCaption
request parameters.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.BooleanPromptRequest;
import com.blockchyp.client.dto.BooleanPromptResponse;
public class BooleanPromptExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
BooleanPromptRequest request = new BooleanPromptRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setPrompt("Would you like to become a member?");
request.setYesCaption("Yes");
request.setNoCaption("No");
// Send the request
BooleanPromptResponse response = client.booleanPrompt(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API prompts the customer to enter numeric or alphanumeric data.
Due to PCI rules, free-form prompts are not permitted when the response could be any valid string. The reason for this is that a malicious developer (not you, of course) could use text prompts to ask the customer to input a card number or PIN code.
This means that instead of providing a prompt, you provide a promptType
instead.
The prompt types currently supported are listed below:
- phone: Captures a phone number.
- email: Captures an email address.
- first-name: Captures a first name.
- last-name: Captures a last name.
- customer-number: Captures a customer number.
- rewards-number: Captures a rewards number.
You can specify the prompt with the promptType
parameter and
the response is returned in the response
field.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TextPromptRequest;
import com.blockchyp.client.dto.TextPromptResponse;
import com.blockchyp.client.dto.PromptType;
public class TextPromptExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TextPromptRequest request = new TextPromptRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setPromptType(PromptType.EMAIL);
// Send the request
TextPromptResponse response = client.textPrompt(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant & Partner
- Required Role: Terminal Management
This API returns details about terminals associated with a merchant account.
Status and resource information is returned for all terminals along with a preview of the current branding image displayed on the terminal
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TerminalProfileRequest;
import com.blockchyp.client.dto.TerminalProfileResponse;
public class TerminalsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TerminalProfileRequest request = new TerminalProfileRequest();
// Send the request
TerminalProfileResponse response = client.terminals(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant & Partner
- Required Role: Terminal Management
This API deactivates a payment terminal.
If the terminal exists and is currently online, it will be removed from the merchant's terminal inventory. The terminal will be remotely cleared and factory reset.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TerminalDeactivationRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class DeactivateTerminalExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TerminalDeactivationRequest request = new TerminalDeactivationRequest();
request.setTerminalId("<TERMINAL ID>");
// Send the request
Acknowledgement response = client.deactivateTerminal(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant & Partner
- Required Role: Terminal Management
This API activates a payment terminal.
If successful, the payment terminal will restart, generate new encryption keys, and download any active branding assets for the merchant account it's been added to.
Activation requests require an activation code and a unique terminal name. All terminal names must be unique across a merchant account.
Optional Parameters
- merchantId: For partner scoped API credentials, a merchant ID is required. For merchant scoped API credentials, the merchant ID is implicit and cannot be overridden.
- cloudRelay: Activates the terminal in cloud relay mode.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TerminalActivationRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class ActivateTerminalExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TerminalActivationRequest request = new TerminalActivationRequest();
request.setTerminalName("Test Terminal");
request.setActivationCode("<ACTIVATION CODE>");
// Send the request
Acknowledgement response = client.activateTerminal(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API reboots the terminal.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PingRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class RebootExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PingRequest request = new PingRequest();
request.setTerminalName("Test Terminal");
// Send the request
Acknowledgement response = client.reboot(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
Developers can use BlockChyp to display and capture acceptance of contracts or agreements related to transactions. These agreements can be any long-form contract ranging from rental agreements to HIPPA disclosures.
There are two basic approaches to terms and conditions capture. Merchants can store contract templates in BlockChyp or they can send the full agreement text as part of every API call. The right approach will largely depend on whether or not the system being integrated with BlockChyp already has a mechanism for organizing and managing agreements. For systems that already have this feature built in, it's probably not necessary to use Terms and Conditions.
When agreements are displayed on a terminal, the consumer can scroll through and read the entire agreement, and provide a signature. Results are returned as part of the API response, but BlockChyp also stores a record of the agreement including the signature image, timestamp, and the full text of the agreement that was agreed to.
The Terms and Conditions Log APIs can be used to search and retrieve acceptance records. Those records can also be linked to a transaction if a transaction id is provided with the original API request.
- API Credential Types: Merchant
- Required Role: Terms & Conditions Management
This API allows you to prompt a customer to accept a legal agreement on the terminal and (usually) capture their signature.
Content for the agreement can be specified in two ways. You can reference a previously configured T&C template or pass in the full agreement text with every request.
Using Templates
If your application doesn't keep track of agreements you can leverage BlockChyp's
template system. You can create any number of T&C Templates in the merchant dashboard
and pass in the tcAlias
flag to specify which one should display.
Raw Content
If your system keeps track of the agreement language or executes complicated merging
and rendering logic, you can bypass our template system and pass in the full text with
every transaction. Use tcName
to pass in the agreement name and tcContent
to
pass in the contract text. Note that only plain text is supported.
Bypassing Signatures
Signature images are captured by default. If for some reason this doesn't fit your
use case and you'd like to capture acceptance without actually capturing a signature image, set
the disableSignature
flag in the request.
Terms & Conditions Log
Every time a user accepts an agreement on the terminal, the signature image (if captured), will be uploaded to the gateway. The image will also be added to the log along with the full text of the agreement. This preserves the historical record in the event that standard agreements or templates change over time.
Associating Agreements with Transactions
To associate a Terms & Conditions log entry with a transaction, just pass in the Transaction ID or Transaction Ref for the associated transaction.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TermsAndConditionsRequest;
import com.blockchyp.client.dto.TermsAndConditionsResponse;
import com.blockchyp.client.dto.SignatureFormat;
public class TermsAndConditionsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TermsAndConditionsRequest request = new TermsAndConditionsRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
request.setTcAlias("hippa");
request.setTcName("HIPPA Disclosure");
request.setTcContent("Full contract text");
request.setSigFormat(SignatureFormat.PNG);
request.setSigWidth(200);
request.setSigRequired(true);
// Send the request
TermsAndConditionsResponse response = client.termsAndConditions(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Terms & Conditions Management
This API returns all terms and conditions templates associated with a merchant account.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TermsAndConditionsTemplateRequest;
import com.blockchyp.client.dto.TermsAndConditionsTemplateResponse;
public class TcTemplatesExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TermsAndConditionsTemplateRequest request = new TermsAndConditionsTemplateRequest();
// Send the request
TermsAndConditionsTemplateResponse response = client.tcTemplates(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Terms & Conditions Management
This API returns as single terms and conditions template.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TermsAndConditionsTemplateRequest;
import com.blockchyp.client.dto.TermsAndConditionsTemplate;
public class TcTemplateExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TermsAndConditionsTemplateRequest request = new TermsAndConditionsTemplateRequest();
request.setTemplateId("<TEMPLATE ID>");
// Send the request
TermsAndConditionsTemplate response = client.tcTemplate(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Terms & Conditions Management
This API updates or creates a terms and conditions template.
Terms and conditions templates are fairly simple and essentially consist of a name, content, and alias.
The name is the caption that will be displayed at the top of the screen. The alias is a code or short description that will be used in subsequence API calls to refer to the template.
Content is the full text of the contract or agreement. Currently, no special formatting or merge behavior is supported. Only plain text is supported.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TermsAndConditionsTemplate;
import com.blockchyp.client.dto.TermsAndConditionsTemplate;
public class TcUpdateTemplateExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TermsAndConditionsTemplate request = new TermsAndConditionsTemplate();
request.setAlias("HIPPA");
request.setName("HIPPA Disclosure");
request.setContent("Lorem ipsum dolor sit amet.");
// Send the request
TermsAndConditionsTemplate response = client.tcUpdateTemplate(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Terms & Conditions Management
This API deletes a terms and conditions template.
If a template is deleted, its alias can be reused and any previous Terms & Conditions log entry derived from the template being deleted is fully preserved since log entries always include a complete independent copy of the agreement text.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TermsAndConditionsTemplateRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class TcDeleteTemplateExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TermsAndConditionsTemplateRequest request = new TermsAndConditionsTemplateRequest();
request.setTemplateId("<TEMPLATE ID>");
// Send the request
Acknowledgement response = client.tcDeleteTemplate(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Terms & Conditions Management
This API allows developers to search and sort through terms and conditions log entries.
The default API call with no parameters will return the last 250 log entries in descending order.
Optional parameters can be used to filter and query the data set.
- transactionId: If provided, returns only those log entries associated with a specific transactions. Paging and date filters are ignored if this parameter is used.
- maxResults: The max number of results to return in a single page. Defaults to 250 and 250 is the maximum value.
- startIndex The zero based start index of results within the full result set to return. Used to advance pages. For example, if the page size is 10 and you wish to return the second page of results, send a startIndex of 10.
- startDate: An optional start date for results provided as an ISO 8601 timestamp. (e.g. 2022-05-24T13:51:38+00:00)
- endDate: An optional end date for results provided as an ISO 8601 timestamp. (e.g. 2022-05-24T13:51:38+00:00)
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TermsAndConditionsLogRequest;
import com.blockchyp.client.dto.TermsAndConditionsLogResponse;
public class TcLogExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TermsAndConditionsLogRequest request = new TermsAndConditionsLogRequest();
request.setLogEntryId("<LOG ENTRY ID>");
// Send the request
TermsAndConditionsLogResponse response = client.tcLog(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Terms & Conditions Management
This API returns details for a single terms and conditions log entry. The logEntryId
of the record to be returned is the only required parameter.
The signature image is returned as Base 64 encoded binary in the image format specified by the sigFormat
field.
The default format is PNG.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TermsAndConditionsLogRequest;
import com.blockchyp.client.dto.TermsAndConditionsLogEntry;
public class TcEntryExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TermsAndConditionsLogRequest request = new TermsAndConditionsLogRequest();
request.setLogEntryId("<ENTRY ID>");
// Send the request
TermsAndConditionsLogEntry response = client.tcEntry(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
BlockChyp supports saved payments and recurring payments through the use of tokens. Tokens can be created via the Enroll API or the web tokenizer. Once created, these tokens can be used for subsequent payments or associated with customer records as saved payment methods.
Tokens are limited to a single merchant by default, but can be shared across an organization for multi-location merchants by special arrangement with BlockChyp. Contact your BlockChyp rep to setup token sharing.
- API Credential Types: Merchant
- Required Role: Payment API Access
This API allows you to tokenize and enroll a payment method in the token vault. You can also pass in customer information and associate the payment method with a customer record.
A token is returned in the response that can be used in subsequent charge, preauth, and refund transactions.
Gift Cards and EBT
Gift Cards and EBT cards cannot be tokenized.
E-Commerce Tokens
The tokens returned by the enroll API and the e-commerce web tokenizer are the same tokens and can be used interchangeably.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.EnrollRequest;
import com.blockchyp.client.dto.EnrollResponse;
public class EnrollExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
EnrollRequest request = new EnrollRequest();
request.setTest(true);
request.setTerminalName("Test Terminal");
// Send the request
EnrollResponse response = client.enroll(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API retrieves status and metadata information about a token, including any links to customer records.
This will also return any customer records related to the card behind the token. If the underlying card has been tokenized multiple times, all customers related to the card will be returned, even if those customer associations are related to other tokens.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.TokenMetadataRequest;
import com.blockchyp.client.dto.TokenMetadataResponse;
public class TokenMetadataExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
TokenMetadataRequest request = new TokenMetadataRequest();
request.setToken("<TOKEN>");
// Send the request
TokenMetadataResponse response = client.tokenMetadata(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API links a payment token with a customer record. Usually this would only be needed to reverse a previous unlink operation.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.LinkTokenRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class LinkTokenExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
LinkTokenRequest request = new LinkTokenRequest();
request.setToken("<TOKEN>");
request.setCustomerId("<CUSTOMER ID>");
// Send the request
Acknowledgement response = client.linkToken(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API removes a payment token link from a customer record.
This will remove links between the customer record and all tokens for the same underlying card.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.UnlinkTokenRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class UnlinkTokenExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
UnlinkTokenRequest request = new UnlinkTokenRequest();
request.setToken("<TOKEN>");
request.setCustomerId("<CUSTOMER ID>");
// Send the request
Acknowledgement response = client.unlinkToken(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API deletes a payment token from the gateway. Tokens are automatically deleted if they have not been used for a year.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.DeleteTokenRequest;
import com.blockchyp.client.dto.DeleteTokenResponse;
public class DeleteTokenExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
DeleteTokenRequest request = new DeleteTokenRequest();
request.setToken("<TOKEN>");
// Send the request
DeleteTokenResponse response = client.deleteToken(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
These APIs allow developers to create and manage customer records in BlockChyp. Developers who wish to use BlockChyp for tokenized recurring payments can use tokens directly if they have their own customer management system. However, BlockChyp provides additional tools for managing customers and keeping track of a customer's saved payment tokens.
In addition, if customer features are used, BlockChyp can detect a payment method associated with an existing customer, and return customer data with payment transactions. This can be used as a passive method to detect repeat customers.
- API Credential Types: Merchant
- Required Role: Payment API Access
This API adds or updates a customer record.
If you pass in customer information including firstName
, lastName
, email
,
or sms
without any Customer ID or Customer Ref, a new record will
be created.
If you pass in customerRef
and customerId
, the customer record will be updated
if it exists.
Customer Ref
The customerRef
field is optional, but highly recommended as this allows you
to use your own customer identifiers instead of storing BlockChyp's Customer IDs
in your systems.
Creating Customer Records With Payment Transactions
If you have customer information available at the time a payment transaction is executed, you can pass all the same customer information directly into a payment transaction. BlockChyp will create a customer record at the same time payment is captured. The advantage of this approach is that the customer's payment card is automatically associated with the customer record in a single step. If the customer uses the payment card in the future, the customer data will automatically be returned. You won't need to ask the customer to provide any additional information.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.UpdateCustomerRequest;
import com.blockchyp.client.dto.CustomerResponse;
import com.blockchyp.client.dto.Customer;
public class UpdateCustomerExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
UpdateCustomerRequest request = new UpdateCustomerRequest();
Customer customer = new Customer();
customer.setId("<CUSTOMER ID>");
customer.setCustomerRef("Customer reference string");
customer.setFirstName("FirstName");
customer.setLastName("LastName");
customer.setCompanyName("Company Name");
customer.setEmailAddress("[email protected]");
customer.setSmsNumber("(123) 123-1231");
request.setCustomer(customer);
// Send the request
CustomerResponse response = client.updateCustomer(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
With this API, you can retrieve detailed information about a customer record, including saved payment methods if available.
Customers can be looked up by customerId
or customerRef
.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CustomerRequest;
import com.blockchyp.client.dto.CustomerResponse;
public class CustomerExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CustomerRequest request = new CustomerRequest();
request.setCustomerId("<CUSTOMER ID>");
// Send the request
CustomerResponse response = client.customer(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API searches the customer database and returns matching results.
Use query
to pass in a search string and the system will return all results whose
first or last names contain the query string.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.CustomerSearchRequest;
import com.blockchyp.client.dto.CustomerSearchResponse;
public class CustomerSearchExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
CustomerSearchRequest request = new CustomerSearchRequest();
request.setQuery("(123) 123-1234");
// Send the request
CustomerSearchResponse response = client.customerSearch(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Payment API Access
This API deletes a customer record.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.DeleteCustomerRequest;
import com.blockchyp.client.dto.DeleteCustomerResponse;
public class DeleteCustomerExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
DeleteCustomerRequest request = new DeleteCustomerRequest();
request.setCustomerId("<CUSTOMER ID>");
// Send the request
DeleteCustomerResponse response = client.deleteCustomer(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
These APIs are used to work with post-transaction surveys and survey data.
Merchants can optionally configure scaled (1-5) or yes/no questions that can be presented to consumers after every approved Charge and Preauth transaction. Surveys do not require any custom programming and merchants can simply configure them without the point-of-sale system needing any additional customization.
However, these APIs allow point-of-sale or third-party system developers to integrate survey question configuration or result visualization into their own systems.
- API Credential Types: Merchant
- Required Role: Survey Management
This API returns all survey questions in the order in which they would be presented on the terminal.
All questions are returned, whether enabled or disabled.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SurveyQuestionRequest;
import com.blockchyp.client.dto.SurveyQuestionResponse;
public class SurveyQuestionsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SurveyQuestionRequest request = new SurveyQuestionRequest();
// Send the request
SurveyQuestionResponse response = client.surveyQuestions(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Survey Management
This API returns a single survey question with response data. questionId
is required.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SurveyQuestionRequest;
import com.blockchyp.client.dto.SurveyQuestion;
public class SurveyQuestionExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SurveyQuestionRequest request = new SurveyQuestionRequest();
request.setQuestionId("<QUESTION ID>");
// Send the request
SurveyQuestion response = client.surveyQuestion(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Survey Management
This API updates or creates survey questions. questionText
and questionType
are required
fields. The following values are valid for questionType
.
- yes_no: Use for simple yes or no questions.
- scaled: Displays the question with buttons that allow the customer to respond with values from 1 through 5.
Questions are disabled by default. Pass in enabled
to enable a question.
The ordinal
field is used to control the sequence of questions when multiple questions are enabled. We recommend keeping
the number of questions minimal.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SurveyQuestion;
import com.blockchyp.client.dto.SurveyQuestion;
public class UpdateSurveyQuestionExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SurveyQuestion request = new SurveyQuestion();
request.setId("<QUESTION ID>");
request.setOrdinal(1);
request.setQuestionText("Would you shop here again?");
request.setQuestionType("yes_no");
request.setEnabled(true);
// Send the request
SurveyQuestion response = client.updateSurveyQuestion(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Survey Management
This API deletes a survey question. questionId
is a required parameter.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SurveyQuestionRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class DeleteSurveyQuestionExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SurveyQuestionRequest request = new SurveyQuestionRequest();
request.setQuestionId("<QUESTION ID>");
// Send the request
Acknowledgement response = client.deleteSurveyQuestion(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant
- Required Role: Survey Management
This API returns survey results for a single question.
The results returned include the response rate, which is the percentage of transactions after which the consumer provided an answer.
The responses
array breaks down the results by answer, providing the total number of responses,
the answer's percentage of the total, and the average transaction amount associated with a specific
answer.
By default, all results based on all responses are returned. However, developers may optionally provide
startDate
and endDate
parameters to return only responses provided between certain dates.
startDate
and endDate
can be provided in MM/DD/YYYY or YYYY-MM-DD format.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SurveyResultsRequest;
import com.blockchyp.client.dto.SurveyQuestion;
public class SurveyResultsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SurveyResultsRequest request = new SurveyResultsRequest();
request.setQuestionId("<QUESTION ID>");
// Send the request
SurveyQuestion response = client.surveyResults(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
BlockChyp has a sophisticated terminal media and branding control platform. Terminals can be configured to display logos, images, videos, and slide shows when a terminal is idle. Branding assets can be configured at the partner, organization, and merchant level with fine-grained hour-by-hour schedules, if desired.
Conceptually, all branding and media start with the media library. Merchants, Partners, and Organizations can upload images or video and build branding assets from uploaded media.
Slide shows can combine images from the media library into a timed loop of repeating images.
Branding Assets can then be used to combine media or slide shows with priority and timing rules to create what we call the Terminal Branding Stack.
We call a group of branding assets the Terminal Branding Stack because there are implicit rules about which branding assets take priority. For example, a merchant with no branding assets configured will inherit the branding rules from any organization to which the merchant may belong. If the merchant doesn't belong to an organization or the organization has no branding rules configured, then the system will defer to branding defaults established by the point-of-sale or software partner that owns the merchant.
This feature enables partners and organizations (multi-store operators and large national chains) to configure branding for potentially thousands of terminals from a single interface.
Terminal Branding can also be configured at the individual terminal level and a merchant's terminal fleet can be broken into groups and branding configured at the group level. Branding configured at the terminal level will always override branding from any higher level group.
The order of priority for the Terminal Branding Stack is given below.
- Terminal
- Terminal Group
- Merchant
- Organization (Region, Chain, etc)
- Partner
- BlockChyp Default Logo
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API returns the entire media library associated with the API Credentials (Merchant, Partner, or Organization). The media library results will include the ID used to reference a media asset in slide shows and branding assets along with the full file url and thumbnail.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MediaRequest;
import com.blockchyp.client.dto.MediaLibraryResponse;
public class MediaExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MediaRequest request = new MediaRequest();
// Send the request
MediaLibraryResponse response = client.media(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API supports media library uploads. The operation of this API works slightly differently depending on the SDK platform. In all cases, the intent is to allow the file's binary to be passed into the SDK using the lowest level I/O primitive possible in order to support situations where developers aren't working with literal files. It might be (and usually is) more convenient to work with buffers, raw bytes, or streams.
For example, the Go implementation accepts an io.Reader
and the Java implementation accepts a
java.io.InputStream
. The CLI does accept a literal File URL via the -file
command line parameter.
The following file formats are accepted as valid uploads:
- .png
- .jpg
- .jpeg
- .gif
- .mov
- .mpg
- .mp4
- .mpeg
The UploadMetadata object allows developers to pass additional metadata about the upload including
fileName
, fileSize
, and uploadId
.
None of these values are required, but providing them can unlock some additional functionality relating to
media uploads. fileName
will be used to record the original file name in the media library. fileSize
and uploadId
are used to support upload status tracking, which is especially useful for large video file
uploads.
The fileSize
should be the file's full size in bytes.
The uploadId
value can be any random string. This is the value you'll use to check the status of an upload
via the Upload Status API. This API will return information needed to drive progress feedback on uploads and
return video transcoding information.
package com.blockchyp.client.examples;
import java.io.File;
import java.io.InputStream;
import java.io.FileInputStream;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.UploadMetadata;
import com.blockchyp.client.dto.MediaMetadata;
public class UploadMediaExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
UploadMetadata request = new UploadMetadata();
request.setFileName("aviato.png");
request.setFileSize(18843);
request.setUploadId("<RANDOM ID>");
// Send the request
InputStream inStream = new FileInputStream(new File("aviato.png"));
MediaMetadata response = client.uploadMedia(request, inStream);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API returns status and progress information about in progress or recently completed uploads.
Before calling this API, developers must first start a file upload with fileSize
and uploadId
parameters.
The data structure returned will include the file size, number of bytes uploaded, a narrative status
and flags indicating whether or not the upload is complete or post upload processing is in progress.
If the upload is completed, the ID assigned to the media asset and a link to the thumbnail image will
also be returned.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.UploadStatusRequest;
import com.blockchyp.client.dto.UploadStatus;
public class UploadStatusExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
UploadStatusRequest request = new UploadStatusRequest();
request.setUploadId("<UPLOAD ID>");
// Send the request
UploadStatus response = client.uploadStatus(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API returns a detailed media asset. The data returned includes the exact same media information returned by the full media library endpoint, including fully qualified URLs pointing to the original media file and the thumbnail.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MediaRequest;
import com.blockchyp.client.dto.MediaMetadata;
public class MediaAssetExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MediaRequest request = new MediaRequest();
request.setMediaId("<MEDIA ASSET ID>");
// Send the request
MediaMetadata response = client.mediaAsset(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API deletes a media asset. Note that a media asset cannot be deleted if it is in use in a slide show or in the terminal branding stack.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MediaRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class DeleteMediaAssetExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MediaRequest request = new MediaRequest();
request.setMediaId("<MEDIA ASSET ID>");
// Send the request
Acknowledgement response = client.deleteMediaAsset(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API returns all slide shows.
Note that slide level data is not returned with this API. Use the Get Slide Show API to get slide level detail.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SlideShowRequest;
import com.blockchyp.client.dto.SlideShowResponse;
public class SlideShowsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SlideShowRequest request = new SlideShowRequest();
// Send the request
SlideShowResponse response = client.slideShows(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API returns a single slide show. Slide level detail is returned with the fully qualified thumbnail URL for each slide.
slideShowId
is the only required parameter.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SlideShowRequest;
import com.blockchyp.client.dto.SlideShow;
public class SlideShowExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SlideShowRequest request = new SlideShowRequest();
request.setSlideShowId("<SLIDE SHOW ID>");
// Send the request
SlideShow response = client.slideShow(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API updates or creates a slide show. name
, delay
and slides
are required.
The slides property is an array of slides. The Slide data structure has ordinal and thumbnail URL fields,
but these are not required when updating or creating a slide show. Only the mediaId
field is required
when updating or creating a slide show.
When using the CLI, slides can be specified by sending a comma-separated list of media ids via the -mediaId
parameter.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SlideShow;
import com.blockchyp.client.dto.SlideShow;
import com.blockchyp.client.dto.Slide;
public class UpdateSlideShowExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SlideShow request = new SlideShow();
request.setName("Test Slide Show");
request.setDelay(5);
Collection slides = new ArrayList();
Slide slides0 = new Slide();
slides0.setMediaId("<MEDIA ID>");
slides.add(slides0);
request.setSlides(slides);
// Send the request
SlideShow response = client.updateSlideShow(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API deletes a slide show slideShowId
is the only required parameter.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SlideShowRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class DeleteSlideShowExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SlideShowRequest request = new SlideShowRequest();
request.setSlideShowId("<SLIDE SHOW ID>");
// Send the request
Acknowledgement response = client.deleteSlideShow(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API returns the full branding stack for a given API scope in the order of priority.
Consumers of this API should pay special attention to the editable
field. This field indicates whether or
not a branding asset is read-only from the perspective of a particular API Credential scope.
The thumbnail
and previewImage
attributes can be used to support building user interfaces for
managing the branding stack. previewImage
differs from thumbnail
in that the preview image is
intended to show how an asset would actually look when displayed on the terminal.
activeAsset
returns the asset that is currently visible on the terminal.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.BrandingAssetRequest;
import com.blockchyp.client.dto.BrandingAssetResponse;
public class TerminalBrandingExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
BrandingAssetRequest request = new BrandingAssetRequest();
// Send the request
BrandingAssetResponse response = client.terminalBranding(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API updates or creates a single Branding Asset.
Branding Assets represent a single element of the terminal branding stack. A Branding Asset can be a video or image,
in which case a mediaId
referencing an asset from the media library must be provided. A Branding Asset can also
be a slide show, in which case slideShowId
must be provided. Branding Assets must have a valid mediaId
or a valid
slideShowId
. The optional notes
field can be used to provide short notes and descriptions for a Branding asset.
Visibility Flags
In order for a Branding Asset to be visible on a terminal, the enabled
flag must be set to true and the preview
must be turned off. preview
is intended to show how a proposed Branding Asset will behave
without pushing it to live terminals. The Publish button in the BlockChyp merchant portal effectively turns
the preview
setting off.
Order and Sequencing
The ordinal
field is used to specify priority for a Branding Asset. Assets with a higher value for ordinal
will be prioritized first.
Padding Images
For plain images, it's sometimes helpful to add margins to images. This is especially helpful with logos
or any image file rendered without any white space or margins between the image content and edge of the image file.
Set the padded
flag to true if you'd like BlockChyp to auto apply margins when displaying an image on
the terminal.
Scheduling
By default, a Branding Asset placed on top of the Branding Stack, if it's enabled
and not in preview
mode, will immediately be displayed on the terminal round the clock.
Branding Assets can be scheduled with effective start and stop dates for seasonal campaigns. These assets can also be scheduled for specific times of day and specific days of the week.
- startDate: Optional date after which the Branding Asset is eligible for display. Can be provided in MM/DD/YYYY or YYYY-MM-DD format.
- endDate: Optional date before which the Branding Asset is eligible for display. Can be provided in MM/DD/YYYY or YYYY-MM-DD format.
- startTime Optional time of day after which the branding asset is eligible for display. Must be provided in 24 hour time: HH:MM.
- endTime Optional time of day before which the branding asset is eligible for display. Must be provided in 24 hour time format: HH:MM
- daysOfWeek For branding assets that should only be displayed on certain days of the week, this field is an array of day of the week constants. (Constants vary by SDK platform.)
Read Only Fields
The Branding Asset data structure has a number of read only fields that are returned when Branding Assets are retrieved. But these fields are ignored when you try to send them as part of an update. These are derived or calculated fields and are helpful for displaying branding assets in a management user interface, but cannot be changed via an API call.
These fields are:
- ownerId
- merchantId
- organizationId
- partnerId
- userId
- userName
- thumbnail
- lastModified
- editable
- assetType
- ownerType
- ownerTypeCaption
- previewImage
- narrativeEffectiveDates
- narrativeDisplayPeriod
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.BrandingAsset;
import com.blockchyp.client.dto.BrandingAsset;
public class UpdateBrandingAssetExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
BrandingAsset request = new BrandingAsset();
request.setMediaId("<MEDIA ID>");
request.setPadded(true);
request.setOrdinal(10);
request.setStartDate("01/06/2021");
request.setStartTime("14:00");
request.setEndDate("11/05/2024");
request.setEndTime("16:00");
request.setNotes("Test Branding Asset");
request.setPreview(false);
request.setEnabled(true);
// Send the request
BrandingAsset response = client.updateBrandingAsset(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Media Management
This API deletes a Branding Asset from the branding stack.
Note that deleting a Branding Asset does not delete the underlying media from the media library or slide show from the slide show library.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.BrandingAssetRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class DeleteBrandingAssetExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
BrandingAssetRequest request = new BrandingAssetRequest();
request.setAssetId("<BRANDING ASSET ID>");
// Send the request
Acknowledgement response = client.deleteBrandingAsset(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
These APIs allow partners to manage and configure their merchant portfolios.
Use of these APIs (other than the Merchant Profile API) requires partner scoped API credentials with special roles and permissions that may require a special arrangement with BlockChyp.
For example, Partners usually can't board merchants directly, but must board merchants using the standard underwriting process via offer codes and invitations.
- API Credential Types: Merchant
- Required Role: Payment API Access
The API returns detailed metadata about the merchant's configuration, including basic identity information, terminal settings, store and forward settings, and bank account information for merchants that support split settlement.
Some of these fields can be updated via the Update Merchant API, but many of these fields are controlled by underwriting and cannot be altered outside of the underwriting and risk processes.
Merchant Descriptive Fields
The following fields are basic descriptive fields that can be used to describe and identify merchants.
- companyName: The merchant's official corporate entity name.
- dbaName: The business's DBA (doing business as) name.
- contactName: Name of the merchant's primary control contact.
- contactNumber: Primary control contact's phone number.
- locationName: Optional location name for multi-location operators.
- storeNumber: Optional store number for multi-location operators.
- partnerRef: Optional reference number partners can add to a merchant record. Usually the partner's own identifier for the merchant.
- timeZone: Unix style local time zone for the merchant. Example: America/New_York.
- publicKey: Read only field. The merchant's blockchain public key. Generated and assigned when a merchant account is first created.
- billingAddress: Address for billing and written correspondence.
- shippingAddress: Physical shipping address. Usually the actual street address of the business.
- status: Current status of the merchant account.
- tcDisabled: Disables all terms and conditions features in the merchant dashboard. Used to hide the feature if a partner has not chosen to support it.
- gatewayOnly: Indicates that a merchant has been boarded in gateway only mode. Not common.
Batch and Terminal Settings
The following fields are used to control batch closure and high level terminal configuration.
- batchCloseTime: Time in 24 hour HH:MM format when batches will automatically close in the merchant's local time. Defaults to 3 AM.
- autoBatchClose: Flag the determines whether or not batches will automatically close. Defaults to true.
- disableBatchEmails: Flag that optionally turns off automatic batch closure notification emails.
- cooldownTimeout: The amount of time in seconds after a transactions for which the transaction response is displayed on the terminal. After the cooldown period elapses, the terminal will revert to the idle state and display the currently active terminal branding.
- surveyTimeout: The amount of time in seconds a survey question should be displayed on a terminal before reverting to the idle screen.
- pinEnabled: Enables pin code entry for debit cards, EBT cards, and EMV cards with pin CVMs. Will be ignored if terminals are not injected with the proper encryption keys.
- pinBypassEnabled: Enable pin bypass for debit transactions.
- cashBackEnabled: Enables cash back for debit transactions.
- cashbackPresets: An array of four default values for cashback amounts when cashback is enabled.
- storeAndForwardEnabled: Enables automatic store and forward during network outages. Store and Forward does not support cash back, refunds, EBT, or gift card transactions.
- storeAndForwardFloorLimit: Maximum dollar value of a store and forward transaction.
- ebtEnabled: Enables EBT (SNAP) on BlockChyp terminals.
- tipEnabled: Enables tips entry on the terminal.
- promptForTip: If true, the terminal will always prompt for a tip, even if the API call does not request a tip prompt.
- tipDefaults: An array of exactly three percentages that will be used to calculate default tip amounts.
- giftCardsDisabled: Disables BlockChyp gift cards. Normally only used if the merchant is using an alternate gift card system.
- digitalSignaturesEnabled: Enables electronic signature capture for mag stripe cards and EMV cards with Signature CVMs.
- digitalSignatureReversal: Will cause a transaction to auto-reverse if the consumer refuses to provide a signature.
- manualEntryEnabled: Enables manual card entry.
- manualEntryPromptZip: Requires zip code based address verification for manual card entry.
- manualEntryPromptStreetNumber: Requires street/address based verification for manual card entry.
Card Brand and Transaction Settings
- freeRangeRefundsEnabled: Enables direct refunds that do not reference a previous transaction.
- partialAuthEnabled: Indicates that partial authorizations (usually for gift card support) are enabled.
- splitBankAccountsEnabled: Used for law firm merchants only.
- contactlessEmv: Enables contactless/tap transactions on a terminal. Defaults to true.
- visa: Enables Visa transactions.
- masterCard: Enables MasterCard transactions.
- amex: Enables American Express transactions.
- discover: Enables Discover transactions.
- jcb: Enables JCB (Japan Card Bureau) transactions.
- unionPay: Enables China UnionPay transactions.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MerchantProfileRequest;
import com.blockchyp.client.dto.MerchantProfileResponse;
public class MerchantProfileExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MerchantProfileRequest request = new MerchantProfileRequest();
// Send the request
MerchantProfileResponse response = client.merchantProfile(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner & Organization
- Required Role: Merchant Management
This is a partner or organization level API that can be used to return the merchant portfolio.
Live merchants are returned by default. Use the test
flag to return only test merchants. The
results returned include detailed settings including underwriting controlled flags.
A maximum of 250 merchants are returned by default. For large merchant portfolios, the maxResults
and startIndex
field can be used to reduce the page size and page through multiple pages of results.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.GetMerchantsRequest;
import com.blockchyp.client.dto.GetMerchantsResponse;
public class GetMerchantsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
GetMerchantsRequest request = new GetMerchantsRequest();
request.setTest(true);
// Send the request
GetMerchantsResponse response = client.getMerchants(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Merchant, Partner, & Organization
- Required Role: Merchant Management
This API can be used to update or create merchant accounts.
Merchant scoped API credentials can be used to update merchant account settings.
Partner scoped API credentials can be used to update merchants, create new test merchants or board new gateway merchants.
Merchant Descriptive Fields
The following fields are basic descriptive fields that can be used to describe and identify merchants.
- companyName: The merchant's official corporate entity name.
- dbaName: The businesses DBA (doing business as) name.
- contactName: Name of the merchant's primary control contact.
- contactNumber: Primary control contact's phone number.
- locationName: Optional location name for multi location operators.
- storeNumber: Optional store number for multi location operators.
- partnerRef: Optional reference number partners can add to a merchant record. Usually the partner's own identifier for the merchant.
- timeZone: Unix style local time zone for the merchant. Example: America/New_York.
- publicKey: Read only field. The merchant's blockchain public key. Generated and assigned when a merchant account is first created.
- billingAddress: Address for billing and written correspondence.
- shippingAddress: Physical shipping address. Usually the actual street address of the business.
- status: Current status of the merchant account.
- tcDisabled: Disables all terms and conditions features in the merchant dashboard. Used to hide the feature if a partner has not chosen to support it.
- gatewayOnly: Indicates that a merchant has been boarded in gateway only mode. Not common.
Batch and Terminal Settings
The following fields are used to control batch closure and high level terminal configuration.
- batchCloseTime: Time in 24 hour HH:MM format when batches will automatically close in the merchant's local time. Defaults to 3 AM.
- autoBatchClose: Flag the determines whether or not batches will automatically close. Defaults to true.
- disableBatchEmails: Flag that optionally turns off automatic batch closure notification emails.
- cooldownTimeout: The amount of time in seconds after a transactions for which the transaction response is displayed on the terminal. After the cooldown period elapses, the terminal will revert to the idle state and display the currently active terminal branding.
- surveyTimeout: The amount of time in seconds a survey question should be displayed on a terminal before reverting to the idle screen.
- pinEnabled: Enables pin code entry for debit cards, EBT cards, and EMV cards with pin CVMs. Will be ignored if terminals are not injected with the proper encryption keys.
- pinBypassEnabled: Enable pin bypass for debit transactions.
- cashBackEnabled: Enables cash back for debit transactions.
- cashbackPresets: An array of four default values for cashback amounts when cashback is enabled.
- storeAndForwardEnabled: Enables automatic store and forward during network outages. Store and Forward does not support cash back, refunds, EBT, or gift card transactions.
- storeAndForwardFloorLimit: Maximum dollar value of a store and forward transaction.
- ebtEnabled: Enables EBT (SNAP) on BlockChyp terminals.
- tipEnabled: Enables tips entry on the terminal.
- promptForTip: If true, the terminal will always prompt for a tip, even if the API call does not request a tip prompt.
- tipDefaults: An array of exactly three percentages that will be used to calculate default tip amounts.
- giftCardsDisabled: Disables BlockChyp gift cards. Normally only used if the merchant is using an alternate gift card system.
- digitalSignaturesEnabled: Enables electronic signature capture for mag stripe cards and EMV cards with Signature CVMs.
- digitalSignatureReversal: Will cause a transaction to auto-reverse if the consumer refuses to provide a signature.
- manualEntryEnabled: Enables manual card entry.
- manualEntryPromptZip: Requires zip code based address verification for manual card entry.
- manualEntryPromptStreetNumber: Requires street/address based verification for manual card entry.
Card Brand and Transaction Settings
- freeRangeRefundsEnabled: Enables direct refunds that do not reference a previous transaction.
- partialAuthEnabled: Indicates that partial authorizations (usually for gift card support) are enabled.
- splitBankAccountsEnabled: Used for law firm merchants only.
- contactlessEmv: Enables contactless/tap transactions on a terminal. Defaults to true.
- visa: Enables Visa transactions.
- masterCard: Enables MasterCard transactions.
- amex: Enables American Express transactions.
- discover: Enables Discover transactions.
- jcb: Enables JCB (Japan Card Bureau) transactions.
- unionPay: Enables China UnionPay transactions.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MerchantProfile;
import com.blockchyp.client.dto.MerchantProfileResponse;
import com.blockchyp.client.dto.Address;
public class UpdateMerchantExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MerchantProfile request = new MerchantProfile();
request.setMerchantId("<MERCHANT ID>");
request.setTest(true);
request.setDbaName("Test Merchant");
request.setCompanyName("Test Merchant");
Address billingAddress = new Address();
billingAddress.setAddress1("1060 West Addison");
billingAddress.setCity("Chicago");
billingAddress.setStateOrProvince("IL");
billingAddress.setPostalCode("60613");
request.setBillingAddress(billingAddress);
// Send the request
MerchantProfileResponse response = client.updateMerchant(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner & Organization
- Required Role: Merchant Management
This API returns all users and pending invites associated with a merchant account including any assigned role codes.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MerchantProfileRequest;
import com.blockchyp.client.dto.MerchantUsersResponse;
public class MerchantUsersExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MerchantProfileRequest request = new MerchantProfileRequest();
request.setMerchantId("<MERCHANT ID>");
// Send the request
MerchantUsersResponse response = client.merchantUsers(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner & Organization
- Required Role: Merchant Management
Invites a new user to join a merchant account. email
, firstName
, and lastName
are required.
The user will be sent an invite email with steps for creating a BlockChyp account and linking it to a merchant account. If the user already has a BlockChyp user account, the new user signup wil be skipped and the existing user account will be linked to the merchant account.
Developers can optionally restrict the user's access level by sending one or more role codes. Otherwise, the user will be given the default merchant user role. (STDMERCHANT)
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.InviteMerchantUserRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class InviteMerchantUserExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
InviteMerchantUserRequest request = new InviteMerchantUserRequest();
request.setEmail("Email address for the invite");
// Send the request
Acknowledgement response = client.inviteMerchantUser(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Gateway Boarding
This is a partner level API that can be used to manually board gateway merchants. Use this API in conjunction with Platform Configuration to instantly board gateway merchants. Note that most partners don't have permission to do this and are unlikely to get it.
Settings can be changed by using the Update Merchant API.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.AddGatewayMerchantRequest;
import com.blockchyp.client.dto.MerchantProfileResponse;
import com.blockchyp.client.dto.MerchantProfile;
public class AddGatewayMerchantExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
AddGatewayMerchantRequest request = new AddGatewayMerchantRequest();
MerchantProfile profile = new MerchantProfile();
profile.setDbaName("DBA Name");
profile.setCompanyName("Corporate Entity Name");
request.setProfile(profile);
// Send the request
MerchantProfileResponse response = client.addGatewayMerchant(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Merchant Management
This is a partner level API that can be used to create test merchant accounts. This creates a basic test merchant with default settings.
Settings can be changed by using the Update Merchant API.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.AddTestMerchantRequest;
import com.blockchyp.client.dto.MerchantProfileResponse;
public class AddTestMerchantExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
AddTestMerchantRequest request = new AddTestMerchantRequest();
request.setDbaName("DBA Name");
request.setCompanyName("Corporate Entity Name");
// Send the request
MerchantProfileResponse response = client.addTestMerchant(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Merchant Management
This partner API can be used to delete unused test merchant accounts. merchantId
is a required parameter.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MerchantProfileRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class DeleteTestMerchantExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MerchantProfileRequest request = new MerchantProfileRequest();
request.setMerchantId("<MERCHANT ID>");
// Send the request
Acknowledgement response = client.deleteTestMerchant(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
These partner only APIs give ISV partners advanced reporting and tools for managing their portfolio.
Most of the APIs below are for portfolio reporting and range from basic partner commission statements to individual statements with all underlying card brand data.
We also provide a pricing policy API that enables partners to pull down the current pricing rules in force for any merchant in their portfolio.
Currency DataAll partner APIs return currency and percentage values in two formats: floating point and formatted strings.
It's recommended that all developers use the formatted string as this will ensure the most precise values. Floating point numbers are usually not appropriate for currency or fixed point decimal numbers as the underlying binary encoding can lead to errors in precision. We provide floating point values only as a convenience for developers want to save development time and can live with approximated values in their use case.
- API Credential Types: Partner
- Required Role: Partner API Access
The API returns the current pricing policy for a merchant. This API is valid for partner scoped API credentials
and merchantId
is a required parameter. By default this API returns the currently in-force pricing policy for a merchant,
but other inactive policies can be returned by providing the id
parameter.
Buy rates for interchange plus and fixed rate pricing are always returned, but only the pricing related to the pricing model type (flat rate or interchange plus) are actually used in fee calculation.
Each pricing level returns three values: buyRate
, current
, and limit
. The actual price the merchant will pay is
given in the current
field. The other values reflect the contract minimum (buyRate
) and maximum (limit
) range
the partner can use when changing prices.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PricingPolicyRequest;
import com.blockchyp.client.dto.PricingPolicyResponse;
public class PricingPolicyExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PricingPolicyRequest request = new PricingPolicyRequest();
// Send the request
PricingPolicyResponse response = client.pricingPolicy(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Partner API Access
The API returns a list of partner residual statements. By default, all statements are returned with the most recent
statements listed first. Optional date parameters (startDate
and endDate
) can filter statements to a specific date range.
The list of statements returns basic information about statements like volume, transaction count, and commissions earned.
Use the id
returned with each statement summary with the Partner Statement Detail API to pull down full details.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PartnerStatementListRequest;
import com.blockchyp.client.dto.PartnerStatementListResponse;
public class PartnerStatementsExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PartnerStatementListRequest request = new PartnerStatementListRequest();
// Send the request
PartnerStatementListResponse response = client.partnerStatements(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Partner API Access
The API returns detailed information about a specific partner statement. Aggregate data is returned along with line item level data for each underlying merchant statement.
Use the merchant invoice id with the Merchant Statement Detail API and the Partner Commission Breakdown API to get the merchant statement and the card brand fee cost breakdown respectively.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PartnerStatementDetailRequest;
import com.blockchyp.client.dto.PartnerStatementDetailResponse;
public class PartnerStatementDetailExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PartnerStatementDetailRequest request = new PartnerStatementDetailRequest();
// Send the request
PartnerStatementDetailResponse response = client.partnerStatementDetail(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner or Merchant
- Required Role: Partner API Access or Merchant API
The API returns a list of merchant statements and invoices. By default, all invoices are returned with the most recent
statements listed first. Optional date parameters (startDate
and endDate
) can be used to filter statements by date
range.
The invoiceType
parameter can also be used to filter invoices by type. Invoices could be conventional invoices, such
as those generated when ordering terminals or gift cards, or invoices could be merchant statements.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MerchantInvoiceListRequest;
import com.blockchyp.client.dto.MerchantInvoiceListResponse;
public class MerchantInvoicesExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MerchantInvoiceListRequest request = new MerchantInvoiceListRequest();
// Send the request
MerchantInvoiceListResponse response = client.merchantInvoices(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Partner API Access
The API returns detailed information about a specific merchant statement or invoice.
All line items are returned a topographically sorted tree modeling the nested line item structure of the invoice. Details about any payments posted against the invoice are returned.
It the invoice is a merchant statement, details about every merchant deposit that occurred during the statement period are also returned.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MerchantInvoiceDetailRequest;
import com.blockchyp.client.dto.MerchantInvoiceDetailResponse;
public class MerchantInvoiceDetailExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MerchantInvoiceDetailRequest request = new MerchantInvoiceDetailRequest();
// Send the request
MerchantInvoiceDetailResponse response = client.merchantInvoiceDetail(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Partner API Access
This API allows partners to pull down the low level data used to compute a partner commission for a specific merchant statement.
The statementId
is required and must be the id of a valid merchant invoice of type statement
.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.PartnerCommissionBreakdownRequest;
import com.blockchyp.client.dto.PartnerCommissionBreakdownResponse;
public class PartnerCommissionBreakdownExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
PartnerCommissionBreakdownRequest request = new PartnerCommissionBreakdownRequest();
// Send the request
PartnerCommissionBreakdownResponse response = client.partnerCommissionBreakdown(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: Partner API Access
This API allows partners to generate API credentials for a merchant.
The merchantId
is required and must be the id of a valid merchant.
Credentials are not delete protected by default. Pass in deleteProtected
to enable delete protection.
The optional notes
field will populate the notes in the credentials.
By default no roles will be assigned unless valid, comma-delimited, role codes are passed in the roles
field.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.MerchantCredentialGenerationRequest;
import com.blockchyp.client.dto.MerchantCredentialGenerationResponse;
public class MerchantCredentialGenerationExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
MerchantCredentialGenerationRequest request = new MerchantCredentialGenerationRequest();
request.setMerchantId("<MERCHANT ID>");
// Send the request
MerchantCredentialGenerationResponse response = client.merchantCredentialGeneration(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
- API Credential Types: Partner
- Required Role: INVITE MERCHANT
This is a partner level API that can be used to submit applications to add new merchant accounts. The application requires a significant amount of detailed information about the merchant and their business. Rather than providing an exhaustive list of required fields, we recommend submitting as much information as possible in your initial request.
If any required fields are missing or if there are any validation errors, the API will return specific error messages indicating which fields need to be addressed. Simply review these validation errors, fill in the missing information or correct any errors, and resubmit the application.
Key areas of information include:
- Business details (name, type, tax information)
- Contact information
- Address information (physical and mailing)
- Owner details
- Bank account information
- Transaction volume estimates
- Operational settings (timezone, batch close time, etc.)
Note: Some fields may be conditionally required based on the values of other fields. The validation process will guide you through ensuring all necessary information is provided.
package com.blockchyp.client.examples;
import java.util.ArrayList;
import java.util.Collection;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectWriter;
import com.blockchyp.client.APICredentials;
import com.blockchyp.client.BlockChypClient;
import com.blockchyp.client.dto.SubmitApplicationRequest;
import com.blockchyp.client.dto.Acknowledgement;
public class SubmitApplicationExample {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) throws Exception {
APICredentials creds = new APICredentials();
creds.setApiKey(System.getenv("BC_API_KEY"));
creds.setBearerToken(System.getenv("BC_BEARER_TOKEN"));
creds.setSigningKey(System.getenv("BC_SIGNING_KEY"));
BlockChypClient client = new BlockChypClient(creds);
// Set request parameters
SubmitApplicationRequest request = new SubmitApplicationRequest();
// Send the request
Acknowledgement response = client.submitApplication(request);
// View the result
System.out.println("Response: " + prettyPrint(response));
}
public static String prettyPrint(Object object) throws Exception {
ObjectWriter writer = new ObjectMapper()
.writer()
.withDefaultPrettyPrinter();
return object.getClass().getSimpleName()
+ ": "
+ writer.writeValueAsString(object);
}
}
If you'd like to run the integration tests, create a new file on your system
called sdk-itest-config.json
with the API credentials you'll be using as
shown in the example below.
{
"gatewayHost": "https://api.blockchyp.com",
"testGatewayHost": "https://test.blockchyp.com",
"apiKey": "PZZNEFK7HFULCB3HTLA7HRQDJU",
"bearerToken": "QUJCHIKNXOMSPGQ4QLT2UJX5DI",
"signingKey": "f88a72d8bc0965f193abc7006bbffa240663c10e4d1dc3ba2f81e0ca10d359f5"
}
This file can be located in a few different places, but is usually located
at <USER_HOME>/.config/blockchyp/sdk-itest-config.json
. All BlockChyp SDKs
use the same configuration file.
To run the integration test suite via make
, type the following command:
make integration
If you'd like to bypass make and run the integration test suite directly, use the following command:
BC_TEST_DELAY=5 mvn test -P integration
If you'd like to run individual tests, try the following command:
mvn test -Dtest=TerminalChargeTest -P integration
And these are all just JUnit tests, so feel free to run them your favorite Java IDE.
BlockChyp welcomes contributions from the open source community, but bear in mind that this repository has been generated by our internal SDK Generator tool. If we choose to accept a PR or contribution, your code will be moved into our SDK Generator project, which is a private repository.
Copyright BlockChyp, Inc., 2019
Distributed under the terms of the MIT license, blockchyp-java is free and open source software.
BlockChyp has officially supported SDKs for eight different development platforms and counting. Here's the full list with links to their GitHub repositories.