Documents: Typeless documents

Typeless documents are documents of which the type is not yet known. For example, a document uploaded via email or via the bulk uploader. It is not possible to update a typeless document, except for adding attachments. You will need to set its type first. You cannot set the type of typeless documents using the API yet, but you can do it via the website.

List ids and versions of typeless documents

Returns all documents in the administration. The list contains the document id and the version of the document. Check if the version of the document is newer than the version you have stored locally, use the POST variant for fetching documents with the given ids.

Parameters

Parameter Type Description
filter String

String terms, example: key1:value1,key2:value2.

Example: retrieves all ids for synchronization

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/typeless_documents/synchronization.json?
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890345413149729",
    "version": 1734685820
  },
  {
    "id": "440890345423635491",
    "version": 1734685820
  },
  {
    "id": "440890345433072677",
    "version": 1734685820
  }
]
      

Fetch typeless documents with given ids

Given a list of document ids, returns the document information belonging to the documents. Returns a maximum of 100 documents, even if more ids are provided.

Parameters

Parameter Type Description
ids Array[integer]

Required

Example: retrieves documents for given ids

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XPOST \
  -d '{"ids":[440890345584067633,440890345593504819]}' \
  https://moneybird.com/api/v2/123/documents/typeless_documents/synchronization.json
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890345584067633",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "20130456",
    "date": "2024-12-20",
    "state": "new",
    "origin": null,
    "created_at": "2024-12-20T09:10:20.656Z",
    "updated_at": "2024-12-20T09:10:20.656Z",
    "version": 1734685820,
    "attachments": [],
    "events": [
      {
        "administration_id": 123,
        "user_id": 17346857489026,
        "action": "document_saved",
        "link_entity_id": null,
        "link_entity_type": null,
        "data": {},
        "created_at": "2024-12-20T09:10:20.658Z",
        "updated_at": "2024-12-20T09:10:20.658Z"
      }
    ]
  },
  {
    "id": "440890345593504819",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "20130456",
    "date": "2024-12-20",
    "state": "new",
    "origin": null,
    "created_at": "2024-12-20T09:10:20.664Z",
    "updated_at": "2024-12-20T09:10:20.664Z",
    "version": 1734685820,
    "attachments": [],
    "events": [
      {
        "administration_id": 123,
        "user_id": 17346857489026,
        "action": "document_saved",
        "link_entity_id": null,
        "link_entity_type": null,
        "data": {},
        "created_at": "2024-12-20T09:10:20.667Z",
        "updated_at": "2024-12-20T09:10:20.667Z"
      }
    ]
  }
]
      

Get typeless documents

Returns a paginated list of documents of this type in the administration.

The filter argument allows you to filter on the list of documents. Filters are a combination of keys and values, separated by a comma: key:value,key2:value2. The most common filter method will be period: period:this_month. Filtering works the same as in the web application, for more advanced examples, change the filtering in the web application and learn from the resulting URI.

Parameters

Parameter Type Description
filter String

Required

String terms, example: key1:value1,key2:value2.

new_filter String

String terms, example: key1:value1,key2:value2.

page Integer
per_page Integer
exclude_new_general_journal_documents Boolean

Example: returns a list of typeless_documents

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/typeless_documents.json?
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890342063998887",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "20130456",
    "date": "2024-12-20",
    "state": "new",
    "origin": null,
    "created_at": "2024-12-20T09:10:17.298Z",
    "updated_at": "2024-12-20T09:10:17.298Z",
    "version": 1734685817,
    "attachments": [],
    "events": [
      {
        "administration_id": 123,
        "user_id": 17346857489026,
        "action": "document_saved",
        "link_entity_id": null,
        "link_entity_type": null,
        "data": {},
        "created_at": "2024-12-20T09:10:17.302Z",
        "updated_at": "2024-12-20T09:10:17.302Z"
      }
    ]
  },
  {
    "id": "440890342051415973",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "20130456",
    "date": "2024-12-20",
    "state": "new",
    "origin": null,
    "created_at": "2024-12-20T09:10:17.287Z",
    "updated_at": "2024-12-20T09:10:17.287Z",
    "version": 1734685817,
    "attachments": [],
    "events": [
      {
        "administration_id": 123,
        "user_id": 17346857489026,
        "action": "document_saved",
        "link_entity_id": null,
        "link_entity_type": null,
        "data": {},
        "created_at": "2024-12-20T09:10:17.290Z",
        "updated_at": "2024-12-20T09:10:17.290Z"
      }
    ]
  },
  {
    "id": "440890342039881635",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "20130456",
    "date": "2024-12-20",
    "state": "new",
    "origin": null,
    "created_at": "2024-12-20T09:10:17.276Z",
    "updated_at": "2024-12-20T09:10:17.276Z",
    "version": 1734685817,
    "attachments": [],
    "events": [
      {
        "administration_id": 123,
        "user_id": 17346857489026,
        "action": "document_saved",
        "link_entity_id": null,
        "link_entity_type": null,
        "data": {},
        "created_at": "2024-12-20T09:10:17.279Z",
        "updated_at": "2024-12-20T09:10:17.279Z"
      }
    ]
  }
]
      

Example: returns paginated typeless documents on page 1

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/typeless_documents.json?per_page=1
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890342292588471",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "20130456",
    "date": "2024-12-20",
    "state": "new",
    "origin": null,
    "created_at": "2024-12-20T09:10:17.516Z",
    "updated_at": "2024-12-20T09:10:17.516Z",
    "version": 1734685817,
    "attachments": [],
    "events": [
      {
        "administration_id": 123,
        "user_id": 17346857489026,
        "action": "document_saved",
        "link_entity_id": null,
        "link_entity_type": null,
        "data": {},
        "created_at": "2024-12-20T09:10:17.520Z",
        "updated_at": "2024-12-20T09:10:17.520Z"
      }
    ]
  }
]
      

Example: returns paginated typeless documents on page 2

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/typeless_documents.json?page=2&per_page=1
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890342511740869",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "20130456",
    "date": "2024-12-20",
    "state": "new",
    "origin": null,
    "created_at": "2024-12-20T09:10:17.726Z",
    "updated_at": "2024-12-20T09:10:17.726Z",
    "version": 1734685817,
    "attachments": [],
    "events": [
      {
        "administration_id": 123,
        "user_id": 17346857489026,
        "action": "document_saved",
        "link_entity_id": null,
        "link_entity_type": null,
        "data": {},
        "created_at": "2024-12-20T09:10:17.729Z",
        "updated_at": "2024-12-20T09:10:17.729Z"
      }
    ]
  }
]
      

Example: returns an error when too many typeless documents are requested

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/typeless_documents.json?per_page=101
    

Response

        
          
          Status: 400 Bad Request
        
      
{
  "error": "Per Page is too big",
  "symbolic": {
    "per_page": "max"
  }
}
      

Get typeless documents

Example: returns the wanted typeless_document

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/typeless_documents/440890342913345505.json?
    

Response

        
          
          Status: 200 OK
        
      
{
  "id": "440890342913345505",
  "administration_id": 123,
  "contact_id": null,
  "contact": null,
  "reference": "20130456",
  "date": "2024-12-20",
  "state": "new",
  "origin": null,
  "created_at": "2024-12-20T09:10:18.108Z",
  "updated_at": "2024-12-20T09:10:18.108Z",
  "version": 1734685818,
  "attachments": [],
  "events": [
    {
      "administration_id": 123,
      "user_id": 17346857489026,
      "action": "document_saved",
      "link_entity_id": null,
      "link_entity_type": null,
      "data": {},
      "created_at": "2024-12-20T09:10:18.111Z",
      "updated_at": "2024-12-20T09:10:18.111Z"
    }
  ]
}
      

Example: only returns typeless_documents

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/typeless_documents/440890343046514664.json?
    

Response

        
          
          Status: 404 Not Found
        
      
{
  "error": "record not found",
  "symbolic": {
    "id": "not_found"
  }
}
      

Create a new typeless documents

Parameters

Parameter Type Description
typeless_document[reference] String

Required

typeless_document[date] String

Required

typeless_document[contact_id] Integer

Should be a valid contact id.

Example: creates the typeless_document

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XPOST \
  -d '{"typeless_document":{"reference":"foobar","contact_id":440890343157663727}}' \
  https://moneybird.com/api/v2/123/documents/typeless_documents.json
    

Response

        
          
          Status: 201 Created
        
      
{
  "id": "440890343295027191",
  "administration_id": 123,
  "contact_id": "440890343157663727",
  "contact": {
    "id": "440890343157663727",
    "administration_id": 123,
    "company_name": "Foobar Holding B.V.",
    "firstname": "",
    "lastname": "",
    "address1": "Hoofdstraat 12",
    "address2": "",
    "zipcode": "1234AB",
    "city": "Amsterdam",
    "country": "NL",
    "phone": "",
    "delivery_method": "Email",
    "customer_id": "1",
    "tax_number": "",
    "chamber_of_commerce": "",
    "bank_account": "",
    "is_trusted": false,
    "max_transfer_amount": null,
    "attention": "",
    "email": "info@example.com",
    "email_ubl": true,
    "send_invoices_to_attention": "",
    "send_invoices_to_email": "info@example.com",
    "send_estimates_to_attention": "",
    "send_estimates_to_email": "info@example.com",
    "sepa_active": false,
    "sepa_iban": "",
    "sepa_iban_account_name": "",
    "sepa_bic": "",
    "sepa_mandate_id": "",
    "sepa_mandate_date": null,
    "sepa_sequence_type": "RCUR",
    "credit_card_number": "",
    "credit_card_reference": "",
    "credit_card_type": null,
    "tax_number_validated_at": null,
    "tax_number_valid": null,
    "invoice_workflow_id": null,
    "estimate_workflow_id": null,
    "si_identifier": "",
    "si_identifier_type": null,
    "moneybird_payments_mandate": false,
    "created_at": "2024-12-20T09:10:18.342Z",
    "updated_at": "2024-12-20T09:10:18.342Z",
    "version": 1734685818,
    "sales_invoices_url": "https://moneybird.dev/123/sales_invoices/860e793151c3e607b018d1a0920af58c49245308467e1df6be394a0519393911/all",
    "notes": [],
    "custom_fields": [],
    "contact_people": [],
    "archived": false
  },
  "reference": "foobar",
  "date": "2024-12-20",
  "state": "new",
  "origin": "api",
  "created_at": "2024-12-20T09:10:18.472Z",
  "updated_at": "2024-12-20T09:10:18.472Z",
  "version": 1734685818,
  "attachments": [],
  "events": [
    {
      "administration_id": 123,
      "user_id": 17346857489026,
      "action": "document_saved",
      "link_entity_id": null,
      "link_entity_type": null,
      "data": {},
      "created_at": "2024-12-20T09:10:18.475Z",
      "updated_at": "2024-12-20T09:10:18.475Z"
    }
  ]
}
      

Example: requires all input

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XPOST \
  -d '{}' \
  https://moneybird.com/api/v2/123/documents/typeless_documents.json
    

Response

        
          
          Status: 400 Bad Request
        
      
{
  "error": "Typeless Document is required",
  "symbolic": {
    "typeless_document": "required"
  }
}
      

Delete a typeless documents

Parameters

Parameter Type Description
refresh_journal_entries Boolean

Example: deletes the typeless_document

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XDELETE \
  -d '{}' \
  https://moneybird.com/api/v2/123/documents/typeless_documents/440890343588627467.json
    

Response

Add attachment to typeless document

Example: uploads an attachment

Request

curl -s -H "Content-Type: multipart/mixed" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XPOST \
  -F file=@/tmp/upload.pdf \
  https://moneybird.com/api/v2/123/documents/typeless_documents/440890343768982550/attachments.json
    

Response

Download attachment

Download the attachment. The response will be a redirect to a temporarily available URL where the attachment can be downloaded. Use the Location header in the response to download the attachment.

Delete an attachment

Deletes an attachment of an attachable.

Example: destroys an attachment

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XDELETE \
  -d '{}' \
  https://moneybird.com/api/v2/123/documents/typeless_documents/440890345763374141/attachments/440890345909126207.json
    

Response