Project Expenses

German: “Projekte / Zusatzleistungen”

Attributes

The representation contains, among the standard fields, also the following fields:

  • Custom properties
  • Company
  • Project
  • Group
{
  "id": 47266,
  "date": "2024-06-07",
  "title": "Hosting XS",
  "description": "<div>Hosting, Monitoring und Backup</div>",
  "quantity": 3,
  "unit": "Monat",
  "unit_price": 29,
  "unit_cost": 19,
  "price": 87,
  "cost": 57,
  "currency": "CHF",
  "budget_relevant": true,
  "billable": true,
  "billed": false,
  "purchase_assignment_locked": true,
  "cost_total_planned": 0,
  "planned_purchase_date": null,
  "invoice_id": null,
  "recurring_expense_id": null,
  "service_period": "06/2024",
  "service_period_from": "2024-06-01",
  "service_period_to": "2024-06-30",
  "file_url": "https//meinefirma.mocoapp.com/.../beleg1.jpg",
  "custom_properties": {
    "Type": "Website"
  },
  "company": {
    "id": 1234,
    "name": "Acme Corp."
  },
  "project": {
    "id": 1234,
    "name": "Project A"
  },
  "group": {
    "id": 456,
    "title": "Exepnse Group A",
    "budget": 5200
  },
  "created_at": "2024-06-06T09:33:46Z",
  "updated_at": "2024-06-06T09:33:46Z"
}

GET /projects/{id}/expenses

Retrieve all additional services for a project:

curl -X GET \
  'https://{domain}.mocoapp.com/api/v1/projects/{id}/expenses' \
  -H 'Authorization: Token token=YOUR_API_KEY'

This returns an array with all additional services (see Attributes).

Additionally, these parameters can be supplied:

  • Global filters apply
  • billable – true/false
  • billed – true/false
  • budget_relevant – true/false
  • user_id - 123456 (user that created expense)

GET /projects/{id}/expenses/{id}

Retrieve a single additional service for a project:

curl -X GET \
  'https://{domain}.mocoapp.com/api/v1/projects/{id}/expenses/{id}' \
  -H 'Authorization: Token token=YOUR_API_KEY'

POST /projects/{id}/expenses

Create an additional service entry on a project:

curl -X POST \
  'https://{domain}.mocoapp.com/api/v1/projects/{id}/expenses' \
  -H 'Authorization: Token token=YOUR_API_KEY' \
  -H 'Content-Type: application/json' \
  -d '{
        "date": "2018-10-01",
        "title": "Hosting XS",
        "quantity": 3,
        "unit": "months",
        "unit_price": 29,
        "unit_cost": 19,
        "file": {
          "filename": "document.pdf",
          "base64": "JVBERi0xLjQKJeLjz9MKNCAwIG9iago8PC9GaWx..."
        }
      }'

Mandatory fields are marked with a star (*):

  • date* – “2017-04-12”
  • title* – “Hosting XS”
  • quantity* – 3
  • unit* – “months”
  • unit_price* – 29
  • unit_cost* – 19
  • description – “Hosting, Monitoring, Backup”
  • billable – true/false (default: true)
  • budget_relevant – true/false (default: false)
  • service_period_from – “2021-01-01”
  • service_period_to – “2021-01-31”
  • user_id - 456 (user responsible, current user by default)
  • custom_properties – {“Type”: “Website”}
  • file – file attached to the expense, with the following fields:
    • filename – “document.pdf”
    • base64 – base64 encoded content of the file

POST /projects/{id}/expenses/bulk

Create multiple additional services entries:

curl -X POST \
  'https://{domain}.mocoapp.com/api/v1/projects/{id}/expenses/bulk' \
  -H 'Authorization: Token token=YOUR_API_KEY' \
  -H 'Content-Type: application/json' \
  -d '{
        "bulk_data": [
          {
            "date": "2018-10-20",
            "title": "Hosting: Server",
            "quantity": 1,
            "unit": "Server",
            "unit_price": 29,
            "unit_cost": 19
          },
          {
            "date": "2018-10-22",
            "title": "Hosting: Server",
            "quantity": 1,
            "unit": "Server",
            "unit_price": 29,
            "unit_cost": 19
          }
        ]
      }'

Mandatory fields are marked with a star (*):

  • date* – “2017-04-12”
  • title* – “Hosting XS”
  • quantity* – 3
  • unit* – “months”
  • unit_price* – 29
  • unit_cost* – 19
  • description – “Hosting, Monitoring, Backup”
  • billable – true/false (default: true)
  • budget_relevant – true/false (default: false)

PUT /projects/{id}/expenses/{id}

Update an additional services entry on a project:

curl -X PUT \
  'https://{domain}.mocoapp.com/api/v1/projects/{id}/expenses/{id}' \
  -H 'Authorization: Token token=YOUR_API_KEY' \
  -H 'Content-Type: application/json' \
  -d '{
        "unit_price": 49
      }'

Fields are analogous to the POST request. Updates are only possible if this entry is not yet billed.

DELETE /projects/{id}/expenses/{id}

Delete an additional services entry on a project.

Deletions are only possible if this entry is not yet billed.

curl -X DELETE \
  'https://{domain}.mocoapp.com/api/v1/projects/{id}/expenses/{id}' \
  -H 'Authorization: Token token=YOUR_API_KEY'

POST /projects/{id}/expenses/disregard

Mark additional services entries as “already billed”.

curl -X POST \
  'https://{domain}.mocoapp.com/api/v1/projects/{id}/expenses/disregard' \
  -H 'Authorization: Token token=YOUR_API_KEY' \
  -H 'Content-Type: application/json' \
  -d '{
        "expense_ids": [1234, 5678],
        "reason": "Courtesy services, as discussed"
      }'

Mandatory fields are marked with a star (*):

  • reason* – “Courtesy services, as discussed”
  • expense_ids* – [1234, 5678]

GET /projects/expenses

Retrieve all additional services

curl -X GET \
  'https://{domain}.mocoapp.com/api/v1/projects/expenses' \
  -H 'Authorization: Token token=YOUR_API_KEY'

This returns an array with all additional services (see Attributes).

Additionally, these parameters can be supplied:

  • ids – e.g. 123,456 (IDS, comma-separated)
  • updated_after - e.g. 2022-09-01T14:00:00Z ISO8601 timestamp, only records that have been updated/created after
  • from – “2019-01-01”
  • to – “2019-01-31”
  • billable – true/false
  • billed – true/false
  • budget_relevant – true/false
  • tags – “tag one,tag two” (comma-separated project tags)
  • user_id - 123456 (user that created expense)

Parameters from and to only work when provided together.