Create a bank transaction

POST /api/v1/bank-transaction

Incoming transactions from a bank statement.

Headers

application/json

Body Required

  • bank_statement_uuid string Required

    Bank statement UUID to store these transactions in.

  • statement_transactions array[string] Required

    An array of payments. Required data are policy_number, date, gross_amount, and category. All amounts must be in pennies.

Responses

  • 201 application/json
    Hide response attributes Show response attributes object
    • uuid string

      The UUID of the resource.

    • The timestamp of when the resource was created.

    • The timestamp of when the resource was updated.

    • date string

      Transaction date on bank statement

    • amount object

      Transaction amount

      Additional properties are allowed.

    • Transaction reference on bank statement

    • metadata object

      Any metadata that was saved during a CSV import for transactions

      Additional properties are allowed.

    • filename string

      Filename of the CSV import transactions

    • Bank statement this bank transaction belongs to

      Additional properties are allowed.

    • The statement period this bank transaction belongs to

      Additional properties are allowed.

    • account object

      Account that created this bank transaction

      Additional properties are allowed.

    • firm object

      Firm this bank transaction belongs to

      Additional properties are allowed.

    • The amount that the payment has been reconciled to statement transactions.

      Additional properties are allowed.

    • The individual reconciliations against the expected bank payment

      Additional properties are allowed.

POST /api/v1/bank-transaction
curl \
 -X POST https://api.plannrcrm.com/api/v1/bank-transaction \
 -H "Authorization: Bearer {OAUTH_ACCESS_TOKEN or PERSONAL_ACCESS_TOKEN}" \
 -H "Content-Type: application/json" \
 -H "Accept: application/json" \
 -H "X-PLANNR-ACCOUNT-UUID: {YOUR_PLANNR_ACCOUNT_UUID}" \
 -d '{"bank_statement_uuid":"2e4197a7-e5e6-472b-92d5-b601bdcd097c","statement_transactions":[{"date":"2025-01-15","amount":15000,"reference":"AVIVA_0001"},{"date":"2025-01-15","amount":8999,"reference":"AVIVA_0002"}]}'
Request examples
# Headers
Authorization: Bearer {OAUTH_ACCESS_TOKEN or PERSONAL_ACCESS_TOKEN}
Content-Type: application/json
Accept: application/json
X-PLANNR-ACCOUNT-UUID: {YOUR_PLANNR_ACCOUNT_UUID}

# Payload
{
  "bank_statement_uuid": "2e4197a7-e5e6-472b-92d5-b601bdcd097c",
  "statement_transactions": [
    {
      "date": "2025-01-15",
      "amount": 15000,
      "reference": "AVIVA_0001"
    },
    {
      "date": "2025-01-15",
      "amount": 8999,
      "reference": "AVIVA_0002"
    }
  ]
}
Response examples (201)
{
  "date": "2022-07-15",
  "firm": {
    "tax": 17.5,
    "logo": "https://api.plannrcrm.com/images/plannr.jpg",
    "name": "Codepotato",
    "slug": "codepotato",
    "uuid": "9398f5eb-2117-4839-b247-f4bd43262a15",
    "county": "Hampshire",
    "billing": {
      "invoice_email": "gareth@codepotato.co.uk",
      "invoice_county": "Hampshire",
      "invoice_country": "United Kingdom",
      "invoice_postcode": "PO7 7YH",
      "invoice_address_1": "Suite E, 5 The Briars",
      "invoice_address_2": "Waterberry Drive",
      "invoice_town_city": "Waterlooville"
    },
    "country": "United Kingdom",
    "postcode": "PO7 7YH",
    "address_1": "Suite E, 5 The Briars",
    "address_2": "Waterberry Drive",
    "logo_icon": "https://api.plannrcrm.com/images/plannr-icon.jpg",
    "month_end": 25,
    "town_city": "Waterlooville",
    "created_at": "2025-01-17T11:18:32+00:00",
    "updated_at": "2025-01-17T11:18:32+00:00",
    "ip_whitelist": [
      "192.168.0.1",
      "127.0.0.1"
    ],
    "brand_colours": {
      "sidebar_text": "#ffffff",
      "sidebar_hover": "#0A0A42",
      "email_sub_text": "#ffffff",
      "sidebar_accent": "#36367E",
      "sidebar_active": "#53DBB8",
      "email_background": "#0E0E56",
      "email_button_text": "#ffffff",
      "sidebar_background": "#0E0E56",
      "sidebar_title_primary": "#FFC634",
      "email_button_background": "#36367E",
      "sidebar_title_secondary": "#ffffff",
      "sidebar_title_background": "#36367E",
      "email_logo_background_panel": "#36367E",
      "sidebar_title_secondary_hover": "#ffffff"
    },
    "is_subscribed": true,
    "regulatory_text": "Regulatory text",
    "addon_subscriptions": "App\\Http\\Resources\\Addons\\AddonSubscriptionResource",
    "statement_frequency": "monthly",
    "task_board_template": "App\\Http\\Resources\\Board\\BoardResource",
    "keep_deleted_files_for": 30,
    "welcome_paragraph_html": "<h1>Welcome.</h1>",
    "email_welcome_paragraph_html": "Welcome to Plannr!"
  },
  "uuid": "5e050d54-6026-4604-a178-07f63dee1a40",
  "amount": {
    "amount": "12399",
    "currency": "GBP",
    "formatted": "£123.99"
  },
  "account": {
    "firm": "App\\Http\\Resources\\FirmResource",
    "name": "Gareth Thompson",
    "role": "client",
    "tags": "App\\Http\\Resources\\TagResource",
    "type": "client",
    "uuid": "6160cb8d-9fc2-4e4f-8805-de91a582d7a0",
    "email": "gareth@codepotato.co.uk",
    "groups": "App\\Http\\Resources\\GroupResource",
    "owners": "App\\Http\\Resources\\AccountResource",
    "last_name": "Thompson",
    "created_at": "2025-01-17T11:18:32+00:00",
    "first_name": "Gareth",
    "updated_at": "2025-01-17T11:18:32+00:00",
    "with_login": true,
    "custom_fields": "App\\Http\\Resources\\CustomFieldValueResource",
    "introduced_by": "App\\Http\\Resources\\AccountResource",
    "primary_email": "App\\Http\\Resources\\ContactDetailResource",
    "can_be_deleted": "false",
    "assigned_adviser": "App\\Http\\Resources\\AccountResource",
    "next_review_date": "2025-01-17T11:18:32+00:00",
    "has_joint_account": true,
    "current_time_entry": "App\\Http\\Resources\\TimeEntryResource",
    "first_contact_date": "2025-01-17T11:18:32+00:00",
    "external_references": "App\\Http\\Resources\\ExternalReferenceResource",
    "assigned_paraplanner": "App\\Http\\Resources\\AccountResource",
    "previous_review_date": "2025-01-17T11:18:32+00:00",
    "primary_phone_number": "App\\Http\\Resources\\ContactDetailResource",
    "assigned_administrator": "App\\Http\\Resources\\AccountResource",
    "anniversary_review_date": "2025-01-17T11:18:32+00:00"
  },
  "filename": "Natwest June 2022 Statement.xlsx",
  "metadata": {
    "client_name": "Gareth Thompson"
  },
  "reference": "VitalityLtd",
  "statement": {
    "name": "01/06/2022 - 30/06/2022",
    "uuid": "fea2178f-476f-4f25-bbdf-461c05044547",
    "locked": false,
    "end_date": "2022-06-01",
    "locked_at": "2025-01-17T11:18:32+00:00",
    "locked_by": "App\\Http\\Resources\\AccountResource",
    "created_at": "2025-01-17T11:18:32+00:00",
    "start_date": "2022-06-30",
    "updated_at": "2025-01-17T11:18:32+00:00",
    "expectations_count": 6,
    "total_expectations": {
      "amount": "124585",
      "currency": "GBP",
      "formatted": "£1,245.85"
    },
    "statement_transactions": "App\\Http\\Resources\\StatementTransactionResource",
    "total_bank_transactions": {
      "amount": "125599",
      "currency": "GBP",
      "formatted": "£1,255.99"
    },
    "statement_transactions_count": 6,
    "total_statement_transactions": {
      "amount": "125599",
      "currency": "GBP",
      "formatted": "£1,255.99"
    },
    "total_expectation_amount_reconciled_to_bank": {
      "amount": "125599",
      "currency": "GBP",
      "formatted": "£1,255.99"
    },
    "total_expectation_percentage_reconciled_to_bank": {
      "amount": "8570",
      "currency": "GBP",
      "formatted": "£85.70"
    }
  },
  "created_at": "2025-01-17T11:18:32+00:00",
  "updated_at": "2025-01-17T11:18:32+00:00",
  "bank_statement": {
    "date": "2025-01-17",
    "name": "Aviva",
    "uuid": "5de473ec-615c-499d-802a-7d34db98ae4f",
    "number": 23,
    "reference": "SW#8434",
    "statement": "App\\Http\\Resources\\StatementResource",
    "created_at": "2025-01-17T11:18:32+00:00",
    "updated_at": "2025-01-17T11:18:32+00:00",
    "total_amount": {
      "amount": "345895",
      "currency": "GBP",
      "formatted": "£3,458.95"
    },
    "bank_transactions": "App\\Http\\Resources\\BankTransactionResource",
    "reconciled_amount": {
      "amount": "12849",
      "currency": "GBP",
      "formatted": "£128.49"
    },
    "reconciled_percentage": 95.68,
    "bank_transactions_count": 6
  },
  "reconciliation": {
    "amount": {
      "amount": {
        "example": "4000",
        "description": "Money amount at their lowest denominator (for example: pennies)"
      },
      "currency": {
        "example": "GBP",
        "description": "Currency of the money"
      },
      "formatted": {
        "example": "£40.00",
        "description": "Money amount formatted with currency"
      }
    },
    "percentage": 100,
    "is_reconciled": true
  },
  "reconciliations": {
    "uuid": "6a7f6042-7db8-4fbf-954d-f562fe9a85c8",
    "amount": {
      "amount": {
        "example": "4000",
        "description": "Money amount at their lowest denominator (for example: pennies)"
      },
      "currency": {
        "example": "GBP",
        "description": "Currency of the money"
      },
      "formatted": {
        "example": "£40.00",
        "description": "Money amount formatted with currency"
      }
    },
    "account": "App\\Http\\Resources\\AccountResource",
    "created_at": "2025-01-17T11:18:32+00:00",
    "updated_at": "2025-01-17T11:18:32+00:00",
    "bank_transaction": "App\\Http\\Resources\\BankTransactionResource",
    "statement_transaction": "App\\Http\\Resources\\StatementTransactionResource"
  }
}