org.hyperledger.fabric.shim.ChaincodeException Maven / Gradle / Ivy
Show all versions of fabric-chaincode-shim Show documentation
/*
* Copyright 2019 IBM All Rights Reserved.
*
* SPDX-License-Identifier: Apache-2.0
*/
package org.hyperledger.fabric.shim;
import static java.nio.charset.StandardCharsets.UTF_8;
/**
* Contracts should use {@code ChaincodeException} to indicate when an error
* occurs in Smart Contract logic.
*
*
* When a {@code ChaincodeException} is thrown an error response will be
* returned from the chaincode container containing the exception message and
* payload, if specified.
*
*
* {@code ChaincodeException} may be extended to provide application specific
* error information. Subclasses should ensure that {@link #getPayload} returns
* a serialized representation of the error in a suitable format for client
* applications to process.
*/
public class ChaincodeException extends RuntimeException {
private static final long serialVersionUID = 3664437023130016393L;
private byte[] payload;
/**
* Constructs a new {@code ChaincodeException} with no detail message.
*/
public ChaincodeException() {
super();
}
/**
* Constructs a new {@code ChaincodeException} with the specified detail
* message.
*
* @param message the detail message.
*/
public ChaincodeException(final String message) {
super(message);
}
/**
* Constructs a new {@code ChaincodeException} with the specified cause.
*
* @param cause the cause.
*/
public ChaincodeException(final Throwable cause) {
super(cause);
}
/**
* Constructs a new {@code ChaincodeException} with the specified detail message
* and cause.
*
* @param message the detail message.
* @param cause the cause.
*/
public ChaincodeException(final String message, final Throwable cause) {
super(message, cause);
}
/**
* Constructs a new {@code ChaincodeException} with the specified detail message
* and response payload.
*
* @param message the detail message.
* @param payload the response payload.
*/
public ChaincodeException(final String message, final byte[] payload) {
super(message);
this.payload = payload;
}
/**
* Constructs a new {@code ChaincodeException} with the specified detail
* message, response payload and cause.
*
* @param message the detail message.
* @param payload the response payload.
* @param cause the cause.
*/
public ChaincodeException(final String message, final byte[] payload, final Throwable cause) {
super(message, cause);
this.payload = payload;
}
/**
* Constructs a new {@code ChaincodeException} with the specified detail message
* and response payload.
*
* @param message the detail message.
* @param payload the response payload.
*/
public ChaincodeException(final String message, final String payload) {
super(message);
this.payload = payload.getBytes(UTF_8);
}
/**
* Constructs a new {@code ChaincodeException} with the specified detail
* message, response payload and cause.
*
* @param message the detail message.
* @param payload the response payload.
* @param cause the cause.
*/
public ChaincodeException(final String message, final String payload, final Throwable cause) {
super(message, cause);
this.payload = payload.getBytes(UTF_8);
}
/**
* Returns the response payload or {@code null} if there is no response.
*
*
* The payload should represent the chaincode error in a way that client
* applications written in different programming languages can interpret. For
* example it could include a domain specific error code, in addition to any
* state information which would allow client applications to respond
* appropriately.
*
* @return the response payload or {@code null} if there is no response.
*/
public byte[] getPayload() {
return payload;
}
}