Off Ramp隐藏收币地址页面

介绍

通过这个对接方式,可以隐藏打币地址页面,但是需要给ACH打币成功通知,流程参考下图:

须知:目前仅支持以下币种使用该功能。

cryptonetwork
USDCBSC
USDTBSC
ETHETH
USDCETH
USDTETH
MATICMATIC
USDCMATIC
USDTMATIC
USDCTRX
USDTTRX

接入方式

商户通过以下请求参数拼接链接后,用户填写收款信息,ACH会推送打币地址给商户的callbackUrl,商户打币后发送通知给ACH进行打款;此方式接入offramp不支持用户在前端发起退款。

请求参数

参数描述必选
appId商户应用Id eg:ahzxh0klegv1fzolY
crypto加密货币名称 eg:USDTY
network网络 eg:ETHY
cryptoAmount售卖加密货币数量Y
fiat法币code eg:USDY
country国家code eg:USY
callbackUrl回调商户同步订单信息Y
withdrawUrl跳转回商户urlY
source来源默认:3。 上传该字段会隐藏收币地址页面Y
type类型 eg:sellY
merchantOrderNo商户自定义订单号 eg:1112957819622420480Y
showAddress是否展示地址二维码可选:Y/NY
merchantName商户名称Y
urlType只能传入app或web,这代表用户跳转的withdrawUrl的类型Y

🚧

注意:

如果传入source参数, url后需拼接 #/sell-formUserInfo

这样跳转过来会直接进入银行信息填写页,没有返回按钮和菜单栏,如不传,则直接进入卖币首页。

如下图:

请求示例:

https://ramp.alchemypay.org?appId=ahzxh0klegv1fzol&crypto=ELF&network=ELF&fiat=USD&country=US&cryptoAmount=100&callbackUrl=https://localhost:9090/test/test&withdrawUrl=www.baidu.com&type=sell&source=3&urlType=web&merchantName=AELF&merchantOrderNo=2134545343544334&showAddress=N#/sell-formUserInfo

通知参数

ACH通知

用户提交表单后会生成订单,订单信息会通过商户请求参数中的callbackUrl推送,每次订单状态变更都会推送订单信息。推送参数:

参数说明必需
orderNo订单号Y
merchantOrderNo商户订单号N
crypto加密货币Y
network网络Y
cryptoPrice加密货币价格N
cryptoAmount加密货币数量Y
fiatAmount法币数量N
appId商户appIdY
fiat法币codeY
txHash交易哈希N
email用户邮箱N
status订单状态:1.订单创建成功,2.用户打币完成,3.开始打款,4.打款成功,5.打款失败,6.退款成功,7.订单超时Y
address打币地址Y
cryptoActualAmount实际打币数量N
rampFee服务费N
receiptTime打款完成N
paymentType支付方式Y
name用户名称Y
card卡号N
account账户N
orderAddress订单详情页urlY
signature签名,参考下方 “通知签名方式”Y

商户通知

用户打币完成,商户需要推送信息给ACH。

请求

路径: https://api.alchemypay.org/webhooks/off/merchant

  • post
  • application/json

📘

需要配置IP白名单,可以在商户后台添加。

推送参数:

参数说明必需
orderNo订单号Y
crypto加密货币Y
cryptoAmount加密货币数量Y
network网络Y
txHash转账hashY
addressACH通知 参数中的 addressY
appId商户appIdY
signature签名,参考下方 “通知签名方式”Y

请求示例:

{
    "orderNo": "string",
    "crypto": "string",
    "cryptoAmount": "string",
    "txHash": "string",
    "network": "string",
    "address": "string",
    "appId": "string",
    "sourceAddress": "string",
    "signature": "string"
}

响应

响应参数:

参数说明必须
successbooleanY
returnCodestringY
returnMsgstringY
extendstringY
dataobjectY

响应示例:

{
    "success": true,
    "returnCode": "string",
    "returnMsg": "string",
    "extend": "string",
    "data": {}
}

通知签名方式

拼接参数appId+appSecret+orderNo+crypto+network+address

public class MerSignCheckUtil {

    private static final char[] HEX_DIGITS = { '0', '1', '2', '3', '4', '5',
        '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };

 

    private static String encode(String algorithm, String value) {
        if (value == null) {
            return null;
        }
        try {
            MessageDigest messageDigest= MessageDigest.getInstance(algorithm);
            messageDigest.update(value.getBytes());
            return getFormattedText(messageDigest.digest());
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
    private static String getFormattedText(byte[] bytes) {
        int len = bytes.length;
        StringBuilder buf = new StringBuilder(len * 2);
        for (int j = 0; j < len; j++) {
            buf.append(HEX_DIGITS[(bytes[j] >> 4) & 0x0f]);
            buf.append(HEX_DIGITS[bytes[j] & 0x0f]);
        }
        return buf.toString();
    }

    public static void main(String[] args) {
          String appId = "";
          String appSecret = "";
          String crypto = "";
          String orderNo = "";
          String network = "";
          String address = "";
          String rawString = appId + appSecret + orderNo + crypto + network + address;
          String sign = encode("sha1", rawString);
    }

}