Spendint API - POST /sn_spend_intg/spendint/invoice

  • Release version: Washingtondc
  • Updated February 1, 2024
  • 5 minutes to read
  • Accepts invoices from third-party providers.

    If the purchase order and purchase order lines are in the Pending Submission status, and the sales order and sales order lines are not populated, then the shipment and invoice posting from the third-party reseller is not allowed. It is only allowed when the status of the purchase order and purchase order lines are Ordered. Also, there is no sequential restriction on shipment and invoice posting.

    After an invoice is submitted, the invoice and invoice lines are mapped to a purchase order. On a successful mapping, the state of the invoice is set as follows:
    • Awaiting Delivery: When no receipts exist, the order is partially delivered, or the invoice requires approval.
    • Invoice Confirmed: When the purchase order is delivered and the amount invoiced matches the purchase order total amount.
    • Requires Review: When the purchase order is delivered and the amount invoiced does not match the purchase order total amount.

    When a valid invoice is posted for a line item, the same invoice cannot be updated.

    If the provided invoice does not have a purchase order number, the invoice is rejected and you see an error message that states that one or more of the provided invoices does not have a purchase order number. If the provided invoice has a purchase order number, but it doesn't match the purchase order or no purchase order exists, you see an error message. The message states that one or more invoices do not have a corresponding purchase order that matches the purchase order number of the invoice. Also, if the amount invoiced sent from the third-party reseller does not match with the invoiced amount, the invoice is rejected.

    Status tables

    To know the status of the invoice request, make a REST call into the ServiceNow database using the Table REST API. The response from the API lists the records where the invoice creation failed. For invoice response, query the Invoice Error table with the following parameter:

    sysparm_query=outbound_error.supplier_id=<supplier_id>^outbound_error.state=20

    The details on the customer ID, supplier ID, error type, unique import set ID, and state can be found in the Outbound Status table, which is the parent error table.

    URL format

    /api/sn_spend_intg/spendint/invoice

    Supported request parameters

    Table 1. Path parameters
    Name Description
    None
    Table 2. Query parameters
    Name Description
    mode Support for asynchronous and synchronous modes for third-party integration.

    Data type: String

    Valid values:
    • async: Asynchronous mode.
    • sync: Synchronous mode.

    Default: async

    Table 3. Request body parameters (XML or JSON)
    Name Description
    currency Required. Currency for subtotal, tax, and shipping. The subtotal, tax, and shipping should be in the same currency.

    Data type: String

    Maximum length: 40

    customer_id Identifier for the customer.

    Data type: String

    Maximum length: 100

    discounts Discounts that are applied toward the invoice. This is an editable field.

    Data type: String

    Maximum length: 100

    invoice_date Required. Date on which the customer was invoiced.

    Data type: String

    Maximum length: 40

    Format: YYYY-MM-DD

    invoice_lines List of objects that define the lines that are being invoiced for purchases within this order.

    Data type: Array

    "invoice_lines": [
      {
        "invoiced_line_amount": "String",
        "invoiced_quantity": "String",
        "line_number": "String",
        "supplier_invoice_line_number": "String",
        "sales_order_line_number": "String"
      }
    ]
    invoice_lines.invoiced_line_amount Required. Total cost, excluding taxes and shipping, that a customer is being invoiced for a given purchase order line.

    Data type: String

    Maximum length: 40

    invoice_lines.invoiced_quantity Required. Quantity of goods or services that a customer is being invoiced for.

    Data type: String

    Maximum length: 40

    invoice_lines.line_number Required. Purchase order line number that is generated by the customer for a particular purchase.

    Data type: String

    Maximum length: 40

    invoice_lines.sales_order_line_number Required. Sales order line number that is generated by the supplier.

    Data type: String

    Maximum length: 40

    invoice_lines.supplier_invoice_line_number Required. Identification number that is generated by a supplier for this invoice line.

    Data type: String

    Maximum length: 100

    other_charges Other additional charges associated to the invoice. This is an editable field.

    Data type: String

    Maximum length: 100

    order_number Required. Purchase order number that is provided by the customer for this order.

    Data type: String

    Maximum length: 40

    remit_to_address Required. Location to which a payment is made.

    Data type: String

    Maximum length: 1000

    sales_order_number Required. Number or value that is generated by the supplier for this order.

    Data type: String

    Maximum length: 40

    shipping Required. Total shipping cost for the entire purchase.

    Data type: String

    Maximum length: 40

    subtotal Required. Total amount of money to be paid to the supplier excluding tax and shipping charges.

    Data type: String

    Maximum length: 40

    supplier_id Required. Identifier for the reseller or supplier that the customer can place orders with.

    Data type: String

    Maximum length: 100

    supplier_invoice_number Required. Identification number that is generated by a supplier for this invoice.

    Data type: String

    Maximum length: 100

    supplier_tax_id Tax identifier that is associated to the third party reseller. This is an editable field.

    Data type: String

    Maximum length: 100

    tax Required. Total amount of taxes that are billed for the purchase.

    Data type: String

    Maximum length: 40

    tax_rate Tax rate percentage that is applied for the order. This is an editable field.

    Data type: String

    Maximum length: 100

    third_party_import_id Identifier that enables a third party to pass a string value to uniquely identify a set of imported data.

    Data type: String

    Maximum length: 100

    total_amount_invoiced Required. Total amount of money to be paid to the supplier including tax and shipping charges.

    Data type: String

    Maximum length: 40

    Headers

    The following request and response headers apply to this HTTP action only or apply to this action in a distinct way.

    Table 4. Request headers
    Header Description
    Accept Data format of the response body. Supported types: application/json or application/xml.

    Default: application/json

    Note:
    Only the application/json data format is supported for Procurement Integration Framework.
    Table 5. Response headers
    Header Description
    None

    Status codes

    The following status codes apply to this HTTP action.

    Table 6. Status codes
    Status code Description
    success Successful. The request was successfully processed.
    failure Unsuccessful. The request was processed with errors.

    Response body parameters (JSON)

    These response body parameters are received when queried in synchronous mode.
    Name Description
    error_response_body Description of the errors, listed by the sales order line number, sales order number, supplier invoice number, supplier invoice line number, and the error message.

    Data type: Array

    error_response_body.error_message Detailed error message.

    Data type: String

    status_code Response status such as "success" or "failure."

    Data type: String

    cURL request

    curl "https://instance.service-now.com/api/sn_spend_intg/spendint/invoice" \
    --request POST \
    --header "Accept:application/json" \
    --user 'username':'password'
    {"root":[{
      "customer_id": "Customer - A",
      "supplier_id": "SUP-123456",
      "third_party_import_id": "undefined",
      "supplier_invoice_number": "QAAP89873220071",
      "supplier_tax_id": "TIN000000",
      "order_number": "POL7987633",
      "sales_order_number": "SO0000000081",
      "invoice_date": "YYYY-MM-DD",
      "subtotal": "6000",
      "tax_rate": "10%",
      "tax": "600",
      "shipping": "120",
      "other_charges": "100",
      "discounts": "200",
      "total_amount_invoiced": "6620",
      "remit_to_address": "1640 Camino Del Rio North #202, San Diego,CA",
      "currency": "USD",
      "invoice_lines": [
        {
          "supplier_invoice_line_number": "QA789A867877ABN32251",
          "line_number": "POL587667",
          "sales_order_line_number": "SOL00000081",
          "invoiced_quantity": "45",
          "invoiced_line_amount": "4000"
        },
        {
          "line_number": "POL587668",
          "supplier_invoice_line_number": "78987323",
          "sales_order_line_number": "SOL98769",
          "invoiced_quantity": "12",
          "invoiced_line_amount": "2000"
        }
      ]
    }
    ]}

    Possible responses:

    // Success response:
    {
        "result": {
            "response": "success"
        }
    }
    
    // Error response:
    {
        "result": {
            "response": [
                {
                    "customer_id": "Customer - A",
                    "supplier_id": "SUP-123456",
                    "third_party_import_id": "undefined",
                    "status_code": "failure",
                    "error_response_body": [
                        {
                            "sales_order_line_number": "SOL00000081",
                            "sales_order_number": "SO0000000081",
                            "supplier_invoice_number": "QAAP89873220071",
                            "supplier_invoice_line_number": "QA789A867877ABN32251",
                            "error_message": "The invoice do not have a corresponding purchase order which matches the purchase order number of the invoice provided\n"
                        }
                    ]
                }
            ]
        }
    }