Resolver Disputa de Marco
Resolve disputas de marcos da caução distribuindo fundos ao aprovador e ao prestador de serviço conforme determinado pelo resolvedor da disputa.
Cabeçalhos
Nome
Valor
Content-Type
application/json
x-api-key
<token>
Open API
post
Autorizações
Corpo
contractIdstringObrigatórioExample:
ID (address) that identifies the escrow contract
CAZ6UQX7...disputeResolverstringObrigatórioExample:
Address of the user defined to resolve disputes in an escrow
GDISPUTE...XYZmilestoneIndexstringObrigatórioExample:
Position that identifies the milestone within the group of milestones in the escrow
1Respostas
201
This endpoint returns an unsigned transaction in XDR format. This XDR is then used to sign the transaction using the “/helper/send-transaction” endpoint.
application/json
400
Bad request
401
Unauthorized access
429
Too Many Requests
500
Possible errors:
- Escrow not found
- Invalid milestone index
- None of the amounts to be transferred should be less or equal than 0
- Only the dispute resolver can execute this function
- This milestone is already released
- This milestone is already resolved
- Milestone not in dispute
- The total funds to resolve the dispute must not exceed the amount defined for this milestone
- Insufficient funds for resolution
- The total amount to be transferred cannot be zero
- An unexpected error occurred
application/json
post
/escrow/multi-release/resolve-milestone-disputePOST /escrow/multi-release/resolve-milestone-dispute HTTP/1.1
Host:
Content-Type: application/json
Accept: */*
Content-Length: 210
{
"contractId": "CAZ6UQX7...",
"disputeResolver": "GAPPROVER1234567890...",
"milestoneIndex": "1",
"distributions": [
{
"address": "GAPPROVER1234567890...",
"amount": 300
},
{
"address": "GRECEIVER1234567890...",
"amount": 700
}
]
}{
"status": "SUCCESS",
"unsignedTransaction": "AAAAAgAAAAAtWsgedQ...."
}
O que este Endpoint retorna?
Este endpoint retorna a transação não assinada para que a transação possa ser assinada por meio da carteira do cliente.
Exemplo de uso:
import axios from "axios";
const http = axios.create({
baseURL: "https://dev.api.trustlesswork.com",
timeout: 10000,
headers: {
"Content-Type": "application/json",
"x-api-key": sua_chave_api,
},
});
export const useExample = async () => {
// Obter o endereço do assinante
const { address } = await kit.getAddress();
const response = await http.post(
"/escrow/liberação-múltipla/resolver-disputa-marco",
{
// corpo solicitado para o endpoint
},
);
// Obter o hash da transação não assinada
const { unsignedTransaction } = response.data;
// Assinar a transação pela carteira
const { signedTxXdr } = await signTransaction(unsignedTransaction, {
address,
networkPassphrase: WalletNetwork.TESTNET,
});
// Enviar a transação para a Rede Stellar
const tx = await http.post("/helper/send-transaction", {
signedXdr: signedTxXdr,
});
const { data } = tx;
return data;
}Atualizado
Isto foi útil?