forked from teamleadercrm/api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchanges-backwards-compatible.apib
367 lines (225 loc) · 15 KB
/
changes-backwards-compatible.apib
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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
<a name="additions"></a>
### Additions
We list all backwards-compatible additions here. These are currently available in all published versions.
(There is also a [list of backwards-incompatible upgrades](#changelog) available, but those only apply if you [upgrade your API version](#upgrading-your-api-version).)
#### May 2023
- We added `team_lead_id` to the filters on `teams.list`.
- We added sorting on `first_name`, `last_name`, `email` and `function` to `users.list`.
- We added `creditNote.updated`, `creditNote.deleted`, `creditNote.sent` types to supported Webhook types.
#### April 2023
- We added `ids` to the filters on `teams.list`.
#### March 2023
- We added `customField`,`timeTracking` and `department` as allowed types on `migrate.id`.
- We added `credit_note_date_before` and `credit_note_date_after` to the filters on `creditNotes.list`.
- We added `ids` to the filters on `timeTrackings.list`.
- We added `term` to the filters on `teams.list`.
- The property `gender` has been expanded with additional values on:
- `contacts.create`
- `contacts.info`
- `contacts.list`
- `contacts.update`
#### February 2023
- Product custom fields are now included as `custom_fields` on `products.info`.
#### January 2023
- We added `user_id` to `timeTracking.add`.
- We updated the HTTP verb for all endpoints to `POST`. Using `GET ` for `.list`, `.info` and `migrate` endpoints is still possible, but deprecated.
#### December 2022
- We added `secondary_position` and `division` to the related company data on `contacts.info`.
#### November 2022
- We added `invoice_date` as a sort field on `invoices.list`.
#### October 2022
- We added `default_department` and `created_at` to the sorting options on `departments.list`.
#### September 2022
- We added `project_id` to `invoices.draft` and `invoices.update`.
- We added `payment_term`, `grouped_lines` and `invoice_generation` to `subscriptions.info`.
- We added `starts_on` and `ends_on` to `subscriptions.list` and `subscriptions.info`.
- We added `subscriptions.create` and `subscriptions.update`.
- We added the `quotations.send` endpoint.
- We clarified how the optional `folder` argument for the `files.upload` endpoint works.
#### August 2022
- We added `invoices.removePayments`.
- We added `department_id` to the filters on `subscriptions.list`.
- We added `tags` to `companies.update`.
#### July 2022
- We added `product` and `project` as subject type for `files.list`.
- We added `priority` to `tasks.list` and `tasks.info`.
- We added `vat_number` to the filters on `companies.list`.
#### June 2022
- We added `files.list`, `files.info`, `files.download`, `files.upload` and `files.delete`.
#### May 2022
- We added `status` as a sort field on `subscriptions.list`.
#### April 2022
- We added the `contacts.updateCompanyLink` endpoint.
- We added the `subscriptions.deactivate` endpoint.
#### March 2022
- We added the `subscriptions.info` and `subscriptions.list` endpoints.
#### February 2022
- We added `customer` to the filters on `invoices.list`.
- We added a `subscription` filter to `invoices.list`.
- We added `project` to `invoices.list` and `invoices.info`.
#### December 2021
- We added `on_hold_since` to `invoices.info`.
- We added `deal_id` to the filters on `invoices.list`.
- We added `project_id` to the filters on `invoices.list`.
- We added `invoice_date_before` and `invoice_date_after` to the filters on `invoices.list`.
- We added an `updated_since` filter to `projects.list`.
#### November 2021
- We added `status` on `companies.list` and `companies.info`.
- We added `status` on `contacts.list` and `contacts.info`.
- We added `ids` to the filters on `creditNotes.list`.
- We added `invoice_id` and `project_id` to the filters on `creditNotes.list`.
- We added `discounts` to `creditNotes.info`.
- We added `added_at` on `products.list`, and `tasks.list`.
- We added `created_at` on `projects.list`.
#### September 2021
- We added `sort` to `timeTracking.list`.
- We added `teams.list`.
#### June 2021
- We added `description` on `products.add`.
- We added `title` on `tasks.info` and `tasks.list`.
- We added `term` to the filters on `workTypes.list`.
- We added `started_on` to `timeTracking.update` and `timeTracking.add`.
- We added the `quotations.delete` endpoint.
- We changed the behaviour of the started_before, started_after, ended_before, and ended_after filters on timeTracking.list to be inclusive. So "started after midnight" will include time tracking that started exactly on midnight.
- We added `status` to `quotations.info` and `quotations.list`.
#### March 2021
- Updated the `migrate.id` endpoint for type `quotation` to return the first or accepted quotation uuid for given deal id.
#### January 2021
- We added `deal` on `invoices.list` and `invoices.info`.
#### October 2020
- We added `title` as a sort field on `projects.list`.
- We added `area_level_two` to the .list and .info responses for `company`, `contact` and `department` addresses.
- We added `area_level_two_id` to the .add and .update calls for `companies` and `contacts`.
- We added `starts_on` to `milestones.create`, `milestones.update`, `milestones.list`, `milestones.info`, and `projects.create` (in the milestone context).
- We added `budget` on `projects.update`.
- We added `customer` on `projects.update`.
- We added `starts_on` and `desc` to the sort options on `milestones.list`.
- We added `file` to `invoices.list` and `invoices.info`.
- We added `quotations.accept` endpoint.
#### September 2020
- We added the `milestones.close` and `milestones.open` endpoints.
- We added the `created_at` and `updated_at` fields to `quotations.list` and `quotations.info`. Please note that these fields are nullable and will only be filled in for future quotations.
- We added the `discounts` field to `quotations.info`.
- We added the `purchase_price` field to `quotations.list`, `quotations.info`, `quotations.create` and `quotations.update`.
- We added `projects.close` and `projects.reopen` endpoints.
#### August 2020
- We added a filter `done` to `events.list`.
- We added the `currency_exchange_rate` to `invoices.list`.
- We added the `product_id` property to `quotations.create`, `quotations.update`, `invoices.draft` and `invoices.update`.
#### July 2020
- We added `quotations.list`, `quotations.create` and `quotations.update`.
#### June 2020
- We added the `emails` property to `departments.list`.
- We added the `status` property to `departments.info` and `departments.list`, this property is also available as a filter on `departments.list`.
- We added a filter `scheduled` to `tasks.list`.
- We added the `total` field to `quotations.info`.
#### May 2020
- We no longer require all fields in `projects.update`, only the id remains required.
- We added the `purchase_order_number` field to `projects.info`, `projects.create`, and `projects.update`.
#### April 2020
- We added the `description` field to `milestones.info`, `milestones.create`, and `milestones.update`.
- We added the `propagate_date_changes` property to `milestones.update`. This allows propagating the new due date difference to the due date of all open tasks of that milestone, and recursively to all depending milestones.
- We added the `vat_number` property to `contacts.info`.
- Project custom fields are now included as `custom_fields` on `projects.info`. They can also be added and updated through the `projects.create` / `projects.update` endpoints.
#### March 2020
- We added actuals and budget to `projects.list`, `projects.info`, `milestones.list`, and `milestones.info`.
- We added `depends_on` to the `milestones.info` and `milestones.list` endpoints.
- We added `dependency_for` to the `milestones.info` and `milestones.list` endpoints. This indicates all the milestones for which the current milestone is a dependency.
- We added `depends_on` to the `milestones.create` and `milestones.update` endpoints. It allows setting a dependency on another milestone of the same project.
#### February 2020
- We added an `ids` filter to `lostReasons.list`.
- As events can be linked to deals, we added the `deal` link type to `events.list` and `events.info`, and allow filtering on deals in `events.list`.
- We added `lost_reason` to the response of `deals.info`.
- We added `lost_reason` to the response of `deals.list`. This is composed of a `lostReason` object along with a more elaborate `remark`.
- We added a filter `term` to `invoices.list`.
- We added the `purchase_order_number` to the response of both `deals.list` and `deals.info` request.
- We added the `summary` to the response of both the `deals.list` and `deals.info` request. The `summary` can also be added and updated through the `deals.create` / `deals.update` endpoints.
#### January 2020
- We added the time tracking `locked` and `updatable` properties to `timeTracking.info`.
- We exposed the "Freeze time tracking after a number of days" preference in `users.me`.
- We added format `ubl/e-fff` to `invoices.download`.
- We added filters `estimated_closing_date_from` and `estimated_closing_date_until` to `deals.list`.
- We added a new sorting option `weighted_value` to `deals.list` and will allow ascending as well as descending orders on sorts.
The default remains created_at and descending as before if nothing is passed.
- We added the `weighted_value` to the response of both `deals.list` and `deals.info` requests.
- We added the `extra_option_allowed` information (for single select custom fields) to `customFieldDefinitions.list` and `customFieldDefinitions.info` endpoints.
- We added format `ubl/e-fff` to `creditNotes.download`.
#### October 2019
- We added `milestones.delete`.
- We added a `estimated_closing_date` filter to `deals.list`.
- We added a filter `created_before` to `deal.list`.
- We modified filter `responsible_user_id` in `deal.list` to also accept an array of responsible_user_ids.
- Task custom fields are now included as `custom_fields` on `tasks.info`. They can also be added and updated through the `tasks.create` / `tasks.update` endpoints.
- Milestone custom fields are now included as `custom_fields` on `milestones.info`. They can also be added and updated through the `milestones.create` / `milestones.update` endpoints.
#### July 2019
- We added an `updated_since` filter to `products.list`.
- We added `project` to `tasks.info` and `tasks.list`.
- We added a filter by `subject` to `timeTracking.list`.
- A `task_id` filter has been added to `/events.list`.
- We added a `term` filter to `milestone.list`.
#### June 2019
- We added a `term` filter to `tasks.list`.
- We added `tasks.complete` and `tasks.reopen` endpoints.
- We added `due_by` and `due_from` to `tasks.list` filters.
- We added a `tasks.schedule` endpoint.
- We added the ability to sort `tasks.list` based on a descending `due_at`.
- `tasks.info` and `tasks.list` now return information about the customer.
- We added `customer` parameter to `tasks.create` and `tasks.update`.
- In order to link milestones and deals to a task, we added `milestone_id` and `deal_id` as optional parameters to `tasks.create` and `tasks.update`.
- `tasks.list` and `tasks.info` now return the milestone and deal objects.
#### May 2019
- We added a `started_at` property to `timers.update` in order to be able to update the start time of a running timer.
- We added `sent` as a boolean to `invoices.info` and `invoices.list`.
- We added an optional filter on `ids` to `invoices.list`.
- We added `creditNote.booked` and `product.added` to the available webhooks list.
#### April 2019
- In `users.info`, we added the `status` property to the response since it is now possible to retrieve deactivated users.
- In `users.list`, you can now also request deactivated users, by using a new filter on `status`.
By default, the endpoint keeps returning active users only. The status is also returned in the response data.
- We've added a `products.add` endpoint.
Because you can provide the selling price of a product in this endpoint, we also return it in `products.info` from now on.
- We now also return the `payment_reference` of an invoice in the `invoices.list`.
We also made it filterable through the `payment_reference` filter.
- We added the `purchase_order_number` to all relevant endpoints (`invoices.draft`, `invoices.update`, `invoices.info` and `invoices.list`).
The property is also filterable through the `purchase_order_number` filter.
- We added `currency_exchange_rate` to `quotations.info`.
- The `events.list` endpoint now has an optional filter property `ids`.
- The `tasks.list` endpoint now has an optional filter property `ids`.
- We added an `invoices.credit` endpoint.
#### March 2019
- On `invoices.draft` and `invoices.update` you can now also provide (a) global discount(s) through the `discounts` property.
- We've published a bunch of `tasks` endpoints (`tasks.list`, `tasks.info`, `tasks.create`, `tasks.update`, `tasks.delete`).
- We now also return a `currency_exchange_rate` on all `.info` endpoints where we support multi-currency.
That is `quotations.info`, `invoices.info` and `creditNotes.info`.
#### February 2019
- We now also return the `invoicing_method` of a milestone. Both in `milestones.list` and `milestones.info`.
- We now expose the invoiceability of time trackings and running timers. You can now use the `invoiceable` property on the following endpoints:
- `timeTracking.list`
- `timeTracking.info`
- `timeTracking.add`
- `timeTracking.update`
- `timers.current`
- `timers.start`
- `timers.update`
We also return an `invoiceable` preference in the `users.me` endpoint that exposes whether a user prefers to track time by default as invoiceable or not.
- We've added a `national_identification_number` property on contacts.
You can read it from `contacts.list` and `contacts.info`.
It's also writeable through `contacts.add` and `contacts.update`.
- Invoicing custom fields included as `custom_fields`.
They are returned in `invoices.info`.
They can be added or updated through `invoices.draft` and `invoices.update`.
- Deal can now be filtered with a `term` in `deals.list`.
We will return deals of which the term is part of the title, reference or customer's name.
- We have created a way to fetch more data about related resources: sideloading.
More information can be found [here](#sideloading).
- We didn't provide you with a way to find the uuid of a quotation.
Based on a v1 deal id, you can now retrieve the uuid of a quotation with `migrate.id`.
#### January 2019
- The `projects.list` endpoint has an optional filter to filter on `term` now.
We return projects for which the term appears in the title or description.
- During `invoices.draft` and `invoices.update`, we now allow you to provide a `withholding_tax_rate_id`.
Don't worry if you don't know what this is. Withholding taxes only apply in certain countries, eg Spain or Italy.
- We added a filter on `term` in `users.list`.
We return those users who have the term in their first name, last name or email address.
- We already had a part of the products APIs for our own usage, but since it might be useful to you, we are making it public.
So `products.list` and `products.info` are now available for usage.