Fatura Tahsilat
Fatura tahsilat işlemi ve ödeme kaydı.
Endpoint
POST /kolaybi/v1/invoices/proceed
Parametreler
| Parametre | Tip | Zorunlu | Açıklama |
|---|---|---|---|
document_id | integer | Evet | Fatura ID |
vault_id | integer | Evet | Tahsilatın yapılacağı kasa/banka ID |
amount | number | Hayır | Tahsilat tutarı. Gönderilmezse kalan tüm tutar tahsil edilir |
Örnekler
- cURL
- JavaScript
- PHP
- Python
- C#
# Tüm fatura tutarını tahsil et
curl -X POST "https://ofis-sandbox-api.kolaybi.com/kolaybi/v1/invoices/proceed" \
-H "Authorization: Bearer YOUR_ACCESS_TOKEN" \
-H "Channel: YOUR_CHANNEL" \
-H "Content-Type: application/x-www-form-urlencoded" \
-d "document_id=1&vault_id=1"
# Belirli bir tutarı tahsil et
curl -X POST "https://ofis-sandbox-api.kolaybi.com/kolaybi/v1/invoices/proceed" \
-H "Authorization: Bearer YOUR_ACCESS_TOKEN" \
-H "Channel: YOUR_CHANNEL" \
-H "Content-Type: application/x-www-form-urlencoded" \
-d "document_id=1&vault_id=1&amount=100.50"
async function proceedInvoice(documentId, vaultId, amount = null) {
const formData = new URLSearchParams();
formData.append("document_id", documentId);
formData.append("vault_id", vaultId);
if (amount !== null) {
formData.append("amount", amount);
}
const response = await fetch(
"https://ofis-sandbox-api.kolaybi.com/kolaybi/v1/invoices/proceed",
{
method: "POST",
headers: {
Authorization: `Bearer ${accessToken}`,
Channel: channel,
"Content-Type": "application/x-www-form-urlencoded",
},
body: formData,
}
);
return await response.json();
}
// Kullanım - Tüm fatura tutarını tahsil et
const result = await proceedInvoice(1, 1);
// Kullanım - Belirli bir tutarı tahsil et
const partialResult = await proceedInvoice(1, 1, 100.50);
function proceedInvoice($documentId, $vaultId, $amount = null) {
$url = 'https://ofis-sandbox-api.kolaybi.com/kolaybi/v1/invoices/proceed';
$postData = [
'document_id' => $documentId,
'vault_id' => $vaultId
];
if ($amount !== null) {
$postData['amount'] = $amount;
}
$ch = curl_init();
curl_setopt_array($ch, [
CURLOPT_URL => $url,
CURLOPT_POST => true,
CURLOPT_POSTFIELDS => http_build_query($postData),
CURLOPT_HTTPHEADER => [
'Authorization: Bearer ' . $accessToken,
'Channel: ' . $channel,
'Content-Type: application/x-www-form-urlencoded'
],
CURLOPT_RETURNTRANSFER => true
]);
$response = curl_exec($ch);
curl_close($ch);
return json_decode($response, true);
}
// Kullanım - Tüm fatura tutarını tahsil et
$result = proceedInvoice(1, 1);
// Kullanım - Belirli bir tutarı tahsil et
$partialResult = proceedInvoice(1, 1, 100.50);
import requests
def proceed_invoice(document_id, vault_id, amount=None):
url = "https://ofis-sandbox-api.kolaybi.com/kolaybi/v1/invoices/proceed"
headers = {
"Authorization": f"Bearer {access_token}",
"Channel": channel,
"Content-Type": "application/x-www-form-urlencoded"
}
data = {
"document_id": document_id,
"vault_id": vault_id
}
if amount is not None:
data["amount"] = amount
response = requests.post(url, headers=headers, data=data)
return response.json()
# Kullanım - Tüm fatura tutarını tahsil et
result = proceed_invoice(1, 1)
# Kullanım - Belirli bir tutarı tahsil et
partial_result = proceed_invoice(1, 1, 100.50)
using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Threading.Tasks;
using Newtonsoft.Json;
async Task<dynamic> ProceedInvoiceAsync(int documentId, int vaultId, double? amount = null)
{
using var client = new HttpClient();
var data = new Dictionary<string, string>
{
{ "document_id", documentId.ToString() },
{ "vault_id", vaultId.ToString() }
};
if (amount.HasValue)
{
data.Add("amount", amount.Value.ToString());
}
var request = new HttpRequestMessage(HttpMethod.Post,
"https://ofis-sandbox-api.kolaybi.com/kolaybi/v1/invoices/proceed")
{
Content = new FormUrlEncodedContent(data)
};
request.Headers.Authorization = new AuthenticationHeaderValue("Bearer", accessToken);
request.Headers.Add("Channel", channel);
var response = await client.SendAsync(request);
var content = await response.Content.ReadAsStringAsync();
return JsonConvert.DeserializeObject<dynamic>(content);
}
// Kullanım - Tüm fatura tutarını tahsil et
var result = await ProceedInvoiceAsync(1, 1);
// Kullanım - Belirli bir tutarı tahsil et
var partialResult = await ProceedInvoiceAsync(1, 1, 100.50);
Yanıt Formatı
{
"data": {
"transaction_status": "Tamamlandı",
"transaction_type": "Tahsilat",
"payment_method": "Nakit",
"issue_date": "2021-10-01 14:37:11",
"remaining_amount": 0.0,
"currency": "try"
}
}
Yanıt Alanları
| Alan | Tip | Açıklama |
|---|---|---|
transaction_status | string | İşlem durumu |
transaction_type | string | İşlem tipi (Tahsilat) |
payment_method | string | Ödeme yöntemi (ör. Nakit) |
issue_date | string | İşlem tarihi (datetime) |
remaining_amount | number | Kalan tutar |
currency | string | Para birimi |