digitaluapi

<back to all web services

PayFastWebHook

The following routes are available for this service:
POST/payfast/webhook/{PublicAccessGuid}
import Foundation
import ServiceStack

public class PayFastWebHook : Codable
{
    // @DataMember(Name="m_payment_id")
    public var m_payment_id:String

    // @DataMember(Name="pf_payment_id")
    public var pf_payment_id:String

    // @DataMember(Name="payment_status")
    public var payment_status:String

    // @DataMember(Name="item_name")
    public var item_name:String

    // @DataMember(Name="item_description")
    public var item_description:String

    // @DataMember(Name="amount_gross")
    public var amount_gross:Double

    // @DataMember(Name="amount_fee")
    public var amount_fee:Double

    // @DataMember(Name="amount_net")
    public var amount_net:Double

    // @DataMember(Name="custom_str1")
    public var custom_str1:String

    // @DataMember(Name="custom_str2")
    public var custom_str2:String

    // @DataMember(Name="custom_str3")
    public var custom_str3:String

    // @DataMember(Name="custom_str4")
    public var custom_str4:String

    // @DataMember(Name="custom_str5")
    public var custom_str5:String

    // @DataMember(Name="custom_int1")
    public var custom_int1:Int

    // @DataMember(Name="custom_int2")
    public var custom_int2:Int

    // @DataMember(Name="custom_int3")
    public var custom_int3:Int

    // @DataMember(Name="custom_int4")
    public var custom_int4:Int

    // @DataMember(Name="custom_int5")
    public var custom_int5:Int

    // @DataMember(Name="name_first")
    public var name_first:String

    // @DataMember(Name="name_last")
    public var name_last:String

    // @DataMember(Name="email_address")
    public var email_address:String

    // @DataMember(Name="merchant_id")
    public var merchant_id:String

    // @DataMember(Name="signature")
    public var signature:String

    // @DataMember(Name="token")
    public var token:String

    // @DataMember(Name="billing_date")
    public var billing_date:Date

    public var publicAccessGuid:String
    public var sandbox:Bool

    required public init(){}
}


Swift PayFastWebHook DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml

HTTP + XML

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /payfast/webhook/{PublicAccessGuid} HTTP/1.1 
Host: duengageapi.uat.scadsoftware.com 
Accept: application/xml
Content-Type: application/xml
Content-Length: length

<PayFastWebHook xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/digitaluapi.ServiceModel">
  <AmountFee>0</AmountFee>
  <AmountGross>0</AmountGross>
  <AmountNet>0</AmountNet>
  <BillingDate>0001-01-01T00:00:00</BillingDate>
  <CustomInt1>0</CustomInt1>
  <CustomInt2>0</CustomInt2>
  <CustomInt3>0</CustomInt3>
  <CustomInt4>0</CustomInt4>
  <CustomInt5>0</CustomInt5>
  <CustomStr1>String</CustomStr1>
  <CustomStr2>String</CustomStr2>
  <CustomStr3>String</CustomStr3>
  <CustomStr4>String</CustomStr4>
  <CustomStr5>String</CustomStr5>
  <EmailAddress>String</EmailAddress>
  <ItemDescription>String</ItemDescription>
  <ItemName>String</ItemName>
  <MPaymentId>String</MPaymentId>
  <MerchantId>String</MerchantId>
  <NameFirst>String</NameFirst>
  <NameLast>String</NameLast>
  <PaymentStatus>String</PaymentStatus>
  <PfPaymentId>String</PfPaymentId>
  <PublicAccessGuid>00000000-0000-0000-0000-000000000000</PublicAccessGuid>
  <Sandbox>false</Sandbox>
  <Signature>String</Signature>
  <Token>String</Token>
</PayFastWebHook>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length

<z:anyType xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns:z="http://schemas.microsoft.com/2003/10/Serialization/" />