Learn how to collect an incoming invoice to start the payable flow.

Overview

There are several ways to collect payables into Monite:

When a payable is created from a PDF, PNG, or JPEG file, Monite’s OCR service automatically extracts the invoice information from the file and a new payable is created with the extracted data fields accordingly. The file property of the payable contains the file metadata and the link to access the original source file.

About Monite OCR

Monite OCR uses top-notch Optical Character Recognition (OCR) algorithms to pull text from payables.

  • The OCR process is asynchronous and the processing time may vary according to the document size. The webhook ocr_finished is triggered once the OCR has finished processing the file and storing the extracted data into a payable.
  • The field payable.ocr_status reflects the current status of the OCR process of a payable. Its possible values are processing, error, and success.
  • The maximum image file size is 10 MB.
  • The maximum email size is 25 MB (including all attachments).
  • Files with dimensions smaller than 400x400 px are not considered payables, thus, they are not processed.
  • PDF files must have at least one page with dimensions bigger than 400x400 px to be considered a payable, otherwise, they are not processed.
  • Multipage PDF files can have up to 10 pages.
  • Monite’s OCR service is not executed if the format of the uploaded document is not supported or the number of pages exceeds 10. Therefore, no invoice information is stored. In this case, only the information about the file is stored.
  • You can configure the system to avoid the creation of duplicated payables based on the information obtained by the OCR.

Create a payable from data

If you already have the invoice data (amount in minor units, currency, vendor information, and other details) stored somewhere as individual attributes, you can create a payable with these attributes by calling POST /payables.

You can provide the base64-encoded contents of the original invoice file in the field base64_encoded_file:

1curl -X POST 'https://api.sandbox.monite.com/v1/payables' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer ACCESS_TOKEN' \
5 -d '{
6 "partner_metadata": {},
7 "currency": "EUR",
8 "description": "Restock office supplies",
9 "due_date": "2023-07-15",
10 "payment_terms": {
11 "name": "2/10, 1/20, net 30",
12 "term_1": {
13 "number_of_days": 10,
14 "discount": 200
15 },
16 "term_2": {
17 "number_of_days": 20,
18 "discount": 100
19 },
20 "term_final": {
21 "number_of_days": 30
22 }
23 },
24 "suggested_payment_term": {
25 "date": "2023-07-25",
26 "discount": 200
27 },
28 "issued_at": "2023-06-15",
29 "counterpart_id": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
30 "counterpart_bank_account_id": "ee415e8a-4368-4ef8-b192-d25b8e86ad0f",
31 "counterpart_address_id": "d0f2899d-e2b1-4b95-8411-2ed1a9063bce",
32 "counterpart_vat_id_id": "c0d3ca66-bdfa-4cdb-aceb-633d4dfe4f11",
33 "base64_encoded_file": "... Base64-encoded contents of the invoice file ...",
34 "file_name": "invoice.pdf",
35 "tag_ids": [
36 "ea837e28-509b-4b6a-a600-d54b6aa0b1f5"
37 ],
38 "document_id": "DE2287",
39 "sender": "hello@example.com"
40 }'

Notes:

  • The file_name field is optional. If omitted, it defaults to "default_file_name".
  • If the settings are configured to automatically set suggested_payment_term, this object can be omitted from the request body.
  • The fields subtotal and total_amount of the payable are automatically calculated based on the values of the line items, therefore, they are read-only and appear only in the response schema. This feature can be disabled in the partner’s settings by calling PATCH /settings passing the field enable_line_items as false (the default value is true). Once enable_line_items is disabled, the fields amount, subtotal, tax, and tax_amount of the payable object become editable during its creation and update, as they will no longer be calculated/re-calculated based on line items.

The successful response returns the id assigned to this payable, along with the information passed in the request. You can use this id in other API calls to update the data of this payable or trigger status transitions:

1{
2 "partner_metadata": {},
3 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0",
4 "entity_id": "en-your0000-enti-ty00-1D3799b65bcf",
5 "marked_as_paid_with_comment": null,
6 "marked_as_paid_by_entity_user_id": null,
7 "amount_due": 9900,
8 "amount_paid": 0,
9 "amount_to_pay": 9900,
10 "status": "new",
11 "source_of_payable_data": "user_specified",
12 "currency": "EUR",
13 "total_amount": 0,
14 "description": "Restock office supplies",
15 "due_date": "2023-07-15",
16 "payment_terms": {
17 "name": "2/10, 1/20, net 30",
18 "term_1": {
19 "number_of_days": 10,
20 "discount": 200
21 },
22 "term_2": {
23 "number_of_days": 20,
24 "discount": 100
25 },
26 "term_final": {
27 "number_of_days": 30
28 }
29 },
30 "suggested_payment_term": {
31 "date": "2023-07-25",
32 "discount": 200
33 },
34 "issued_at": "2022-06-15",
35 "counterpart_id": "8737964a-5246-47f4-8243-8728a2be1e75",
36 "counterpart_bank_account_id": "ee415e8a-4368-4ef8-b192-d25b8e86ad0f",
37 "counterpart_address_id": "d0f2899d-e2b1-4b95-8411-2ed1a9063bce",
38 "counterpart_vat_id_id": "c0d3ca66-bdfa-4cdb-aceb-633d4dfe4f11",
39 "counterpart_bank_id": null,
40 "counterpart_account_id": null,
41 "counterpart_name": "Acme Inc.",
42 "counterpart_address": {
43 "country": "DE",
44 "city": "Berlin",
45 "postal_code": "10115",
46 "state": "BE",
47 "line1": "Flughafenstrasse 52",
48 "line2": "Floor 2"
49 },
50 "payable_origin": "upload",
51 "was_created_by_user_id": "e4e422fc-6956-4fdd-b091-920329f8b92e",
52 "currency_exchange": {
53 "default_currency_code": "EUR",
54 "rate": 10.0,
55 "total": 0
56 },
57 "file": {
58 "id": "2d14935e-505b-4863-a082-b6a340acabbc",
59 "created_at": "2022-04-05T06:31:31.431Z",
60 "file_type": "payables",
61 "name": "file name",
62 "region": "eu-central-1",
63 "md5": "623470039566983ed5e5945f769ea873",
64 "mimetype": "application/pdf",
65 "url": "https://monite-file-saver-payables-eu-central-1-dev.s3.amazonaws.com/2d14935e.../669bab57c57f.pdf",
66 "size": 49463,
67 "previews": [],
68 "pages": []
69 },
70 "tags": [
71 {
72 "name": "Marketing",
73 "id": "ea837e28-509b-4b6a-a600-d54b6aa0b1f5",
74 "created_at": "2022-09-07T16:35:18.484507+00:00",
75 "updated_at": "2022-09-07T16:35:18.484507+00:00",
76 "created_by_entity_user_id": "efe7eedd-89c5-56f5-984c-0712ee41a2eb"
77 }
78 ],
79 "created_at": "2022-06-17T06:31:31.431Z",
80 "updated_at": "2022-06-17T06:31:31.431Z",
81 "approval_policy_id": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
82 "document_id": "DE2287",
83 "subtotal": 0,
84 "tax": null,
85 "tax_amount": null,
86 "sender": "hello@example.com"
87}

Automatic calculation of due date

If the values of the fields payment_terms.final_term and issued_at are provided in the payable, the due_date will be automatically calculated based on issued_at plus the number of days defined by payment_terms.final_term.number_of_days.

For example, if issued_at equals to 2023-06-15 and payment_terms.term_final.number_of_days equals to 10, the due_date will be automatically set to 2023-06-25.

In any other case, the due_date supplied by the user is stored in the payable. The payment_terms and issued_at fields have priority in the calculation of the due_date, even if thedue_date is supplied by the user.

The automatic calculation of the due_date happens when the payable is parsed by the OCR, created with data, or updated.

Suggested payment date

Once the payable is created, Monite automatically fills the payable’s field suggested_payment_term with a suggestion for the payment date and corresponding discount, if available, based on its payment terms (represented by the field payment_terms). When the payable’s issued_at or payment_terms fields are updated, the value for the suggested_payment_term is recalculated.

It is possible to choose the payment term (term_1, term_2, or term_final) to be suggested as default by setting the field payment_priority in the entity’s settings to one of these values:

  • working_capital: Selects the term with the latest possible payment target.

  • bottom_line: Selects the term with the highest discount.

  • balanced: Selects the intermediate term, that is, a balance between duration and drawn discount.

The suggested_payment_term will be calculated based on the field issued_at added by the term_X.number_of_days. Note that this suggestion does not affect the invoice’s due date, which remains the same.

Change the payment priority

To update the payment_priority of in the entity’s settings, call PATCH /entities/{entity_id}/settings, passing the new payment_priority in the body:

1curl -X PATCH 'https://api.sandbox.monite.com/v1/entities/{entity_id}/settings' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer YOUR_PARTNER_TOKEN' \
5 -d '{
6 "payment_priority": "working_capital"
7 }'

Attach file

You can attach an invoice file to an existing payable, in any status, by calling POST /payables/{payable_id}/attach_file:

1curl -X POST 'https://api.sandbox.monite.com/v1/payables/{payable_id}/attach_file' \
2 -H 'accept: application/json' \
3 -H 'X-Monite-Version: 2024-01-31' \
4 -H 'X-Monite-Entity-Id: ENTITY_ID' \
5 -H 'Authorization: Bearer ACCESS_TOKEN' \
6 -H 'Content-Type: multipart/form-data' \
7 -F 'file=@payable.png;type=image/png'

The provided file is then returned in the file field on the payable object.

1{
2 "partner_metadata": {},
3 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0",
4 "marked_as_paid_with_comment": null,
5 "marked_as_paid_by_entity_user_id": null,
6 "amount_due": 9900,
7 "amount_paid": 0,
8 "amount_to_pay": 9900,
9 "entity_id": "en-your0000-enti-ty00-1D3799b65bcf",
10 "status": "new",
11 "source_of_payable_data": "user_specified",
12 "currency": "EUR",
13 "total_amount": 0,
14 "description": "Restock office supplies",
15 "due_date": "2022-07-15",
16 "payable_origin": "upload",
17 "file": {
18 "id": "2d14935e-505b-4863-a082-b6a340acabbc",
19 "created_at": "2022-04-05T06:31:31.431Z",
20 "file_type": "payables",
21 "name": "payable",
22 "region": "eu-central-1",
23 "md5": "623470039566983ed5e5945f769ea873",
24 "mimetype": "image/png",
25 "url": "https://monite-file-saver-payables-eu-central-1-dev.s3.amazonaws.com/2d14935e.../payable.png",
26 "size": 49463,
27 "previews": [],
28 "pages": []
29 },
30 "tags": [
31 {
32 "name": "Marketing",
33 "id": "ea837e28-509b-4b6a-a600-d54b6aa0b1f5",
34 "created_at": "2022-09-07T16:35:18.484507+00:00",
35 "updated_at": "2022-09-07T16:35:18.484507+00:00",
36 "created_by_entity_user_id": "ea837e28-509b-4b6a-a600-d54b6aa0b1f5"
37 }
38 ],
39 "created_at": "2023-11-21T15:32:36.695Z",
40 "updated_at": "2023-11-21T15:32:36.695Z",
41 "other_extracted_data": {...},
42 ...
43}

Notes:

  • The uploaded file is stored only for reference purposes.
  • The file is not processed by the OCR or validated, therefore, the users need to ensure that the information in the file is correct.
  • If the payable already has a file attached, an error is returned when trying to attach another one.

Cancel duplicated payables automatically

You can configure the system to avoid the creation of duplicated payable based on the information obtained by the OCR.

To enable this feature, send a PATCH request to the /settings endpoint, setting the payable.allow_cancel_duplicates_automatically field to true:

1curl -X PATCH 'https://api.sandbox.monite.com/v1/settings' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer YOUR_PARTNER_TOKEN' \
5 -d '{
6 "payable": {
7 "allow_cancel_duplicates_automatically": true
8 }
9 }'

This way, once the counterpart is successfully auto-linked and the OCR identifies the invoice number inside the payable, the system verifies if there is any invoice with an identical counterpart ID (counterpart_id field) and invoice number (document_id field) for the given entity. If a payable with this information is found, i.e. the payable already exists, the system automatically sends the newly created payable to the canceled status.

To ensure the automatic cancellation of duplicated payables, it is imperative to have the auto-linking feature enabled.

Upload files via API

You can upload invoices in the PDF, PNG, or JPG format to Monite by calling POST /payables/upload_from_file. The maximum file size is 10 MB:

1curl -X POST 'https://api.sandbox.monite.com/v1/payables/upload_from_file' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer ACCESS_TOKEN' \
5 -H 'Content-Type: multipart/form-data' \
6 -F 'file=@pdf-invoice.pdf;type=application/pdf'

In return, you receive back the 201 Created response with id and other parameters:

1{
2 "partner_metadata": {},
3 "id": "61257ac9-ef71-4977-9e40-c9e027c7d539",
4 "entity_id": "9d2b4c8f-2087-4738-ba91-7359683c49a4",
5 "marked_as_paid_with_comment": null,
6 "marked_as_paid_by_entity_user_id": null,
7 "amount_due": 9900,
8 "amount_paid": 0,
9 "amount_to_pay": 9900,
10 "status": "draft",
11 "source_of_payable_data": "ocr",
12 "currency": "EUR",
13 "total_amount": 0,
14 "description": null,
15 "due_date": null,
16 "payment_terms": null,
17 "suggested_payment_term": null,
18 "issued_at": null,
19 "counterpart_bank_account_id": "ee415e8a-4368-4ef8-b192-d25b8e86ad0f",
20 "counterpart_address_id": "d0f2899d-e2b1-4b95-8411-2ed1a9063bce",
21 "counterpart_vat_id_id": "c0d3ca66-bdfa-4cdb-aceb-633d4dfe4f11",
22 "counterpart_bank_id": null,
23 "counterpart_id": null,
24 "counterpart_account_id": null,
25 "counterpart_name": null,
26 "counterpart_tax_id": null,
27 "counterpart_address": null,
28 "payable_origin": "upload",
29 "was_created_by_user_id": null,
30 "currency_exchange": null,
31 "file": {
32 "id": "eac016c4-e06e-4cea-8ebf-3ec72dc8b49d",
33 "created_at": "2023-03-20T18:24:24.808836+00:00",
34 "file_type": "payables",
35 "name": "8d545f97-bcb3-4dfc-8ccf-1aa62d887781",
36 "region": "eu-central-1",
37 "md5": "89746feb534f35364e6760e2d834fe19",
38 "mimetype": "application/pdf",
39 "url": "https://monite-file-saver-payables-eu-central-1-dev.s3.amazonaws.com/2d14935e.../669bab57c57f.pdf",
40 "size": 18095,
41 "previews": [],
42 "pages": []
43 },
44 "tags": null,
45 "created_at": "2023-03-22T08:09:06.650657+00:00",
46 "updated_at": "2023-03-22T08:09:06.650669+00:00",
47 "other_extracted_data": {
48 "total": 9900,
49 "currency": "EUR",
50 "line_items": [
51 {
52 "unit": "item",
53 "quantity": 1.22,
54 "unit_price": 1200,
55 "description": "Services , Products & Goods",
56 "total_excl_vat": 1200,
57 "vat_percentage": 2000,
58 "line_item_ocr_id": "65379361795af74184f49608_3_c2e0d25bcef3edc8037218a553abcff2"
59 }
60 ],
61 "document_id": "FA - 000001",
62 "tax_payer_id": null,
63 "payment_terms": null,
64 "counterpart_name": "Mindspace Germany GmbH",
65 "document_due_date": "2022-01-22",
66 "counterpart_address": null,
67 "counterpart_account_id": null,
68 "document_issued_at_date": "2022-01-04",
69 "counterpart_address_object": {
70 "city": "Berlin",
71 "line1": "Witter . 30 , Haus F",
72 "line2": null,
73 "state": null,
74 "country": null,
75 "postal_code": "13509",
76 "original_country_name": null
77 }
78 },
79 "approval_policy_id": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
80 "document_id": null,
81 "subtotal": 0,
82 "tax": null,
83 "tax_amount": null,
84 "sender": null,
85 "ocr_request_id": "d31562e6-8e7d-4dbd-ba53-a8a62b6c2a62",
86 "ocr_status": "success"
87}

You will also receive a webhook indicating that this payable resource has been created:

1{
2 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0",
3 "created_at": "2024-03-04T20:06:48.593225+00:00",
4 "action": "payable.created_from_file_upload",
5 "api_version": "2024-01-31",
6 "entity_id": "en-your0000-enti-ty00-1D3799b65bcf",
7 "description": "Action has been performed on the invoice: created_from_file_upload.",
8 "object": {
9 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0"
10 },
11 "object_type": "payable",
12 "webhook_subscription_id": "c7f37127-44e5-494a-833a-21e60585f187"
13}

Note that at this stage the payable resource is incomplete and waiting for the results of the OCR service, which automatically scans the details from the uploaded invoice and maps the information from the invoice to the corresponding data field in the system.

When the OCR scanning is finished (this might take up to 5-7 minutes), you will receive the payable.ocr_finished webhook event:

1{
2 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0",
3 "created_at": "2024-03-04T20:09:32.593225+00:00",
4 "action": "payable.ocr_finished",
5 "api_version": "2024-01-31",
6 "entity_id": "en-your0000-enti-ty00-1D3799b65bcf",
7 "description": "Action has been performed on the invoice: ocr_finished.",
8 "object": {
9 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0"
10 },
11 "object_type": "payable",
12 "webhook_subscription_id": "c7f37127-44e5-494a-833a-21e60585f187"
13}

Now, you can call GET /payables/{payable_id} to retrieve the results of the OCR scanning:

1{
2 "partner_metadata": {},
3 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0",
4 "entity_id": "en-your0000-enti-ty00-1D3799b65bcf",
5 "marked_as_paid_with_comment": null,
6 "marked_as_paid_by_entity_user_id": null,
7 "amount_due": 9900,
8 "amount_paid": 0,
9 "amount_to_pay": 9900,
10 "status": "new",
11 "source_of_payable_data": "ocr",
12 "currency": "EUR",
13 "total_amount": 9900,
14 "description": "",
15 "due_date": "2023-07-15",
16 "payment_terms": {
17 "name": "2/10, 1/20, net 30",
18 "term_1": {
19 "number_of_days": 10,
20 "discount": 200
21 },
22 "term_2": {
23 "number_of_days": 20,
24 "discount": 100
25 },
26 "term_final": {
27 "number_of_days": 30
28 }
29 },
30 "suggested_payment_term": {
31 "date": "2023-07-25",
32 "discount": 200
33 },
34 "issued_at": "2023-06-15",
35 "counterpart_bank_account_id": "ee415e8a-4368-4ef8-b192-d25b8e86ad0f",
36 "counterpart_address_id": "d0f2899d-e2b1-4b95-8411-2ed1a9063bce",
37 "counterpart_vat_id_id": "c0d3ca66-bdfa-4cdb-aceb-633d4dfe4f11",
38 "counterpart_bank_id": "DEUTDE2HXXX",
39 "counterpart_id": "8737964a-5246-47f4-8243-8728a2be1e75",
40 "counterpart_account_id": "123456789012",
41 "counterpart_name": "Acme Inc.",
42 "counterpart_address": {
43 "country": "DE",
44 "city": "Berlin",
45 "postal_code": "10115",
46 "state": "BE",
47 "line1": "Flughafenstrasse 52",
48 "line2": "Floor 2"
49 },
50 "payable_origin": "upload",
51 "was_created_by_user_id": "e4e422fc-6956-4fdd-b091-920329f8b92e",
52 "currency_exchange": null,
53 "file": {
54 "id": "2d14935e-505b-4863-a082-b6a340acabbc",
55 "created_at": "2022-04-05T06:31:31.431Z",
56 "file_type": "payables",
57 "name": "invoice-example.pdf",
58 "region": "eu-central-1",
59 "md5": "623470039566983ed5e5945f769ea873",
60 "mimetype": "application/pdf",
61 "url": "https://monite-file-saver-payables-eu-central-1-dev.s3.amazonaws.com/2d14935e.../669bab57c57f.pdf",
62 "size": 49463,
63 "previews": [],
64 "pages": [
65 {
66 "id": "ad712600-bab8-4e0d-9da7-5d561484f1b1",
67 "mimetype": "image/png",
68 "size": 219712,
69 "number": 0,
70 "url": "https://monite-payables.com/1a95c387.../ac02c56d2a3d.png"
71 }
72 ]
73 },
74 "tags": [],
75 "created_at": "2022-04-05T06:31:31.431Z",
76 "updated_at": "2022-04-05T06:31:31.431Z",
77 "ocr_request_id": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
78 "ocr_status": "success",
79 "other_extracted_data": {
80 "total": 52649,
81 "currency": "EUR",
82 "line_items": [
83 {
84 "unit": "items",
85 "quantity": 0.25,
86 "unit_price": 38500,
87 "description": "Open Space - monthly rent",
88 "total_excl_vat": 9625,
89 "vat_percentage": 1900,
90 "line_item_ocr_id": "65391e037952904f8af4dbb2_0_cb9bdddf14bd17bf789a24f9d99a94bf"
91 },
92 {
93 "unit": "m",
94 "quantity": 1.0,
95 "unit_price": 38500,
96 "description": "Open Space - extra requests",
97 "total_excl_vat": 38500,
98 "vat_percentage": 700,
99 "line_item_ocr_id": "65391e037952904f8af4dbb2_1_3332ec854a09518fccd73598795147e7"
100 }
101 ],
102 "document_id": "202008476",
103 "tax_payer_id": "DE 302071443",
104 "payment_terms": null,
105 "counterpart_name": "Mindspace Germany GmbH",
106 "document_due_date": "2021-02-01",
107 "counterpart_address": null,
108 "counterpart_account_id": "DE 57550104000595963377",
109 "document_issued_at_date": "2021-02-01",
110 "counterpart_address_object": {
111 "city": "Berlin",
112 "line1": "Wittestr . 30 , Haus F",
113 "line2": null,
114 "state": null,
115 "country": null,
116 "postal_code": "13509",
117 "original_country_name": null
118 }
119 },
120 "approval_policy_id": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
121 "document_id": "DE2287",
122 "subtotal": 9000,
123 "tax": 1000,
124 "tax_amount": 250,
125 "sender": "hello@example.com"
126}

The other_extracted_data field in the response contains individual text labels and values extracted by OCR.

You can use this data to review and double-check the recognized text, but keep in mind that the structure of this object can change or even be null depending on the OCR results and various types of invoices:

1"other_extracted_data": {
2 "total": 52649,
3 "currency": "EUR",
4 "line_items": [
5 {
6 "unit": "items",
7 "quantity": 0.25,
8 "unit_price": 38500,
9 "description": "Open Space - monthly rent",
10 "total_excl_vat": 9625,
11 "vat_percentage": 1900,
12 "line_item_ocr_id": "65391e037952904f8af4dbb2_0_cb9bdddf14bd17bf789a24f9d99a94bf"
13 },
14 {
15 "unit": "m",
16 "quantity": 1.0,
17 "unit_price": 38500,
18 "description": "Open Space - extra requests",
19 "total_excl_vat": 38500,
20 "vat_percentage": 700,
21 "line_item_ocr_id": "65391e037952904f8af4dbb2_1_3332ec854a09518fccd73598795147e7"
22 }
23 ],
24 "document_id": "202008476",
25 "tax_payer_id": "DE 302071443",
26 "payment_terms": null,
27 "counterpart_name": "Mindspace Germany GmbH",
28 "document_due_date": "2021-02-01",
29 "counterpart_address": null,
30 "counterpart_account_id": "DE 57550104000595963377",
31 "document_issued_at_date": "2021-02-01",
32 "counterpart_address_object": {
33 "city": "Berlin",
34 "line1": "Wittestr . 30 , Haus F",
35 "line2": null,
36 "state": null,
37 "country": null,
38 "postal_code": "13509",
39 "original_country_name": null
40 }
41}

Some comments about the line_items field:

  • unit: This can be any string that describes the units involved. It can be “m”, “h”, “items”, or anything else. It does not affect any numerical values.
  • quantity: The number of items in float format, for example, 0.25 or 10.0. The quantity is used to calculate the total amount and subtotal of the line item and the overall payable.
  • unit_price: The price per unit expressed in minor unit of currency. This value influences the total amount and subtotal of the line item and the overall invoice.
  • description: The description of the line item.
  • total_excl_vat: The total amount before taxes that equals to quantity * unit_price. It is also measured in minor units and its value is used to calculate the total amount of the line item and the overall invoice.
  • vat_percentage: The taxes as a percentage, expressed in minor units, for example, 1900 represents 19%. This value influences the total amount of the line item and the overall invoice ( = subtotal + applying taxes).

Send payables by email

Each entity has a dedicated mailbox in Monite to which the payables can be sent. The entity or entity user can send invoices as attachments in PDF, PNG, or JPEG format to this mailbox (the maximum file size is 10 MB).

The Monite OCR service scans the information inside each email’s attachments. Then, Monite automatically creates a draft payable invoice for each occurrence found. The email of the sender of these files is saved in the field sender of the invoice.

To find the mailbox assigned to a specific entity, call GET /v1/mailboxes:

1curl -X GET 'https://api.sandbox.monite.com/v1/mailboxes' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer YOUR_PARTNER_TOKEN'

The successful response contains information about the mailbox:

1[
2 {
3 "id": "e8c884f8-bed3-4d92-afc9-3538c5079014",
4 "entity_id": "68fdd6b5-b60c-4f4d-8642-1cd7f2fa31e8",
5 "status": "active",
6 "related_object_type": "payable",
7 "mailbox_name": "1102737648192968373_payables",
8 "mailbox_full_address": "1102737648192968373_payables@mg.sandbox.monite.com",
9 "belongs_to_mailbox_domain_id": null
10 }
11]

By default, the automatically created mailboxes belong to the Monite domain (the web address that comes after @ in an email address), but the partners can set up their own email domain for better convenience.

Automatic matching of purchase orders with payables

Every time a payable is created or updated, Monite automatically tries to link this payable to its corresponding purchase order, which is already created in the system. The conditions for the purchase order autolinking to be performed are:

  • The counterpart name on the payable must match, with a certain tolerance, the counterpart name on the purchase order.
  • The line items` name and price on the payable must match those on the purchase order.
  • The total amount of the payable or unit price for the line items on the payable must match those on the purchase order.

Once the corresponding purchase order is found, its ID is added to the payable.purchase_order_id field. If more than one applicable purchase order is found, the most recently created is selected.

The automatic matching is enabled by default. To disable this behavior, call PATCH /entities/{entity_id}/settings, passing the field allow_purchase_order_autolinking as false in the body.

The payable can also be manually matched by calling PATCH /payables/{payable_id}, passing the purchase_order_id in the body.

Tolerance match

The matching is performed considering these tolerance rules:

  • Minor variations in the counterparts` names are accepted (e.g., “Ltd” vs. “Limited”).
  • The billed quantity may vary slightly within a small allowable range.
  • The total amount of the payable or the unit price on the payable may exceed the agreed-upon price by 5%.

Payables that do not meet the exact or tolerance match criteria require a manual review. This process includes:

  • Checking for typos or data entry errors.
  • Verifying explanations for discrepancies (e.g., price changes, shipping fees).

Get payables analytics

You can obtain aggregated statistics for the total number and sum total amount of all existing payables, along with the breakdown per payable status. To do this, send a GET request to the /payables/analytics endpoint.

The results can be filtered by a specific time period, counterpart, or other search filters. For the full list of available sort and filter parameters, see the GET /payables/analytics endpoint.

For example, to get statistics about all payables in the approve_in_progress and waiting_to_be_paid statuses, call GET /payables/analytics?status**in=approve_in_progress&status**in=waiting_to_be_paid:

1curl -X GET 'https://api.sandbox.monite.com/v1/payables/analytics?status__in=approve_in_progress&status__in=waiting_to_be_paid&id__in=' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer ACCESS_TOKEN'

The successful response contains the total number and sum total amount of all existing payables:

1{
2 "count": 35,
3 "data": [
4 {
5 "count": 22,
6 "status": "approve_in_progress",
7 "sum_total_amount": 12566
8 },
9 {
10 "count": 13,
11 "status": "waiting_to_be_paid",
12 "sum_total_amount": 22688
13 }
14 ],
15 "sum_total_amount": 35254
16}

Some other examples of statistics:

  • GET /payables/analytics?created_at**gt=2023-10-01T14%3A48%3A00Z&created_at**lt=2023-10-31T14%3A48%3A00Z - Get statistics about all payables for a specific period.
  • GET /payables/analytics?counterpart_name=Acme%20Inc. - Get statistics about all payables for a specific counterpart.

List all payables

It is possible to view all the payables in the Monite space. To allow the right level of access to the authorized users, Monite allows certain entity users to view them but not change uploads.

To list all payables, call GET /payables. You can sort and filter the results by the amount, status, and other fields. For the full list of available sort and filter parameters, see the GET /payables endpoint.

Some examples:

  • GET /payables?counterpart_name=Acme%20Inc. - get all payables issued to Acme Inc.
  • GET /payables?amount__gte=15000 - get all payables where the total amount is 150$ or more.
  • GET /payables?status__in=draft&status__in=new - get all draft and new payables.
  • GET /payables?created_at__gte=2022-01-01T00%3A00%3A00 - get all payables created on or after January 1, 2022.
  • GET /payables?&ocr_status=error - get all payables that have failed to be recognized by the OCR.

Sample request to fetch 100 payables:

1curl -X GET 'https://api.sandbox.monite.com/v1/payables?order=asc&limit=100' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer ACCESS_TOKEN'

The successful response returns a paged series of all payables that the entity has access to. For example:

1{
2 "data": [
3 {
4 "partner_metadata": {},
5 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0",
6 "entity_id": "b0ff50d0-cdea-42fd-9461-1b3799b65bcf",
7 "marked_as_paid_with_comment": null,
8 "marked_as_paid_by_entity_user_id": null,
9 "status": "new",
10 "source_of_payable_data": "ocr",
11 "currency": "EUR",
12 "total_amount": 9900,
13 "description": null,
14 "due_date": "2022-06-30",
15 ...,
16 }
17 ],
18 "prev_pagination_token": null,
19 "next_pagination_token": "bGltaXQ9MiZmaXJzdF9vaWQ9MSZuZXh0X3Rva2VuPTQ="
20}

The prev_pagination_token and next_pagination_token fields in the response are pagination tokens.

Retrieve a payable

Once a payable is uploaded, the entity and entity users can review the information extracted from the payable by the OCR system.

To retrieve a payable, call GET /payables/{payable_id}:

1curl -X GET 'https://api.sandbox.monite.com/v1/payables/{payable_id}' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer ACCESS_TOKEN'

The successful response contains the payable attributes:

1{
2 "partner_metadata": {},
3 "id": "aa314fdd-a763-4920-a8c8-6285fc1745c0",
4 "entity_id": "b0ff50d0-cdea-42fd-9461-1b3799b65bcf",
5 "marked_as_paid_with_comment": null,
6 "marked_as_paid_by_entity_user_id": null,
7 "amount_due": 9900,
8 "amount_paid": 0,
9 "amount_to_pay": 9900,
10 "status": "new",
11 "total_amount": 9900,
12 "source_of_payable_data": "ocr",
13 "currency": "EUR",
14 "description": null,
15 "due_date": "2023-07-15",
16 "payment_terms": {
17 "name": "2/10, 1/20, net 30",
18 "term_1": {
19 "number_of_days": 10,
20 "discount": 200
21 },
22 "term_2": {
23 "number_of_days": 20,
24 "discount": 100
25 },
26 "term_final": {
27 "number_of_days": 30
28 }
29 },
30 "suggested_payment_term": {
31 "date": "2023-07-25",
32 "discount": 200
33 },
34 "issued_at": "2023-06-15",
35 "counterpart_bank_id": "DEUTDE2HXXX",
36 "counterpart_id": "8737964a-5246-47f4-8243-8728a2be1e75",
37 "counterpart_bank_account_id": "ee415e8a-4368-4ef8-b192-d25b8e86ad0f",
38 "counterpart_address_id": "d0f2899d-e2b1-4b95-8411-2ed1a9063bce",
39 "counterpart_vat_id_id": "c0d3ca66-bdfa-4cdb-aceb-633d4dfe4f11",
40 "counterpart_account_id": "123456789012",
41 "counterpart_name": "Acme Inc.",
42 "counterpart_address": {
43 "country": "DE",
44 "city": "Berlin",
45 "postal_code": "10115",
46 "state": "BE",
47 "line1": "Flughafenstrasse 52",
48 "line2": "Floor 2"
49 },
50 "payable_origin": "upload",
51 "was_created_by_user_id": "e4e422fc-6956-4fdd-b091-920329f8b92e",
52 "currency_exchange": {
53 "default_currency_code": "EUR",
54 "rate": 10.0,
55 "total": 0
56 },
57 "file": {
58 "id": "2d14935e-505b-4863-a082-b6a340acabbc",
59 "created_at": "2021-11-25T05:10:35.211432+00:00",
60 "file_type": "payables",
61 "name": "file name",
62 "region": "eu-central-1",
63 "md5": "623470039566983ed5e5945f769ea873",
64 "mimetype": "image/png",
65 "url": "https://monite-payables.com/2d14935e.../669bab57c57f.png",
66 "size": 49463,
67 "previews": [],
68 "pages": []
69 },
70 "tags": [
71 {
72 "name": "Marketing",
73 "id": "ea837e28-509b-4b6a-a600-d54b6aa0b1f5",
74 "created_at": "2022-09-07T16:35:18.484507+00:00",
75 "updated_at": "2022-09-07T16:35:18.484507+00:00",
76 "created_by_entity_user_id": "ea837e28-509b-4b6a-a600-d54b6aa0b1f5"
77 }
78 ],
79 "created_at": "2021-11-25T05:10:35.211432+00:00",
80 "updated_at": "2021-11-25T05:10:35.211447+00:00",
81 "ocr_request_id": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
82 "ocr_status": "success",
83 "other_extracted_data": {
84 "total": 52649,
85 "currency": "EUR",
86 "line_items": [
87 {
88 "unit": "items",
89 "quantity": 0.25,
90 "unit_price": 38500,
91 "description": "Open Space - monthly rent",
92 "total_excl_vat": 9625,
93 "vat_percentage": 1900,
94 "line_item_ocr_id": "65391e037952904f8af4dbb2_0_cb9bdddf14bd17bf789a24f9d99a94bf"
95 },
96 {
97 "unit": "m",
98 "quantity": 1.0,
99 "unit_price": 38500,
100 "description": "Open Space - extra requests",
101 "total_excl_vat": 38500,
102 "vat_percentage": 700,
103 "line_item_ocr_id": "65391e037952904f8af4dbb2_1_3332ec854a09518fccd73598795147e7"
104 }
105 ],
106 "document_id": "202008476",
107 "tax_payer_id": "DE 302071443",
108 "payment_terms": null,
109 "counterpart_name": "Mindspace Germany GmbH",
110 "document_due_date": "2021-02-01",
111 "counterpart_address": null,
112 "counterpart_account_id": "DE 57550104000595963377",
113 "document_issued_at_date": "2021-02-01",
114 "counterpart_address_object": {
115 "city": "Berlin",
116 "line1": "Wittestr . 30 , Haus F",
117 "line2": null,
118 "state": null,
119 "country": null,
120 "postal_code": "13509",
121 "original_country_name": null
122 }
123 },
124 "approval_policy_id": "3fa85f64-5717-4562-b3fc-2c963f66afa6",
125 "document_id": "DE2287",
126 "subtotal": 9000,
127 "tax": 1000,
128 "sender": "hello@example.com"
129}

Update a payable

Payables in the draft and new statuses can be updated, for example, to provide additional details or fix the information extracted by OCR. To update a payable, send a PATCH request to the /payables/{payable_id} endpoint with the request body containing the new field values. For example, to update the description field:

1curl -X PATCH 'https://api.sandbox.monite.com/v1/payables/{payable_id}' \
2 -H 'X-Monite-Version: 2024-01-31' \
3 -H 'X-Monite-Entity-Id: ENTITY_ID' \
4 -H 'Authorization: Bearer ACCESS_TOKEN' \
5 -H 'Content-Type: application/json' \
6 -d '{
7 "description": "New description of the payable"
8 }'