Skip to content
Download OpenAPI description
Languages
Servers
Production environment
https://api.dualentry.com
Development environment (for testing)
https://api-dev.dualentry.com

Monitor API availability and service status. Use these endpoints to verify connectivity and check if the API is operational.

Operations

Manage your chart of accounts. Create and maintain the accounts used to categorize financial transactions, including assets, liabilities, equity, revenue, and expenses.

Operations

Manage products and services. Define items that appear on invoices and bills, including pricing, descriptions, and associated accounts for revenue or expense tracking.

Operations

Manage custom classification dimensions. Create and maintain classification categories (e.g., departments, locations, projects) used to tag and analyze transactions across multiple dimensions.

Operations

Manage classification values. Define the specific values within each classification category that can be assigned to transaction line items for detailed reporting and analysis.

Operations

Access and manage company information. Retrieve details about your organization including legal name, tax identifiers, addresses, and accounting preferences.

Operations

Manage approval workflows and policies. Define approval rules, steps, conditions, and approvers for different record types. Monitor workflow execution states and view approval history.

Operations

View pending approvals and approval status. Access transactions and records awaiting approval across the organization, including full approval workflow details, approvers, and action history.

Operations

Manage financial budgets. Create and track income statement and balance sheet budgets with monthly cell values, actuals comparison, and classification filtering.

Operations

Create and manage manual journal entries. Record direct debits and credits to accounts for adjustments, accruals, reclassifications, and other accounting transactions.

Operations

Automate recurring journal entries. Create templates for journal entries that occur regularly (e.g., monthly depreciation, amortization) to ensure consistent accounting treatment.

Operations

Manage bank-to-bank transfers. Record and track transfers between bank and credit card accounts, including multi-currency transfers with exchange rate handling.

Operations

Manage sales invoices. Create and track invoices sent to customers for goods or services rendered, including line items, taxes, discounts, and payment status.

Operations

Manage revenue recognition contracts. Create and retrieve contracts with performance obligations, and manage obligation usage for usage-based obligations.

Operations

Create and manage sales orders. Track customer orders for goods or services before invoicing, including line items, quantities, fulfillment status, and invoicing progress.

Operations

Automate recurring billing. Set up and manage templates for invoices that are automatically generated on a regular schedule (e.g., monthly subscriptions).

Operations

Manage customer records. Create, update, and track customers who purchase goods or services from your organization, including contact information, billing addresses, and payment terms.

Operations

Record and manage customer payments. Track payments received from customers and apply them to outstanding invoices, including partial payments and overpayments.

Operations

Track advance payments from customers. Access prepayments received before goods or services are delivered, which can be applied to future invoices.

Operations

Apply customer prepayments and credits to invoices. Record applications of prepayments or credit memos to reduce invoice balances.

Operations

Manage customer deposit transactions. Record and track deposits received from customers as security or partial payment, held in liability accounts until earned or refunded.

Operations

Process and track customer refunds. Record refunds issued to customers for overpayments, returns, or cancelled transactions.

Operations

Manage credit memos for customers. Issue credits for returned goods, billing adjustments, or discounts that reduce customer balances or can be applied to future invoices.

Operations

Record immediate cash sales transactions. Track sales where payment is received at the time of sale, including point-of-sale transactions and cash receipts.

Operations

Request

Retrieve a paginated list of CashSale records with filtering and ordering options.

Query
searchstring or null(Search)
company_idArray of integers or null(Company Id)
numberArray of integers or null(Number)
customer_idArray of integers or null(Customer Id)
start_datestring or null(date)(Start Date)
end_datestring or null(date)(End Date)
transaction_currencystring or null(SystemCurrencies)
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
record_statusstring or null(RecordStatus)
Enum"draft""posted""archived"
orderingstring or null(Ordering)
Default "id"
limitinteger(Limit)>= 1

Number of records to return per page (capped at 100)

Default 100
offsetinteger(Offset)>= 0

Number of records to skip before starting to return results

Default 0
curl -i -X GET \
  'https://api.dualentry.com/public/v1/cash-sales/?search=string&company_id=0&number=0&customer_id=0&start_date=2019-08-24&end_date=2019-08-24&transaction_currency=AED&record_status=draft&ordering=id&limit=100&offset=0'

Responses

OK

Bodyapplication/json
itemsArray of objects(Items)required
items[].​classificationsArray of objects(Classifications)
Default []
items[].​transaction_idsArray of integers(Transaction Ids)required
items[].​created_byobject or null(AuditActorSchemaOut)

Schema for audit actor information.

items[].​updated_byobject or null(AuditActorSchemaOut)

Schema for audit actor information.

items[].​internal_idinteger(Internal Id)required
items[].​numberinteger(Number)required
items[].​itemsArray of objects(Items)required
items[].​items[].​classificationsArray of objects(Classifications)
Default []
items[].​items[].​idinteger(Id)required
items[].​items[].​item_idinteger(Item Id)required
items[].​items[].​quantitystring(Quantity)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,6}0*$required
items[].​items[].​ratestring(Rate)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,6}0*$required
items[].​items[].​positioninteger(Position)required
items[].​items[].​memostring(Memo)required
items[].​items[].​bank_or_undeposited_account_amountstring(Bank Or Undeposited Account Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required
items[].​company_idinteger(Company Id)required
items[].​company_namestring(Company Name)required
items[].​company_currencystring(Company Currency)required
items[].​customer_idinteger(Customer Id)required
items[].​customer_namestring(Customer Name)required
items[].​account_numberinteger or null(Account Number)required
items[].​amountstring(Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required

Total transaction amount

items[].​memostring(Memo)required
items[].​bill_to_addressstring(Bill To Address)required
items[].​ship_to_addressstring(Ship To Address)required
items[].​billing_addressobject or null(AddressSchemaIn)
items[].​shipping_addressobject or null(AddressSchemaIn)
items[].​check_numberstring(Check Number)required
items[].​datestring(date)(Date)required

Posting date (GL date) - the date when the transaction is recorded in the general ledger

items[].​transaction_datestring(date)(Transaction Date)required

Transaction date (inception date) - the date when the transaction actually occurred

items[].​currency_iso_4217_codestring(SystemCurrencies)required
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
items[].​exchange_ratestring(Exchange Rate)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,16}0*$required
items[].​undeposited_funds_currencystring or null(SystemCurrencies)required
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
items[].​bank_or_undeposited_account_amountstring(Bank Or Undeposited Account Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required
items[].​record_statusstring(RecordStatus)required
Enum"draft""posted""archived"
countinteger(Count)required
Response
application/json
{ "items": [ { … } ], "count": 0 }

Request

Create a new CashSale record with the provided data. Validates all required fields and business rules.

Bodyapplication/jsonrequired
custom_fieldsArray of objects or null(Custom Fields)
datestring(date)(Date)required
transaction_datestring or null(date)(Transaction Date)
itemsArray of objects(Items)
Default []
memostring(Memo)
Default ""
bill_to_addressstring or null(Bill To Address)
Default ""
billing_addressobject or null(AddressSchemaIn)
ship_to_addressstring or null(Ship To Address)
Default ""
shipping_addressobject or null(AddressSchemaIn)
check_numberstring(Check Number)
Default ""
company_idinteger(Company Id)required
customer_idinteger(Customer Id)required
account_numberinteger or null(Account Number)
currency_iso_4217_codestring(SystemCurrencies)required
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
exchange_rateExchange Rate (number) or Exchange Rate (string)(Exchange Rate)required
Any of:
number(Exchange Rate)
bank_or_undeposited_account_amountBank Or Undeposited Account Amount (number) or Bank Or Undeposited Account Amount (string)(Bank Or Undeposited Account Amount)required
Any of:
number(Bank Or Undeposited Account Amount)
undeposited_funds_currencystring or null(SystemCurrencies)
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
attachmentsArray of objects(Attachments)
Default []
record_statusstring(RecordStatus)
Default "posted"
Enum"draft""posted""archived"
curl -i -X POST \
  https://api.dualentry.com/public/v1/cash-sales/ \
  -H 'Content-Type: application/json' \
  -d '{
    "custom_fields": [
      {}
    ],
    "date": "2019-08-24",
    "transaction_date": "2019-08-24",
    "items": [],
    "memo": "",
    "bill_to_address": "",
    "billing_address": {
      "street": "string",
      "city": "string",
      "state": "",
      "postal_code": "string",
      "country": "",
      "second_line": "",
      "name": "string"
    },
    "ship_to_address": "",
    "shipping_address": {
      "street": "string",
      "city": "string",
      "state": "",
      "postal_code": "string",
      "country": "",
      "second_line": "",
      "name": "string"
    },
    "check_number": "",
    "company_id": 0,
    "customer_id": 0,
    "account_number": 0,
    "currency_iso_4217_code": "AED",
    "exchange_rate": 0,
    "bank_or_undeposited_account_amount": 0,
    "undeposited_funds_currency": "AED",
    "attachments": [],
    "record_status": "posted"
  }'

Responses

OK

Bodyapplication/json
classificationsArray of objects(Classifications)
Default []
transaction_idsArray of integers(Transaction Ids)required
created_byobject or null(AuditActorSchemaOut)

Schema for audit actor information.

updated_byobject or null(AuditActorSchemaOut)

Schema for audit actor information.

internal_idinteger(Internal Id)required
numberinteger(Number)required
itemsArray of objects(Items)required
items[].​classificationsArray of objects(Classifications)
Default []
items[].​idinteger(Id)required
items[].​item_idinteger(Item Id)required
items[].​quantitystring(Quantity)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,6}0*$required
items[].​ratestring(Rate)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,6}0*$required
items[].​positioninteger(Position)required
items[].​memostring(Memo)required
items[].​bank_or_undeposited_account_amountstring(Bank Or Undeposited Account Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required
company_idinteger(Company Id)required
company_namestring(Company Name)required
company_currencystring(Company Currency)required
customer_idinteger(Customer Id)required
customer_namestring(Customer Name)required
account_numberinteger or null(Account Number)required
amountstring(Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required

Total transaction amount

memostring(Memo)required
bill_to_addressstring(Bill To Address)required
ship_to_addressstring(Ship To Address)required
billing_addressobject or null(AddressSchemaIn)
shipping_addressobject or null(AddressSchemaIn)
check_numberstring(Check Number)required
datestring(date)(Date)required

Posting date (GL date) - the date when the transaction is recorded in the general ledger

transaction_datestring(date)(Transaction Date)required

Transaction date (inception date) - the date when the transaction actually occurred

currency_iso_4217_codestring(SystemCurrencies)required
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
exchange_ratestring(Exchange Rate)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,16}0*$required
undeposited_funds_currencystring or null(SystemCurrencies)required
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
bank_or_undeposited_account_amountstring(Bank Or Undeposited Account Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required
record_statusstring(RecordStatus)required
Enum"draft""posted""archived"
Response
application/json
{ "classifications": [], "transaction_ids": [ 0 ], "created_by": { "actor_type": "string", "email": "string", "first_name": "string", "last_name": "string", "timestamp": "2019-08-24T14:15:22Z" }, "updated_by": { "actor_type": "string", "email": "string", "first_name": "string", "last_name": "string", "timestamp": "2019-08-24T14:15:22Z" }, "internal_id": 0, "number": 0, "items": [ { … } ], "company_id": 0, "company_name": "string", "company_currency": "string", "customer_id": 0, "customer_name": "string", "account_number": 0, "amount": "string", "memo": "string", "bill_to_address": "string", "ship_to_address": "string", "billing_address": { "street": "string", "city": "string", "state": "", "postal_code": "string", "country": "", "second_line": "", "name": "string" }, "shipping_address": { "street": "string", "city": "string", "state": "", "postal_code": "string", "country": "", "second_line": "", "name": "string" }, "check_number": "string", "date": "2019-08-24", "transaction_date": "2019-08-24", "currency_iso_4217_code": "AED", "exchange_rate": "string", "undeposited_funds_currency": "AED", "bank_or_undeposited_account_amount": "string", "record_status": "draft" }

Request

Retrieve a specific CashSale record by number with all related data.

Path
record_numberinteger(Record Number)required
Query
searchstring or null(Search)
company_idArray of integers or null(Company Id)
numberArray of integers or null(Number)
customer_idArray of integers or null(Customer Id)
start_datestring or null(date)(Start Date)
end_datestring or null(date)(End Date)
transaction_currencystring or null(SystemCurrencies)
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
record_statusstring or null(RecordStatus)
Enum"draft""posted""archived"
curl -i -X GET \
  'https://api.dualentry.com/public/v1/cash-sales/{record_number}/?search=string&company_id=0&number=0&customer_id=0&start_date=2019-08-24&end_date=2019-08-24&transaction_currency=AED&record_status=draft'

Responses

OK

Bodyapplication/json
classificationsArray of objects(Classifications)
Default []
transaction_idsArray of integers(Transaction Ids)required
created_byobject or null(AuditActorSchemaOut)

Schema for audit actor information.

updated_byobject or null(AuditActorSchemaOut)

Schema for audit actor information.

internal_idinteger(Internal Id)required
numberinteger(Number)required
itemsArray of objects(Items)required
items[].​classificationsArray of objects(Classifications)
Default []
items[].​idinteger(Id)required
items[].​item_idinteger(Item Id)required
items[].​quantitystring(Quantity)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,6}0*$required
items[].​ratestring(Rate)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,6}0*$required
items[].​positioninteger(Position)required
items[].​memostring(Memo)required
items[].​bank_or_undeposited_account_amountstring(Bank Or Undeposited Account Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required
company_idinteger(Company Id)required
company_namestring(Company Name)required
company_currencystring(Company Currency)required
customer_idinteger(Customer Id)required
customer_namestring(Customer Name)required
account_numberinteger or null(Account Number)required
amountstring(Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required

Total transaction amount

memostring(Memo)required
bill_to_addressstring(Bill To Address)required
ship_to_addressstring(Ship To Address)required
billing_addressobject or null(AddressSchemaIn)
shipping_addressobject or null(AddressSchemaIn)
check_numberstring(Check Number)required
datestring(date)(Date)required

Posting date (GL date) - the date when the transaction is recorded in the general ledger

transaction_datestring(date)(Transaction Date)required

Transaction date (inception date) - the date when the transaction actually occurred

currency_iso_4217_codestring(SystemCurrencies)required
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
exchange_ratestring(Exchange Rate)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,16}0*$required
undeposited_funds_currencystring or null(SystemCurrencies)required
Enum"AED""AFN""ALL""AMD""ANG""AOA""ARS""AUD""AWG""AZN"
bank_or_undeposited_account_amountstring(Bank Or Undeposited Account Amount)^(?!^[-+.]*$)[+-]?0*\d*\.?\d{0,2}0*$required
record_statusstring(RecordStatus)required
Enum"draft""posted""archived"
Response
application/json
{ "classifications": [], "transaction_ids": [ 0 ], "created_by": { "actor_type": "string", "email": "string", "first_name": "string", "last_name": "string", "timestamp": "2019-08-24T14:15:22Z" }, "updated_by": { "actor_type": "string", "email": "string", "first_name": "string", "last_name": "string", "timestamp": "2019-08-24T14:15:22Z" }, "internal_id": 0, "number": 0, "items": [ { … } ], "company_id": 0, "company_name": "string", "company_currency": "string", "customer_id": 0, "customer_name": "string", "account_number": 0, "amount": "string", "memo": "string", "bill_to_address": "string", "ship_to_address": "string", "billing_address": { "street": "string", "city": "string", "state": "", "postal_code": "string", "country": "", "second_line": "", "name": "string" }, "shipping_address": { "street": "string", "city": "string", "state": "", "postal_code": "string", "country": "", "second_line": "", "name": "string" }, "check_number": "string", "date": "2019-08-24", "transaction_date": "2019-08-24", "currency_iso_4217_code": "AED", "exchange_rate": "string", "undeposited_funds_currency": "AED", "bank_or_undeposited_account_amount": "string", "record_status": "draft" }

Manage vendor bills and payables. Record and track bills received from vendors for goods or services purchased, including line items, due dates, and payment tracking.

Operations

Automate recurring expenses. Configure templates for bills that repeat on a regular basis (e.g., monthly rent, subscriptions) to streamline expense tracking.

Operations

Create and track purchase orders. Manage formal requests to vendors for goods or services, including approval workflows, receiving tracking, and bill matching.

Operations

Record direct expense transactions. Track payments made directly from a bank or credit card account for expenses, without going through the accounts payable process.

Operations

Manage vendor and supplier records. Track businesses and individuals from whom you purchase goods or services, including contact details, payment terms, and tax information.

Operations

Record and manage vendor payments. Track payments made to vendors and apply them to outstanding bills and credits, including partial payments and overpayments.

Operations

Track advance payments to vendors. Record prepayments made before goods or services are received, which can be applied to future bills.

Operations

Apply vendor prepayments to bills. Record applications of prepayments to reduce bill balances and track amounts owed.

Operations

Manage vendor credit memos. Record credits from vendors for returned goods, billing adjustments, or discounts that reduce amounts owed or can be applied to future bills.

Operations

Process and track vendor refunds. Record refunds received from vendors for overpayments, returns, or cancelled transactions.

Operations

Manage paper check printing. Create, queue, and batch print paper checks for vendor payments, direct expenses, vendor prepayments, and customer refunds.

Operations

Manage fixed assets and capital equipment. Create, update, and track long-lived tangible assets including depreciation schedules, account assignments, and asset lifecycle management.

Operations