使用双因素身份验证执行 TED 批量交易
QI Tech 提供通过单次 API 调用执行多笔 TED 交易的功能。在此系统中,交易以异步方式执行。如果初始调用返回 http status 4xx,则不会执行任何交易。请求后,集成合作伙伴将为每笔交易收到一个 Webhook,告知尝试的最终状态,可能为 rejected 或 sent。
在此类交易中,需要通过发送给账户中具有批准转账权限的人员的令牌来确认付款。
配置为使用双因素身份验证的集成合作伙伴的 TED 批量交易请求方式与执行 TED 批量交易中描述的方式类似。区别在于添加了 tfa_info 对象,以及成功请求的状态将始终为 pending_2fa_approval。
令牌发送至批准人的通知事件为 baas.token_validation.ted.batch。可以自定义发送的消息。
请求
ENDPOINT
/account/ACCOUNT_KEY/ted_batch方法
POST通过邮件和短信进行身份验证
Request Body: 通过短信或邮件进行 TFA 的批量转账
{
"request_control_key": "6e4fc980-f8a1-4462-b6e2-d8a49f0ac055",
"tfa_info": {
"approver_document_number": "98765432100",
"contact_type": "email"
},
"teds": [
{
"request_control_key": "0c3d2a3e-c121-464e-b5a4-8e69e0c17bbd",
"target_account": {
"account_branch": "0001","account_number": "92796","account_digit": "1",
"owner_document_number": "23599885000192","owner_name": "Titular da Conta",
"ispb": "12345678","account_type": "checking_account"
},
"transaction_amount": 8.86
},
{
"request_control_key": "ff9f2a48-918c-4911-9371-a496e37dccfc",
"target_account": {
"account_branch": "0001","account_number": "92797","account_digit": "2",
"owner_document_number": "23599885000192","owner_name": "Titular da Conta",
"ispb": "12345678","account_type": "checking_account"
},
"transaction_amount": 10.00
}
]
}
通过设备进行身份验证
除了现有的 sms 和 email 身份验证方式外,还可以使用预先注册的设备对交易进行身份验证。在这种情况下,需要从 Device Scan 中获取 session_id 并在 tfa_info 中发送。
Request Body: 通过设备进行 TFA 的批量转账
{
"request_control_key": "6e4fc980-f8a1-4462-b6e2-d8a49f0ac055",
"tfa_info": {
"approver_document_number": "98765432100",
"session_id": "b2f18d3a-67c2-4a7f-98e5-1d3f5c6b8a72",
"contact_type": "device"
},
"teds": [
{
"request_control_key": "0c3d2a3e-c121-464e-b5a4-8e69e0c17bbd",
"target_account": {
"account_branch": "0001","account_number": "92796","account_digit": "1",
"owner_document_number": "23599885000192","owner_name": "Titular da Conta",
"ispb": "12345678","account_type": "checking_account"
},
"transaction_amount": 8.86
},
{
"request_control_key": "ff9f2a48-918c-4911-9371-a496e37dccfc",
"target_account": {
"account_branch": "0001","account_number": "92797","account_digit": "2",
"owner_document_number": "23599885000192","owner_name": "Titular da Conta",
"ispb": "12345678","account_type": "checking_account"
},
"transaction_amount": 10.00
}
]
}
Path Params
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
account_key | uuidv4 | 账户的唯一标识键。 | 36 |
Body Params
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
request_control_key * | uuidv4 | 客户使用的 uuid v4 格式的请求唯一标识键。 | 36 |
teds * | array | 与批次关联的 TED 对象列表。 | 列表 Objeto ted |
tfa_info * | Object | 包含账户批准人文件号和联系方式的对象。 | Objeto tfa_info |
Objeto tfa_info
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
approver_document_number * | string | 账户批准人的文件号。 | 11 |
session_id | string | 设备会话唯一标识键,UUID v4 格式(设备 TFA 必填)。 | 36 |
contact_type * | string | 与账户批准人的联系方式,可为 sms、email 或 device |
Objeto ted
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
request_control_key * | string | 客户使用的 uuid v4 格式的请求唯一标识键。 | 36 |
target_account * | object | 目标账户 | Objeto target_account |
transaction_amount * | float | 转账金额 | 10 |
Objeto target_account
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
account_branch * | string | 银行代码(机构代码)。 | 4 |
account_digit * | string | 账户校验码 | 1 |
account_number * | string | 账户号码。 | 20 |
owner_document_number * | string | 账户持有人的 CPF 或 CNPJ(仅数字)。 | 14 |
owner_name * | string | 账户持有人姓名。 | 50 |
account_type * | string | 账户类型。 | Enumerador account_type |
ispb * | string | 基于金融机构 CNPJ(8 位数字)。 | 8 |