Documents: General documents

List ids and versions of general 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/general_documents/synchronization.json?
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890319082358424",
    "version": 1734685795
  },
  {
    "id": "440890319110669978",
    "version": 1734685795
  },
  {
    "id": "440890319121155740",
    "version": 1734685795
  }
]
      

Example: retrieves all ids for synchronization using a filter

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XGET \
  https://moneybird.com/api/v2/123/documents/general_documents/synchronization.json?filter=period%3Athis_month
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890319266907814",
    "version": 1734685795
  },
  {
    "id": "440890319275296424",
    "version": 1734685795
  },
  {
    "id": "440890319283685034",
    "version": 1734685795
  }
]
      

Fetch general 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":[440890319456700086,440890319469283000]}' \
  https://moneybird.com/api/v2/123/documents/general_documents/synchronization.json
    

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890319469283000",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "Contract",
    "date": "2024-12-20",
    "due_date": null,
    "entry_number": 4,
    "state": "saved",
    "exchange_rate": "1.0",
    "created_at": "2024-12-20T09:09:55.751Z",
    "updated_at": "2024-12-20T09:09:55.751Z",
    "version": 1734685795,
    "notes": [],
    "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:09:55.754Z",
        "updated_at": "2024-12-20T09:09:55.754Z"
      }
    ]
  },
  {
    "id": "440890319456700086",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "Contract",
    "date": "2024-12-20",
    "due_date": null,
    "entry_number": 3,
    "state": "saved",
    "exchange_rate": "1.0",
    "created_at": "2024-12-20T09:09:55.738Z",
    "updated_at": "2024-12-20T09:09:55.738Z",
    "version": 1734685795,
    "notes": [],
    "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:09:55.741Z",
        "updated_at": "2024-12-20T09:09:55.741Z"
      }
    ]
  }
]
      

Get general 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 general_documents

Request

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

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890314155099630",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "Contract",
    "date": "2024-12-20",
    "due_date": null,
    "entry_number": 5,
    "state": "saved",
    "exchange_rate": "1.0",
    "created_at": "2024-12-20T09:09:50.682Z",
    "updated_at": "2024-12-20T09:09:50.682Z",
    "version": 1734685790,
    "notes": [],
    "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:09:50.685Z",
        "updated_at": "2024-12-20T09:09:50.685Z"
      }
    ]
  },
  {
    "id": "440890314145662444",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "Contract",
    "date": "2024-12-20",
    "due_date": null,
    "entry_number": 4,
    "state": "saved",
    "exchange_rate": "1.0",
    "created_at": "2024-12-20T09:09:50.673Z",
    "updated_at": "2024-12-20T09:09:50.673Z",
    "version": 1734685790,
    "notes": [],
    "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:09:50.676Z",
        "updated_at": "2024-12-20T09:09:50.676Z"
      }
    ]
  },
  {
    "id": "440890314136225258",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "Contract",
    "date": "2024-12-20",
    "due_date": null,
    "entry_number": 3,
    "state": "saved",
    "exchange_rate": "1.0",
    "created_at": "2024-12-20T09:09:50.665Z",
    "updated_at": "2024-12-20T09:09:50.665Z",
    "version": 1734685790,
    "notes": [],
    "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:09:50.667Z",
        "updated_at": "2024-12-20T09:09:50.667Z"
      }
    ]
  }
]
      

Example: returns paginated general documents on page 1

Request

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

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890314355377662",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "Contract",
    "date": "2024-12-20",
    "due_date": null,
    "entry_number": 5,
    "state": "saved",
    "exchange_rate": "1.0",
    "created_at": "2024-12-20T09:09:50.873Z",
    "updated_at": "2024-12-20T09:09:50.873Z",
    "version": 1734685790,
    "notes": [],
    "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:09:50.876Z",
        "updated_at": "2024-12-20T09:09:50.876Z"
      }
    ]
  }
]
      

Example: returns paginated general documents on page 2

Request

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

Response

        
          
          Status: 200 OK
        
      
[
  {
    "id": "440890314546218508",
    "administration_id": 123,
    "contact_id": null,
    "contact": null,
    "reference": "Contract",
    "date": "2024-12-20",
    "due_date": null,
    "entry_number": 4,
    "state": "saved",
    "exchange_rate": "1.0",
    "created_at": "2024-12-20T09:09:51.055Z",
    "updated_at": "2024-12-20T09:09:51.055Z",
    "version": 1734685791,
    "notes": [],
    "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:09:51.058Z",
        "updated_at": "2024-12-20T09:09:51.058Z"
      }
    ]
  }
]
      

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

Request

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

Response

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

Get general documents

Example: returns the wanted general_document

Request

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

Response

        
          
          Status: 200 OK
        
      
{
  "id": "440890314906928680",
  "administration_id": 123,
  "contact_id": null,
  "contact": null,
  "reference": "Contract",
  "date": "2024-12-20",
  "due_date": null,
  "entry_number": 2,
  "state": "saved",
  "exchange_rate": "1.0",
  "created_at": "2024-12-20T09:09:51.400Z",
  "updated_at": "2024-12-20T09:09:51.400Z",
  "version": 1734685791,
  "notes": [],
  "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:09:51.403Z",
      "updated_at": "2024-12-20T09:09:51.403Z"
    }
  ]
}
      

Example: only returns general_documents

Request

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

Response

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

Create a new general documents

Parameters

Parameter Type Description
general_document[reference] String

Required.

general_document[date] String

Required

Required.

general_document[due_date] String
general_document[reminder_date] String
general_document[contact_id] Integer

Should be a valid contact id.

general_document[reminder][date] String

Required

general_document[reminder][message] String

Example: creates the general_document

Request

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

Response

        
          
          Status: 201 Created
        
      
{
  "id": "440890315659806297",
  "administration_id": 123,
  "contact_id": "440890315530831441",
  "contact": {
    "id": "440890315530831441",
    "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:09:51.992Z",
    "updated_at": "2024-12-20T09:09:51.992Z",
    "version": 1734685791,
    "sales_invoices_url": "https://moneybird.dev/123/sales_invoices/ed1c58b2f40592e191a514c50ab793d8f4ff0ac0a1fd755de7fc9b3c14fa2736/all",
    "notes": [],
    "custom_fields": [],
    "contact_people": [],
    "archived": false
  },
  "reference": "foobar",
  "date": "2024-12-20",
  "due_date": null,
  "entry_number": 3,
  "state": "saved",
  "exchange_rate": "1.0",
  "created_at": "2024-12-20T09:09:52.118Z",
  "updated_at": "2024-12-20T09:09:52.118Z",
  "version": 1734685792,
  "notes": [],
  "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:09:52.120Z",
      "updated_at": "2024-12-20T09:09:52.120Z"
    }
  ]
}
      

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/general_documents.json
    

Response

        
          
          Status: 400 Bad Request
        
      
{
  "error": "General Document is required",
  "symbolic": {
    "general_document": "required"
  }
}
      

Delete a general documents

Parameters

Parameter Type Description
refresh_journal_entries Boolean

Example: deletes the general_document

Request

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

Response

Update a general documents

Parameters

Parameter Type Description
general_document[reference] String

Required.

general_document[date] String

Required

Required.

general_document[due_date] String
general_document[reminder_date] String
general_document[contact_id] Integer

Should be a valid contact id.

general_document[reminder][date] String

Required

general_document[reminder][message] String
remove_contact Boolean

Example: updates the general_document

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XPATCH \
  -d '{"general_document":{"reference":"updated reference"}}' \
  https://moneybird.com/api/v2/123/documents/general_documents/440890315940824685.json
    

Response

        
          
          Status: 200 OK
        
      
{
  "id": "440890315940824685",
  "administration_id": 123,
  "contact_id": null,
  "contact": null,
  "reference": "updated reference",
  "date": "2024-12-20",
  "due_date": null,
  "entry_number": 2,
  "state": "saved",
  "exchange_rate": "1.0",
  "created_at": "2024-12-20T09:09:52.386Z",
  "updated_at": "2024-12-20T09:09:52.458Z",
  "version": 1734685792,
  "notes": [],
  "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:09:52.389Z",
      "updated_at": "2024-12-20T09:09:52.389Z"
    },
    {
      "administration_id": 123,
      "user_id": 17346857489026,
      "action": "document_updated",
      "link_entity_id": null,
      "link_entity_type": null,
      "data": {},
      "created_at": "2024-12-20T09:09:52.461Z",
      "updated_at": "2024-12-20T09:09:52.461Z"
    }
  ]
}
      

Add attachment to general 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/general_documents/440890316551095949/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/general_documents/440890319631812290/attachments/440890319772321476.json
    

Response

Adds note to entity

Parameters

Parameter Type Description
note[note] String

Required. Text for the note or to-do.

note[todo] Boolean

If true the note is a to-do.

note[assignee_id] Integer

Assign to-do to user. Should be a valid user id. If assignee_id is provided the note will be a to-do.

Example: create a note

Request

curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
  -XPOST \
  -d '{"note":{"note":"Text of the note","assignee_id":440890315243521598,"todo":true}}' \
  https://moneybird.com/api/v2/123/documents/general_documents/440890315234084412/notes.json
    

Response

        
          
          Status: 201 Created
        
      
{
  "id": "440890315305387584",
  "administration_id": 123,
  "entity_id": "440890315234084412",
  "entity_type": "Document",
  "user_id": 17346857489026,
  "assignee_id": "440890315243521598",
  "todo": true,
  "note": "Text of the note",
  "completed_at": null,
  "completed_by_id": null,
  "todo_type": null,
  "data": {},
  "created_at": "2024-12-20T09:09:51.779Z",
  "updated_at": "2024-12-20T09:09:51.779Z"
}
      

Destroys note from entity

Example: destroy a note

Request

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

Response