Before you start

Please download the suggested API integration process flow document and use it as a reference when developing.
Kindly adhere to the Netcash brand guidelines when developing.

 

Programmers Guide

Refer to our Programmers guide for more detail on how to apply the required methodology in this document.
Ensure that the settings for developers are adhered to before you proceed with your implementation.

 

Web Service Methods

The list of Netcash web service methods can be found here.

 

Quick Start Guides

Quick Start Guides will help you understand this service and get you started.

Overview

DebiCheck is a preferential debit order system requiring the bank account holder to give specific electronic permission (via their bank) prior to any debit order being processed.

Contract Types

  1. Fixed: terms of the contract remain unchanged. For example, a gym contract.
  2. Variable: contract terms may change. eg, a home loan may vary in line with the prevailing interest rates. *Note
  3. Usage-based: terms of the contract change regularly. eg, a cellphone bill may vary monthly based on usage.

Technical Information

 

Input

Requests to the web service is sent as a string.

Example:  public string BatchFileUpload(string ServiceKey, string File)

Output

Successful request

If the method call was successful and the file is being processed, the web service will return a file token which is used to retrieve the load report

Example:  20000000.2550236530.0483.2.2

 


Unsuccessful request

If the method call fails, the web service will return an error code:

Code Description
100 Authentication failure. Ensure that the service key in the method call is correct
102 Parameter error. One or more of the parameters in the string is incorrect
200 General code exception. Please contact Netcash Technical Support.

Input File Structure

Each file has the following mandatory records:

H – Header record identifies the upload and passes instructions to the Netcash server to determine the purpose of the file.
K – Key record must follow the header record. The key record describes the transaction records which follow. The format defined in the key record is used to validate the record structure and content.
T – Transaction records follow the key record. The fields in the transaction records must conform to the layout defined in the key.
F – Footer record must be the last record in the file and confirms that the file is complete.


Header record (H)

Every file must contain a header record as the first record in the file.


Record Structure

Field Name Type Value
1 Record Identifier AN H
2 Service Key AN Service GUID
3 Version AN 1
4 Instruction AN Purpose of the file
5 Batch name AN Your identifier
6 Action date N CCYYMMDD
7 Software vendor key AN The key issued by Netcash to identify the software origin of transactions. (only used by Netcash ISV‘s else use the default value: 24ade73c-98cf-47b3-99be-cc7b867b3080)

Field explanations

Field Explanation
Record Id “H” – Identifies the record as a header
Service key Debit order service key
Version “1” – This is the Netcash version of the file specification
Instruction DebiCheckAmend
Batch name Use this field as an identifier of your batch.
Action date Current date
Software Vendor Key The key issued by Netcash to identify the software origin of transactions. (only used by Netcash ISV‘s else use the default value: 24ade73c-98cf-47b3-99be-cc7b867b3080)

Key record (K)

  • The key record is mandatory and must appear in the file between the header record and the transaction records.
  • The key defines the content, order and length of the transaction records in the file. It can be likened to the column headings in a spreadsheet.
  • The key lists all the possible fields contained in the subsequent transaction records, even if not every transaction record contains data in all the fields.
  • While the file is customizable, it is recommended that keys are listed in ascending numerical order for ease of debugging and support.

Transaction record (T)

  • There must be at least one transaction record in the file.
  • The transaction records must conform to the order of the fields as described in the key record.
    (In the example above, the account reference (field id 138) is defined as the first field in the record, therefore, every transaction record MUST have the Budget as the first field or it will fail validation)
  • Every transaction record must have the same number of fields as defined in the key record (K).
  • Empty fields should be replaced by a blank tab or a default value, where one has been defined.
    Where fields are left empty, the Netcash system will assume spaces or zeroes for fields defined in the key record.

Mandatory fields

The fields indicated by are mandatory for the specified instruction.

Key Field name Mandatory

See key legend for value requirements
Type Description
Service Key Debit order service key is required
102 Account name AN50 The name of the Debit Order Master file account
111 SA ID Number N13
127 Is ID number N1 0 = Not an SA ID number
1 = is an SA ID
133 Bank account type N1 1 = cheque
2 = savings
136 Bank Account Number The bank account numbers can only be amended within the same branch. If the branch code changes the change will require re-authentication by the account holder
243 DebiCheck collection amount N In cents
604 Max Collection Amount N In cents
617 Contract Reference of DC authentication being amended AN50

Example

H	59B81F94-7C38-XXXX-XXXX-ACA2E1517011	1	DebiCheckAmend	Batch2	20231010	24ade73c-98cf-47b3-99be-cc7b867b3080
K	617	102	243	604	111	127	133	136	602
T	NC000000012213	NEVILLE MCKENZIE	19700	19900	910330####081	1	1	6281###6918	0
T	NC000000012371	ELTON MAY	49800	50000	840717####088	1	1	126###8009	0
F	2	69500	9999

The template on the Netcash Account must be setup for TT2 (batch) authentication. This specific service does not offer real-time authentication and data sent to this endpoint will processed as a “Batch Instruction” (non realtime) – irrespective of whether the template is set to process the data as realtime.

Footer record (F)

The footer record indicates that the complete file has been received. It must be the last record in the file. If the record is not present, the system will fail the file without processing any transaction records.

Structure

Field Name Type Value
1 Record Identifier AN F
2 No of transactions N A count of the transaction records
3 Sum of amounts N The sum of the monetary fields (in cents)
4 End-of-file indicator N 9999

 

Field explanations

Field Explanation
Record Identifier “F” – Identifies the record as a footer
No of transactions This is the count of all the ‘T’ records in the file.
Sum of amounts This is the sum of all the values in the 161 fields.
End-of-file indicator ‘9999’ – Indicates there are no more records.

 

Example  F 2 0 9999

 

Postback option


Using the file token, call:

  • Web service: https://ws.netcash.co.za/niws/niws_nif.svc
  • Method: RequestFileUploadReport
  • Service key:  Debit Order service key

Requests to the web service are sent as strings

Example:  public string RequestFileUploadReport(string ServiceKey, string FileToken)

Output file

File content

Only errors are reported in the file. If all the entries in the file are successfully validated, the Load report header will contain “SUCCESSFUL” and there will be no detail messages.

 

File structure

The report is tab delimited with a linefeed character as line terminator.

Load report header

(occurs once at the start of each load report)

Field

Name

Type

Value

1

Record identifier

AN8

###BEGIN

2

Batch name

AN

{your batch name}

3

Result of upload

A13

SUCCESSFUL / UNSUCCESSFUL /
SUCCESSFUL WITH ERRORS

4

Start time of report

AN8

HH:MM AM/PM

 

Load report message

(occurs multiple times – once per error record)

Field

Name

Type

Value

1

Unique reference

AN25

The unique reference you supplied in (p2)

2

Line number

AN

Line :{line in your file where error was found}

3

Error message

AN

The error message

OR

1

Record identifier

AN8

###ERROR

2

Error message

AN

The error message

 

Load report trailer

(occurs once – the last line in the report)

Field

Name

Type

Value

1

Record identifier

AN6

###END

2

End time of report

AN8

HH:MM AM/PM

Examples

Data:

Account Name: NEVILLE MCKENZIE
Account Id: 31142
Contract Reference: NC000000012213
Collection Amount In Cents: 19700
Max Collection Amount In Cents: 19900
Id Number: 91033####81
Is Id Number: 1
Account Type: 1
Account Number: 6281###6918
Is Tracking: 0

Account Name: ELTON MAY
Account Id: 31142
Contract Reference: NC000000012371
Collection Amount In Cents: 49800
Max Collection Amount In Cents: 50000
Id Number: 840717####088
Is Id Number: 1
Account Type: 1
Account Number: 126###8009
Is Tracking: 0

Input

H	59B81F94-7C38-XXXX-XXXX-ACA2E1517011	1	DebiCheckAmend	Batch2	20231010	24ade73c-98cf-47b3-99be-cc7b867b3080
K	617	102	243	604	111	127	133	136	602
T	NC000000012213	NEVILLE MCKENZIE	19700	19900	910330####081	1	1	6281###6918	0
T	NC000000012371	ELTON MAY	49800	50000	840717####088	1	1	126###8009	0
F	2	69500	9999

XML

<BatchFileUpload>
  <MethodParameters>
    <ServiceKey>59B81F94-7C38-XXXX-XXXX-ACA2E1517011</ServiceKey>
    <File>H    59B81F94-7C38-XXXX-XXXX-ACA2E1517011    1    DebiCheckAmend    Batch2    20231010    24ade73c-98cf-47b3-99be-cc7b867b3080
K    617    102    243    604    111    127    133    136    602
T    NC000000012213    NEVILLE MCKENZIE    19700    19900    910330####081    1    1    62818###918    0
T    NC000000012371    ELTON MAY    49800    50000    840717####088    1    1    126###8009    0
F    2    69500    9999</File>
  </MethodParameters>
</BatchFileUpload>

Response

<BatchFileUpload>
  <MethodParameters>
    <String>10013792.1000831941.8519.31142.011</String>
  </MethodParameters>
</BatchFileUpload>

DebiCheckAmendAuthentication Single transaction

Technical Information

  • Web service: https://ws.netcash.co.za/niws/niws_nif.svc
  • Method: DebiCheckAmendAuthentication
  • Service keyDebit order service key

Input

Submit the following parameters

 

Mandatory fields
ServiceKey Debit order service key
ContractReference Contract reference of the existing DC Mandate
The following data can be changed
AccountName Mandate holder name
IsIdNumber Is this an SA ID number
DebtorIdentification If SAID -= enter ID number
CollectionAmountInCents Amount in cents
MaximumCollectionAmountInCents Amount in cents
BankAccountNumber Mandate holder bank account number
BankAccountType Bank account Type
IsTracking True/False

 

Response

<DebiCheckAmendAuthentication>
  <MethodParameters>
    <DebiCheckAmendmentResponse>
      <ContractReference>NC000000012213</ContractReference>
      <Messages attr0="StringArray" isNull="false" />
      <ErrorCode>000</ErrorCode>
    </DebiCheckAmendmentResponse>
  </MethodParameters>
</DebiCheckAmendAuthentication>

Netcash brand guidelines

Please refer to the Netcash brand guidelines here when using any logos, images, icons, labels, descriptions, and references to Netcash in your software.

Testing

See Testing section for more details. If you require any integration assistance contact our technical support team

Netcash may provide example/sample/demo ‘code snippets’ and/or external links in this Technical Document. Such are for guidance purposes only and may not function on every developer’s system/s. Netcash disclaims any and all liability for the usage of guidance resources provided -and you as the Developer; must accept full responsibility for the usage of such. While every possible effort has been taken to ensure compatibility across multiple system configurations, the contents of this document cannot be guaranteed to work on all systems, with all operating systems -and/or with all system configuration/s.