Generic Transactions
Overview
Generic Transactions are the transactions that can be configured for specific use cases which are out of scope of incoming/outgoing transfers and exchange transactions. Please contact your solution consultant to explain your required use case before using these APIs. IF Team needs to configure your instance for your use case of generic transactions. You'll receive the configured values that can be used as generic-transaction-type. After that, Generic Transaction APIs can be used with specified type values.
Create a Generic Transaction
The process of creating a Generic Transaction is executed using two different workflows. These workflows can be as follows:
- Client Direct: To create a Generic Transaction  whose owner is the Client, the workflow code must be client.direct. In this caseaccountIdcorresponds to an ID of a client account.
- Organization Direct: To create a Generic Transaction whose owner is Organization, the workflow code must be organization.direct. TheclientIdfield must be empty when the workflow code is organization. In this caseaccountIdcorresponds to an ID of a transaction account.
POST /generic-transactions
{
  "workflow": {
    "code": "client.direct",
    "narrative": {
      "sourcingMethod": "explicit",
      "enabled": true
    }
  },
  "data": {
    "genericTransaction": {
      "type": "<generic-transaction-type>",
      "clientId": "00000000-0000-0000-0000-000000000000",
      "accountId": "00000000-0000-0000-0000-000000000000",
      "amount": 10,
      "currency": "GBP",
      "attributes": {
        "key01": "value01",
        "key02": "value02"
      }
    },
    "narrative": {
      "template": "Payment of <#if key01??>${key01}</#elseif key02??>${key02}<#/else>N/A</#if>"
    }
  },
  "connect": {},
  "metadata": {}
}{
  "workflow": {
    "code": "client.direct",
    "narrative": {
      "sourcingMethod": "explicit",
      "enabled": true
    }
  },
  "data": {
    "genericTransaction": {
      "id": "00000000-0000-0000-0000-000000000000",
      "type": "<generic-transaction-type>",
      "owner": "client",
      "clientId": "00000000-0000-0000-0000-000000000000",
      "accountId": "00000000-0000-0000-0000-000000000000",
      "transactionNumber": "20230613-ABCDEF",
      "amount": 10,
      "currency": "GBP",
      "status": "completed",
      "narrative": "Payment of value01",
      "creationDateTime": "2023-06-13T00:00:00.000",
      "attributes": {
        "key01": "value01",
        "key02": "value02"
      }
    }
  },
  "connect": {},
  "metadata": {}
}{
 "workflow": {
    "code": "organization.direct",
    "narrative": {
      "sourcingMethod": "implicit"
    }
  },
  "data": {
    "genericTransaction": {
      "type": "gwt-principal-organization",
      "accountId": "00000000-0000-0000-0000-000000000000",
      "amount": 10,
      "currency": "GBP",
      "attributes": {
        "description": "This transfer is related to expenses."
      }
    }
  },
  "connect": {},
  "metadata": {}
}{
 "workflow": {
        "code": "organization.direct",
        "narrative": {
            "sourcingMethod": "implicit"
        }
    },
    "data": {
        "genericTransaction": {
            "id": "00000000-0000-0000-0000-000000000000",
            "type": "gwt-principal-organization",
            "owner": "organization",
            "clientId": null,
            "accountId": "00000000-0000-0000-0000-000000000000",
            "transactionNumber": "20240807-6XGQ92",
            "amount": 10.00,
            "currency": "GBP",
            "status": "completed",
            "attributes": {
                "description": "This transfer is related to expenses."
            },
            "narrative": "This transfer is related to expenses.",
            "creationDateTime": "2024-08-07T08:19:17.288243"
        }
    },
    "connect": {},
    "metadata": {}
}- workflow.code must be sent as client.direct or organization.direct
- data.genericTransaction.type is required and it must be sent using one of the types configured in your instance.
- Fields other than attributes are required in data.genericTransaction section.
- attributes is a key value map to store any related information with this transaction. Invoice ID, ID from an external service, ID or reference assigned to this transaction on your side can be the example usages.
- Narrative is the text that will be displayed on account statements. workflow.narrative configures the usage of narrative. workflow.narrative.sourcingMethod must be one of implicit or explicit.
- Implicitly defined narrative means the template of the narrative has already been defined by your solution consultant on IF side and it'll be used to generate the narrative text. In this case, workflow.narrative.enabled & data.narrative shouldn't be included in the payload.
- Explicitly defined narrative means the configuration of the narrative is passed in the payload. In this case, workflow.narrative.enabled is required. If the narrative would like to be discarded, workflow.narrative.enabled must be sent as false, otherwise it must be true. If narrative is enabled, data.narrative.template is also required.
- data.narrative.template defines how narrative text should be built. It supports Apache Freemarker template language (https://freemarker.apache.org/docs/dgui.html). The values defined in data.genericTransaction.attributes section are passed to template engine to build the narrative. If you'd like to build the narrative on your side and send it as plain text, you can send it in data.narrative.template field without using any template functionality.
- Example of narrative generation:
- Narrative Template: Payment for invoice ${invoiceId}
- invoiceId parameter is set in attributes as 123456
- Generated narrative: Payment for invoice 123456
 
- Narrative Template: 
- Generic transactions are created as completed and there is no additional status.
Update a Generic Transaction
There are two different workflows to update generic transaction.
1. Client Direct: Using this workflow, certain editable fields of Client Generic Transactions can be updated.
2. Organization Direct: Using this workflow, certain editable fields of Organization Generic Transaction can be updated.
PATCH /generic-transactions/{id}
{
  "workflow": {
    "code": "client.direct"
  },
  "data": {
    "genericTransaction": {
      "attributes": {
        "key01": "updated-value",
        "key02": null
      }
    }
  },
  "connect": {},
  "metadata": {}
}{
  "workflow": {
    "code": "client.direct"
  },
  "data": {
    "genericTransaction": {
      "id": "00000000-0000-0000-0000-000000000000",
      "type": "<generic-transaction-type>",
      "owner": "client",
      "clientId": "00000000-0000-0000-0000-000000000000",
      "accountId": "00000000-0000-0000-0000-000000000000",
      "transactionNumber": "20230613-ABCDEF",
      "amount": 10,
      "currency": "GBP",
      "status": "completed",
      "narrative": "narrative text",
      "creationDateTime": "2023-06-13T00:00:00.000",
      "attributes": {
        "key01": "updated-value"
      }
    }
  },
  "connect": {},
  "metadata": {}
}{
  "workflow": {
    "code": "organization.direct"
  },
  "data": {
    "genericTransaction": {
      "attributes": {
        "key01": "updated-value",
        "key02": null
      }
    }
  },
  "connect": {},
  "metadata": {}
}{
  "workflow": {
    "code": "organization.direct"
  },
  "data": {
    "genericTransaction": {
      "id": "00000000-0000-0000-0000-000000000000",
      "type": "<generic-transaction-type>",
      "owner": "organization",
      "clientId": null,
      "accountId": "00000000-0000-0000-0000-000000000000",
      "transactionNumber": "20230613-ABCDEF",
      "amount": 10,
      "currency": "GBP",
      "status": "completed",
      "narrative": "narrative text",
      "creationDateTime": "2023-06-13T00:00:00.000",
      "attributes": {
        "key01": "updated-value"
      }
    }
  },
  "connect": {},
  "metadata": {}
}- 
Only attributes of a generic transaction are allowed to be updated. If an already existing key is not available in the request, it means it shouldn't be updated. If a key mentioned in the request with a null value, it means the key should be deleted. 
- 
Updating attributes does not affect narrative of the transaction even if narrative template includes the updated attributes. Narratives are immutable and they are created on generic transaction creation. 
Get a Generic Transaction
GET /generic-transactions/{id}
{
  "workflow": {},
  "data": {
    "genericTransaction": {
      "id": "00000000-0000-0000-0000-000000000000",
      "type": "<generic-transaction-type>",
      "owner": "client",
      "clientId": "00000000-0000-0000-0000-000000000000",
      "accountId": "00000000-0000-0000-0000-000000000000",
      "transactionNumber": "20230613-ABCDEF",
      "amount": 10,
      "currency": "GBP",
      "status": "completed",
      "narrative": "narrative",
      "creationDateTime": "2023-06-13T00:00:00.000",
      "attributes": {
        "key01": "value01",
        "key02": "value02"
      }
    }
  },
  "connect": {},
  "metadata": {}
}{
 "workflow": {},
    "data": {
        "genericTransaction": {
            "id": "00000000-0000-0000-0000-000000000000",
            "type": "gwt-principal-organization",
            "owner": "organization",
            "clientId": null,
            "accountId": "00000000-0000-0000-0000-000000000000",
            "transactionNumber": "20240805-WE9GXX",
            "amount": 10.00,
            "currency": "GBP",
            "status": "completed",
            "attributes": {
                "description": "This transfer is related to expenses."
            },
            "narrative": "This transfer is related to expenses.",
            "creationDateTime": "2024-08-05T08:59:13.684091"
        }
    },
    "connect": {},
    "metadata": {}
}List Generic Transactions
GET /generic-transactions
Supported query parameters:
| parameter | description | 
|---|---|
| metadata.page.number | 0-indexed, default=0 | 
| metadata.page.size | default=20, max=100 | 
| data.genericTransaction.type | A predefined type used with generic transactions | 
| data.genericTransaction.owner | one of client, organization. default: client | 
| data.genericTransaction.clientId | ID of a client | 
| data.genericTransaction.accountId | ID of an account | 
| data.genericTransaction.transactionNumber | transaction number of generic transaction | 
| data.genericTransaction.amountFrom | minimum amount | 
| data.genericTransaction.amountTo | maximum amount | 
| data.genericTransaction.currency | ISO 4217 currency code | 
| data.genericTransaction.creationDateTimeFrom | minimum creation date time | 
| data.genericTransaction.creationDateTimeTo | maximum creation date time | 
| data.genericTransaction.attributess** a | A key from attributes map. Example usage: | 
{
   "workflow":{
      
   },
   "data":{
      "genericTransactions":[
         {
            "id":"00000000-0000-0000-0000-000000000000",
            "type":"<generic-transaction-type>",
            "owner":"client",
            "clientId":"00000000-0000-0000-0000-000000000000",
            "accountId":"00000000-0000-0000-0000-000000000000",
            "transactionNumber":"20230613-ABCDEF",
            "amount":10,
            "currency":"GBP",
            "status":"completed",
            "narrative":"narrative text",
            "creationDateTime":"2023-06-13T00:00:00.000",
            "attributes":{
               "key01":"value01",
               "key02":"value02"
            }
         },
         {
            "id":"00000000-0000-0000-0000-000000000000",
            "type":"gwt-principal-organization",
            "owner":"organization",
            "clientId":null,
            "accountId":"00000000-0000-0000-0000-000000000000",
            "transactionNumber":"20240807-6XGQ92",
            "amount":10.00,
            "currency":"GBP",
            "status":"completed",
            "attributes":{
               "description":"This transfer is related to expenses."
            },
            "narrative":"This transfer is related to expenses.",
            "creationDateTime":"2024-08-07T08:19:17.288243"
         }
      ]
   },
   "connect":{
      
   },
   "metadata":{
      "page":{
         "size":2,
         "number":0,
         "totalElements":1,
         "totalPages":1
      }
   }
}Webhooks
Generic Transaction webhooks have "generic-transactions" in the module field in the webhook container object.
There is only one type of webhook sent for generic-transactions as follows:
- generic-transaction-created
This type is exposed in the webhook.type field.
{
  "webhook": {
    "module": "generic-transactions",
    "type": "generic-transaction-created"
  },
  "data": {
    "genericTransaction": {
      "id":"00000000-0000-0000-0000-000000000000",
      "type":"gwt-principal",
      "owner":"client",
      "clientId":"00000000-0000-0000-0000-000000000000",
      "accountId":"00000000-0000-0000-0000-000000000000",
      "transactionNumber":"20240811-GWGK2W",
      "amount":50,
      "currency":"EUR",
      "status":"completed",
      "attributes":{
          "key01": "value01",
          "key02": "value02"
      },
      "narrative":"Monthly Banking Payment - Agust 2024",
      "creationDateTime":"2024-08-07T08:19:17.288243"
      
  },
  "connect": {},
  "metadata": {}
}Updated 1 day ago
