Manual BaaS - 数字账户
在开始开户流程之前,合作伙伴有责任进行 KYC 和反欺诈分析。
QI Tech 的 Webhooks 不应以受限方式进行映射。 API 返回的 Webhook payload 中可能会新增额外字段。
您可以按照文档中的详细说明查询和重新发送 Webhooks:重新发送 Webhooks。
为此,应使用 /onboarding 中描述的分析端点。
1 - 创建账户
1.1. 上传文件
开户前须先上传公司文件。以下是各类型公司所需的文件列表:
S.A. 公司:
-
公司章程。
-
公司法定代表人选举会议纪要。
-
授权书(如适用)。
-
每位法定代表人或受托人的带照片证件。
其他情况:
-
合同协议。
-
授权书(如适用)。
-
每位法定代表人或受托人的带照片证件。文件须压缩为 ".zip" 格式,并通过文件上传端点发送()。
Response
Response Body
{
"document_key": "cd639c4a-2279-468a-a047-59865b8159ed",
"document_md5": "8f5bef84cb07dc047017c0d304dbb6b8",
"url": "https://storage.googleapis.com/sandbox-doc-api/documents/cd639c4a-2279-468a-a047-59865b8159ed/identificacao_teste.pdf"
}
请保存此 "document_key",因为在创建账户步骤中将会用到它。
1.2. 创建法人账户(PJ)
Request
Request Body
{
"account_owner": {
"annual_revenue_amount": 180000,
"address": {
"city": "Limeira",
"complement": "complemento",
"neighborhood": "Vila Cidade Jardim",
"number": "662",
"postal_code": "13480290",
"state": "SP",
"street": "Avenida Campinas"
},
"cnae_code": "4721-1/02",
"company_statute": "8b0d8c33-01c9-4cf5-a0fa-1d2a96f4b34d",
"company_document_number": "09080702000105",
"company_type": "ltda",
"email": "padaria@vovolucia.com.br",
"foundation_date": "1950-08-21",
"annual_revenue_amount": "1000000.00",
"name": "VOVO LUCIA CONVENIENCIA LTDA",
"person_type": "legal",
"phone": {
"area_code": "19",
"country_code": "55",
"number": "988888888"
},
"trading_name": "Empadaria Vovo Lucia",
"company_representatives": [{
"address": {
"city": "Recife",
"complement": null,
"neighborhood": "Fundão",
"number": "137",
"postal_code": "52221110",
"state": "PE",
"street": "Rua Camapuã"
},
"birth_date": "1972-02-02",
"document_identification_number": "339122924",
"document_identification": "8b0d8c33-01c9-4cf5-a0fa-1d2a96f4b34d",
"email": "marcos.alves@yopmail.com",
"individual_document_number": "08531309069",
"is_pep": false,
"marital_status": "single",
"mother_name": "Sueli Isadora Alves",
"name": "Marcos Felipe Henrique Alves",
"nationality": "Brasileira",
"person_type": "natural",
"phone": {
"area_code": "88",
"country_code": "55",
"number": "995924634"
}
},
{
"person_type": "natural",
"name": "Juliana Tereza Bernardes",
"mother_name": "Maria Mariane",
"birth_date": "1990-05-06",
"profession": "Deputada",
"nationality": "Brasileira",
"marital_status": "single",
"is_pep": false,
"individual_document_number": "97564480084",
"document_identification_number": "232479719",
"document_identification": "8b0d8c33-01c9-4cf5-a0fa-1d2a96f4b34d",
"email": "juliana.tereza@yopmail.com",
"phone": {
"country_code": "55",
"area_code": "11",
"number": "912821359"
},
"address": {
"street": "Passagem Mariana",
"state": "PA",
"city": "Ananindeua",
"neighborhood": "Águas Lindas",
"number": "660",
"postal_code": "67118003",
"complement": "complemento"
}
}
]
},
"allowed_user": {
"email": "juliana.tereza@yopmail.com",
"individual_document_number": "97564480084",
"name": "Juliana Tereza Bernardes",
"person_type": "natural",
"phone": {
"country_code": "55",
"area_code": "11",
"number": "912828135"
}
},
"signed_contract": {
"document_key": "4d7f4e29-4b58-4905-9a69-b1f9215263f5",
"signatures": [
{
"authenticity": {
"timestamp": "1970-01-01T00:00:01.080100Z",
"facial_recognition_key": "79003de0-2590-455d-9b73-426b8ca284eb",
"lang": "-35.8916627",
"lat": "-7.2226067",
"ip_address": "177.51.1.000",
"session_id": "jdifj329842"
},
"signer": {
"name": "IVANILDO DE SENA LIMA",
"email": "teste@gmail.com",
"phone": {
"country_code": "055",
"area_code": "11",
"number": "999999999"
},
"document_number": "99999999999"
},
"authentication_type": "opt-in"
}
]
}
}
"account_owner": 公司数据应在此对象中发送。
"account_owner.company_statute":上传公司章程文件(".zip" 格式)时,文件上传端点返回的 "document_key" 应在此字段中发送。
"account_owner.company_representatives":公司法定代表人的数据列表应在此对象中发送。至少应发送足以根据公司章程/合同合法代表公司的法定代表人。每位法定代表人的权限验证由合作伙伴负责。
"account_owner.company_representatives.document_identification":上传代表人带照片证件(".zip" 格式)时,文件上传端点返回的 "document_key" 应在此字段中发送。
"allowed_user":此字段应发送 "account_owner.company_representatives" 对象中某位法定代表人的数据。该用户将成为账户管理员,拥有账户操作权限以及添加新管理员用户的权限。无论是账户操作还是添加新用户的 SMS/邮件确认,均将发送给此人。
具有管理员权限的用户对账户拥有完全控制权(通过短信或邮件的双因素认证)。因此,该用户须根据公司合同/章程在法律上具有操作账户的权限。管理员用户的权限验证由合作伙伴负责。
1.2.1 开户条款签署
在开户 payload 中,须发送 signature_contract 字段,该字段应包含用户(账户持有人或主用户)接受开户条款时的设备扫描信息。
signed_contract 对象
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
| document_key * | uuidv4 | 开户条款或托管账户合同文件的唯一标识键。(DOCUMENT_KEY 在文件上传端点的响应中返回) | 36 |
| signatures * | list | 所发送文件的签名数据。列表中的每一项对应一位签署人。 | signatures 对象 |
signatures 对象
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
| authenticity * | object | 证明签署人完成电子签名的数据集合。 | authenticity 对象 |
| signer * | object | 包含某位文件签署人数据的对象。 | signer 对象 |
| authentication_type * | enumerator | 签名类型。始终为 "opt-in" | "opt-in" |
authenticity 对象
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
| timestamp * | string | 文件签署时的日期和时间。 | 27 |
| facial_recognition_key | uuidv4 | 账户持有人自拍照片的唯一标识键。(DOCUMENT_KEY 在文件上传端点的响应中返回) | 36 |
| lang | string | 签署时捕获的签署人地理位置经度坐标。 | - |
| lat | string | 签署时捕获的签署人地理位置纬度坐标。 | - |
| ip_address | string | 签署人设备的 IP 地址。 | - |
| session_id | string | 签署时签署人的会话 ID。 | - |
signer 对象
| 字段 | 类型 | 描述 | 字符数 |
|---|---|---|---|
| name * | string | 签署人姓名。 | - |
| email * | string | 签署人邮箱。 | - |
| phone * | object | 包含签署人电话数据的对象 | phone 对象 |
| document_number * | string | 签署人 CPF。 | 11 |
phone 对象
| 字段 | 描述 | 示例 | 最大字符数 |
|---|---|---|---|
country_code * | string | 电话 DDI 代码 (https://ddi.guiamais.com.br/) | 3 |
area_code * | string | 电话 DDD 代码 (https://ddd.guiamais.com.br/) | 2 |
number * | string | 电话号码(仅数字) | 10 |
Response
- MÉTODOPOST
- ENDPOINT/account
Response Body
{
"data": {
"account_info": {
"account_branch": "0001",
"account_digit": "2",
"account_number": "2359934",
"financial_institution_code": "329"
},
"account_owner": {
"document_number": "09080702000105",
"name": "VOVO LUCIA CONVENIENCIA LTDA"
},
"allowed_user": {
"document_number": "97564480084",
"name": "Juliana Tereza Bernardes"
}
},
"event_datetime": "2022-09-02 22:39:10",
"key": "\<UUID PROPOSAL-KEY\>",
"status": "pending_kyc_analysis",
"webhook_type": "account"
}
重要:此响应中返回的 "key" 是开户申请的 PROPOSAL-KEY。应将其保存,以便读取开户 Webhook。
开户申请的响应始终返回状态 "pending_kyc_analysis"。
系统将为该客户保留一个账号,但账户仍待 QI Tech 进行 KYC 分析。此时,账户尚未开通,无法接收或发送资金。
1.3. 创建个人账户(PF)
Request
- ENDPOINT/account
- MÉTODOPOST
Request Body
{
"account_owner": {
"address": {
"street": "Avenida Sargento Geraldo Sant'Ana",
"number": "1100",
"neighborhood": "Jardim Taquaral",
"city": "São Paulo",
"state": "SP",
"postal_code": "04674225"
},
"phone": {
"country_code": "55",
"number": "912828135",
"area_code": "11"
},
"email": "juliana.tereza@yopmail.com",
"name": "Juliana Tereza Bernardes",
"person_type": "natural",
"nationality": "Brasil",
"birth_date": "1993-08-02",
"mother_name": "Patricia Monica Diaz Bascur Tieppo",
"is_pep": false,
"individual_document_number": "97564480084",
"document_identification": "8b0d8c33-01c9-4cf5-a0fa-1d2a96f4b34d",
"document_identification_type": "cnh",
"revenue_amount": 1000,
"profession": "autonomo"
},
"signed_contract": {
"document_key": "4d7f4e29-4b58-4905-9a69-b1f9215263f5",
"signatures": [
{
"authenticity": {
"timestamp": "1970-01-01T00:00:01.080100Z",
"facial_recognition_key": "79003de0-2590-455d-9b73-426b8ca284eb",
"lang": "-35.8916627",
"lat": "-7.2226067",
"ip_address": "177.51.1.000",
"session_id": "jdifj329842"
},
"signer": {
"name": "IVANILDO DE SENA LIMA",
"email": "teste@gmail.com",
"phone": {
"country_code": "055",
"area_code": "11",
"number": "999999999"
},
"document_number": "99999999999"
},
"authentication_type": "opt-in"
}
]
}
}
"account_owner": 个人账户持有人的数据应在此对象中发送。
"account_owner.document_identification": 文件上传端点返回的 "document_key"。