Appearance
Account Statements
Account Statements synthesize all operations affecting the Balance of a Wallet for a given month, along with the Balance at the start and end of that month. It also displays the sum of debits, and the sum of credits.
Feature activation – Accounts Statements are disabled by default
You can request access to this feature by contacting Treezor. Please keep in mind this service only applies starting February, 2022.
Banks are legally obligated to provide Accounts Statements for a duration of 5 years, although the requirements differ depending on the nature of the end user.
Account statements must provide mandatory information about:
- The account holder – Name, legal status, address, capital, VAT no., Companies Register no. (RCS)
- The mediator – Name, legal status, address, capital, VAT no., Companies Register no. (RCS)
Note – Account statements and parent-children relations
Parent Users can access Accounts Statement of their Children Users.
Treezor provides Account Statements in 2 formats:
- As PDF – Customize the templates and Treezor generates the statements in PDF.
- As JSON – Retrieve the raw information in JSON and you generate the statements.
Reading – Your legal obligations explained
Learn more about the requirements regarding statement of account and statement of fees.
As PDF Incompatible with crypto feature
Templated statements are Account Statements generated by Treezor in PDF file format. They can be provided as-is to your Users.
You may customize the HTML template of those Statements and request an Account Statement for any given month but the current one.
Account Statements for the previous month are generated between the 1st and 3rd of the current month.
Request an Account Statement
To request an Account Statement you may use the following request.
Query parameters
Attribute | Type | Description |
---|---|---|
walletId | string | The unique identifier of the Wallet. |
month | integer | The month of the statement (2 digits leading with 0 ) |
year | integer | The year of the statement (4 digits, e.g., 2024 ) |
Caution – You can generate statements from Feb, 2022 only
Treezor can't generate statements before the service was made available. Therefore, the earliest statement you can generate is for 02/2022.
Request
You can use the following request to generate the statement.
bash
curl -X GET {baseUrl}/core-connect/statements/{walletId}/computed?year={year}&month={month} \
--header 'Authorization: Bearer {accessToken}'
1
2
2
Returns an object containing a download URL (link
).
json
{
"link": "https://xxxxxx.s3.eu-west-3.amazonaws.com/tmp/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxxx.pdf",
"expireIn": 300
}
1
2
3
4
2
3
4
The provided download URL expires after 5 minutes.
Customize the template
Produce the template
The templating engine that should be used for the template is Twig with some limitations.
Providing a new template will not affect previously generated Accounts Statments.
html
<html lang="en">
<head>
<meta charset="UTF-8">
<meta content="width=device-width, initial-scale=1.0" name="viewport">
<title>Statement</title>
<style>
body{background-size:100% 100%;margin:25px;padding:1%;font-family:-webkit-pictograph,Roboto,sans-serif}.statement-header,td,th{text-align:left}.statement-header-title{font-size:20px;white-space:nowrap}.header-baseline{color:#3e5064;text-align:center}.spacer{width:100%;border-bottom:1px solid #e5e5e5;margin:1em}.bank-account-informations{margin-bottom:4em}.infos>div>div>p{margin:0}.statement-first-balance-amount{text-align:right;display:inline}.statement-operations td{padding:14px;font-size:10px}.statement-operations th{text-align:left;font-size:12px}.statement-operations tr:nth-child(2n){background-color:#ddd}.statement-operations td th{border:1px solid #ddd;text-align:left;padding:14px}.statement-last-balance,.statement-operations-credit,.statement-operations-debit{text-align:right}table{border-spacing:0;font-family:arial,sans-serif;border-collapse:collapse;width:100%}table>thead>tr{background-color:#f7f9ff}table>thead>tr>th{text-align:left;padding:1em}.footer-total-movement td{text-align:right;padding:10px}.footer-new-balance,.total-amount-fees-and-credit-note{margin-top:7px;width:70%;margin-left:auto;background-color:#f7f9ff;padding:10px;text-align:right}.statement-footer{position:fixed;bottom:0;display:flex;flex-direction:column;width:100%;align-items:right}.statement-footer>p{font-size:8px;line-height:0}td{margin-bottom:10px}
</style>
<link
href="https://fonts.googleapis.com/css?family=Roboto:400,100,100italic,300,300italic,400italic,500,500italic,700,700italic,900italic,900"
rel="stylesheet" type="text/css">
</head>
<body>
<div class="statement-header">
<table>
<tbody>
<tr>
<th>
<img alt="agent-logo"
src=""
width="55%">
</th>
<th class="statement-header-title">
RELEVE D'OPERATIONS
</th>
</tr>
</tbody>
</table>
<p class="header-baseline">Compte - en euros</p>
<div class="spacer"></div>
<div class="statement-content">
<table>
<tbody>
<tr>
{% if user.userTypeId and user.legalName and user.legalRegistrationNumber and user.userTypeId !=
1 %}
<th>{{ user.legalName }} {{ user.legalRegistrationNumber }}</th>
{% else %}
<th>{{ user.firstname }} {{ user.lastname }}</th>
{% endif %}
</tr>
<tr>
<td>{{ user.address1 }}</td>
</tr>
<tr>
<td>{{ user.postcode }} {{ user.city }}
{% if user.state %} {{ user.state }} {% endif %}
{% if user.country %} {{ user.country }} {% endif %}
</td>
</tr>
</tbody>
</table>
</div>
<div class="bank-account-informations">
<div>
<div>
<h3>IBAN</h3>
<p>{{ wallet.iban }}</p>
</div>
</div>
</div>
<div>
<div>
<h3>Relevé d'opérations</h3>
</div>
</div>
<p>du {{ firstBalance.date|date("d/m/Y") }} au {{ lastBalance.date|date("d/m/Y") }}</p>
<div class="statement-first-balance-amount">
<p>Votre précédent solde au {{ firstBalance.date|date("d/m/Y") }}</p>
<h3>{{ firstBalance.amount }} €</h3>
</div>
<table class="statement-operations">
<thead>
<tr>
<th>Date</th>
<th>Type</th>
<th>Opération</th>
<th>Débit</th>
<th>Crédit</th>
</tr>
</thead>
<tbody>
{% for operation in operations %}
<tr>
<td>{{ operation.date|date("d/m/Y") }}</td>
<td>{{ operation.type }}</td>
<td>{{ operation.name }}</td>
<td class="statement-operations-debit">{% if operation.direction == 'DEBIT' %} {{ operation.amount }}
{% endif %}
</td>
<td class="statement-operations-credit">{% if operation.direction == 'CREDIT' %}
{{ operation.amount }} {% endif %}
</td>
</tr>
{% endfor %}
<tr>
<td></td>
<td></td>
<td>Total des mouvements</td>
<td class="statement-operations-debit">{{ totalDebit }}</td>
<td class="statement-operations-credit">{{ totalCredit }}</td>
</tr>
</tbody>
</table>
<div>
<table class="footer-new-balance">
<tbody>
<tr>
<td>Votre nouveau solde au {{ lastBalance.date|date("d/m/Y") }}</td>
<td class="statement-last-balance"><h3>{{ lastBalance.amount }} €</h3></td>
</tr>
</tbody>
</table>
</div>
<div>
<div>
<p><i>Total des frais de gestion sur la période : {{ totalAmountFees }} €</i></p>
<p><i>Total des remboursements des frais de gestion sur la période : {{ totalAmountCreditNote }} €</i></p>
</div>
</div>
</div>
<div class="statement-footer">
<p>_PARTENAIRE_ TYPE DE SOCIETE_ CAPITAL_ RCS_ SIREN_ SIEGE SOCIAL_ agissant en qualité [1 : d'agent de services de paiement OU 2 : distributeur de monnaie électronique]
</p>
<p> de Treezor SAS, établissement de monnaie électronique et agréée par l'ACPR sous le numéro 16798 - [email contact Partenaire] -
</p>
<p> Médiateur : AFEPAME, https://mediateur-consommation-afepame.fr/
</p>
</div>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
You can check the list of all available variables.
Notes
- The
operation.type
variable is always provided in French. - The
totalAmountFees
must be present - The
totalAmountCreditNote
is optional
Upload the template
Don't forget to encode your template in base64.
bash
curl -X PUT {baseUrl}/customization/templates/wallet.statement/template \
--header 'Authorization: Bearer {accessToken}' \
--header 'Content-Type: application/json' \
-d '{
"template": "{base64encodedTemplate}"
}'
1
2
3
4
5
6
2
3
4
5
6
This should return an HTTP Status Code 201
without any content.
If something goes wrong, you can also get an error.
You may also customize the template using the Dashboard.
Test the template
To test your template you may use the following request, which will populate your template with dummy data.
bash
curl -X POST {baseUrl}/simulation/operations \
--header 'Authorization: Bearer {accessToken}' \
--header 'Content-Type: application/json' \
-d '{payload}'
1
2
3
4
2
3
4
Here is a {payload}
example:
json
{
"walletId": {walletId},
"date": "2023-10",
"operations": {
"payin": 5,
"payinrefund": 2,
"payout": 6,
"payoutrefund": 1,
"transfer": 3,
"cardtransaction": 7,
"transferfees":2,
"transfercreditnote":1
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
2
3
4
5
6
7
8
9
10
11
12
13
14
Answer with a 201
HTTP Status Code.
You can then follow with a normal request of Account Statement to download it.
Tips
- Use the same value for
payin
andpayinrefund
to include payin refunds in your test. - Use a fairly high
payin
value, as types (cheque, sctr) are generated randomly. - An Account Statement generated for a given month can't be overriden nor regenerated.
As JSON
The process for generating a statement from raw data is as follows:
- Retrieve the data needed for the building a statement via an API Call to Treezor
- Optionally decrypt the data
- Generate a PDF on your own, using the collected data
Note – When the Encryption feature is active
- The operation
name
field returns an empty string. - Encrypted fields are returned among the header parameters with the following structure:
operations.metadata.<field>
.
Retrieve the raw data
Query parameters
Attribute | Type | Description |
---|---|---|
walletId | string | The unique identifier of the Wallet. |
month | integer | The month of the statement (2 digits leading with 0 ) |
year | integer | The year of the statement (4 digits, e.g., 2022 ) |
Caution – You can generate statements from Feb, 2022 only
Treezor can't generate statements before the service was made available. Therefore, the earliest statement you can generate is for 02/2022.
Request
You can use the following request to retrieve the raw data, with the relevant query parameters.
bash
curl -X GET {baseUrl}/core-connect/statements/{walletId}/raw?month={month}&year={year} \
--header 'Authorization: Bearer {accessToken}'
1
2
2
Returns the object containing all the necessary data.
json
{
"firstBalance":{
"amount":5.76,
"date":"2024-01-01"
},
"lastBalance":{
"amount":-553.03,
"date":"2024-01-31"
},
"operations":[
{
"date":"2024-01-22",
"type":"cardTransaction",
"name":"Reece Little (978 46.81)",
"direction":"DEBIT",
"amount":46.81,
"metadata": {}, //new
},
// some operations hidden for brevity
{
"date":"2024-01-13",
"type":"check",
"name":"Check (258925650)",
"direction":"CREDIT",
"amount":97.34,
"metadata": {}, //new
},
{
"date":"2024-01-14",
"type":"cardTopup",
"name":"Card Top Up (via hipay) (1716679992)",
"direction":"CREDIT",
"amount":87.96,
"metadata": {}, //new
}
],
"totalOperation":-558.79,
"totalAmountFees":0,
"totalAmountCreditNote":0,
"user":{
"title":"M",
"firstname":"Alex",
"lastname":"Oak",
"address1":"15 Rosewood lane",
"address2":"",
"address3":"",
"postcode":"75017",
"city":"Paris",
"country":"FR"
},
"wallet":{
"iban":"FR7616798000010000166897545",
"bic":"TRZOFR21XXX"
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
If you get a 404
HTTP Status Code, the Statement data is not yet ready or the Wallet doesn't exist.
Build a template
You need to:
- Build a template using your favorite template engine
- Decipher the data (if the Encryption feature is activated)
- Inject the data into the template
- Generate a PDF
- Send the generated PDF to your end user.
Variables
Below is a list of available variables for Account Statement templates.
Variable | Related to | Additional information (if any) |
---|---|---|
wallet.iban | Wallet | |
wallet.bic | Wallet | |
user.title | User | |
user.firstname | User | |
user.lastname | User | |
user.address1 | User | |
user.address2 | User | |
user.address3 | User | |
user.postcode | User | |
user.city | User | |
user.country | User | |
operations[*].date | Operations | |
operations[*].type | Operations | Always provided in French. |
operations[*].name | Operations | |
operations[*].direction | Operations | |
operations[*].amount | Operations | |
firstBalance.currency | Balances | |
firstBalance.date | Balances | The date of the first Balance of the month. |
firstBalance.amount | Balances | The amount of the first Balance of the month. |
lastBalance.currency | Balances | |
lastBalance.date | Balances | The date of the last Balance of the month. |
lastBalance.amount | Balances | The amount of the last Balance of the month. |
totalDebit | Balances | The cumulated amount of debit Operations. |
totalCredit | Balances | The cumulated amount of credit Operations. |
totalOperation | Totals | The sum of all Operations Mandatory |
totalAmountFees | Totals | The sum of Transfers of type Fees Mandatory |
totalAmountCreditNote | Totals | The sum of Transfers of type Credit note Optional |
Endpoints
Endpoint | Scope |
---|---|
/core-connect/statements/{walletId}/computed Request a PDF statement for a given Wallet | read_only |
/core-connect/statements/{walletId}/raw Retrieve statement information for a given Wallet | read_only |