SugarClub will be undergoing planned maintenance from 08 January 2025 at 3:00 PM PDT until 08 January 2025 at 4:00 PM PDT.
The site will be inaccessible during this time. We are sorry for any inconvenience.

Rest API Quote Line Items

Hi,

I have  developed a simple C# program to extract Quotes from Sugar using the example

sugarondemand.com/rest/v11/Quotes/{0}

However  this returns the header data only.

Question  is:

What do I use to return the Quote Line Items?

Thank you

  • If you get the quotes data there should be a 'bundles' property in the json returned.

  • Hi Jeroen,

    Thank you for reply.  I have been testing in postman and can view  the  header, but  there are no  bundles property  in my json response.

    {
        "id": "0bd9effa-2569-11eb-bcbb-02dad32f8720",
        "name": "test",
        "date_entered": "2020-11-13T15:31:06+11:00",
        "date_modified": "2020-12-04T11:12:19+11:00",
        "modified_user_id": "5a86deca-2539-821d-832c-57b3ef40b586",
        "modified_by_name": "Admin",
        "modified_user_link": {
            "full_name": "Admin",
            "id": "5a86deca-2539-821d-832c-57b3ef40b586",
            "_acl": {
                "fields": {
                    "pwd_last_changed": {
                        "write": "no",
                        "create": "no"
                    },
                    "last_login": {
                        "write": "no",
                        "create": "no"
                    }
                },
                "_hash": "6d408abe17083243re7afd72eaecf780699c2"
            }
        },
        "created_by": "dXfe43ef0-75e7-sqds11e9-aa84-06dc56813a60",
        "created_by_name": "User Name",
        "created_by_link": {
            "full_name": "User Name",
            "id": "dfe43ef0-75e7-11e9-aa84-06dc5681313a60",
            "_acl": {
                "fields": [],
                "_hash": "654d337e0e2912edaa00dbb0fb3dc3c17"
            }
        },
        "description": "",
        "deleted": false,
        "shipper_id": "",
        "shipper_name": "",
        "shippers": {
            "name": "",
            "id": "",
            "_acl": {
                "fields": [],
                "_hash": "654d33w7e0e912edaa0034dbb0fb3dc3c17"
            }
        },
        "taxrate_id": "61762173-85323a-1375-6a4c-56d54137925b1",
        "taxrate_name": "GST",
        "taxrates": {
            "name": "GST",
            "id": "617632173-85323a-1375-6a4c-56d5137925b1",
            "_acl": {
                "fields": [],
                "_hash": "654d337e033e912edaa00dbb0fb3d32c3c17"
            }
        },
        "taxrate_value": "10.000000",
        "show_line_nums": true,
        "quote_type": "Quotes",
        "date_quote_expected_closed": "2020-12-31",
        "original_po_date": "",
        "payment_terms": "",
        "date_quote_closed": "",
        "date_order_shipped": "",
        "order_stage": "Pending",
        "quote_stage": "Draft",
        "purchase_order_num": "",
        "quote_num": 11729,
        "subtotal": "1465.000000",
        "subtotal_usdollar": "1465.000000",
        "shipping": "0.000000",
        "shipping_usdollar": "0.000000",
        "discount": "0.000000",
        "deal_tot": "0.00",
        "deal_tot_discount_percentage": 0,
        "deal_tot_usdollar": "0.00",
        "new_sub": "1465.000000",
        "new_sub_usdollar": "1465.000000",
        "taxable_subtotal": "1465.000000",
        "tax": "146.500000",
        "tax_usdollar": "146.500000",
        "total": "1611.500000",
        "total_usdollar": "1611.500000",
        "billing_address_street": "",
        "billing_address_city": "",
        "billing_address_state": "Victoria",
        "billing_address_postalcode": "",
        "billing_address_country": "",
        "shipping_address_street": "",
        "shipping_address_city": "",
        "shipping_address_state": "Vic",
        "shipping_address_postalcode": "",
        "shipping_address_country": "",
        "shipping_account_name": "Test Practice",
        "shipping_accounts": {
            "name": "Test Practice",
            "id": "9918dd4c-4653-c0fa-c9fe-572ac94d4e17",
            "_acl": {
                "fields": [],
                "_hash": "654d337e0e912edaa00dbb0fb3dc3c17"
            }
        },
        "shipping_account_id": "9918dd4c-4653-c0fa-c9fe-572ac94d4e17",
        "shipping_contact_name": "",
        "shipping_contacts": {
            "full_name": "",
            "id": "",
            "_acl": {
                "fields": [],
                "_hash": "654d337e0e912edaa00dbb0fb3dc3c17"
            }
        },
        "shipping_contact_id": "",
        "account_name": "Test Practice",
        "billing_accounts": {
            "name": "Test Practice",
            "id": "9918dd4c-4653-c0fa-c9fe-572ac94d4e17",
            "_acl": {
                "fields": [],
                "_hash": "654d337e0e912edaa00dbb0fb3dc3c17"
            }
        },
        "account_id": "9918dd4c-4653-c0fa-c9fe-572ac94d4e17",
        "billing_account_name": "Test Practice",
        "billing_account_id": "9918dd4c-4653-c0fa-c9fe-572ac94d4e17",
        "billing_contact_name": "",
        "billing_contacts": {
            "full_name": "",
            "id": "",
            "_acl": {
                "fields": [],
                "_hash": "654d337e0e912edaa00dbb0fb3dc3c17"
            }
        },
        "billing_contact_id": "",
        "opportunity_name": "",
        "opportunities": {
            "name": "",
            "id": "0bd9effa-2569-11eb-bcbb-02dad32f8720",
            "_acl": {
                "fields": [],
                "_hash": "654d337e0e912edaa00dbb0fb3dc3c17"
            }
        },
        "opportunity_id": "",
        "following": "",
        "my_favorite": false,
        "tag": [],
        "sync_key": "",
        "assigned_user_id": "dfe4sdfs3ef0-75e7-11e9-aa84-06dc56813a60",
        "assigned_user_name": "Test User",
        "assigned_user_link": {
            "full_name": "Test User",
            "id": "dfedswd43ef0-75e7-11e9-aa84-06dc56813a60",
            "_acl": {
                "fields": [],
                "_hash": "654dsadsw337e0e912edaa00dbb0fb3dc3c17"
            }
        },
        "team_count": "",
        "team_count_link": {
            "team_count": "",
            "id": "1",
            "_acl": {
                "fields": [],
                "_hash": "654d337e0e91dwdqd2edaa00dbb0fb3dc3c17"
            }
        },
        "team_name": [
            {
                "id": "1",
                "name": "Global",
                "name_2": "",
                "primary": true
            }
        ],
        "currency_id": "-99",
        "base_rate": "1.000000",
        "currency_name": "",
        "currencies": {
            "name": "",
            "id": "-99",
            "_acl": {
                "fields": [],
                "_hash": "65asd4d337e0sdcseve912edaa00dbc34b0fb3dc3c17"
            },
            "symbol": ""
        },
        "currency_symbol": "",
        "incl_gst_c": "2130.000000",
        "gst_mgt_c": "Grand Total inc GST",
        "closed_accepted_total_c": "0.000000",
        "new_sub_shipping_c": "1465.000000",
        "gst_c": "665.000000",
        "show_total_incl_gst_c": false,
        "monthly_subcription_c": false,
        "product_count_c": 5,
        "product_count_monthly_sub_c": 0,
        "product_count_non_sub_c": 5,
        "product_count_bundle_c": 1,
        "payment_terms_c": "",
        "special_price_quote_c": true,
        "second_year_c": "yes",
        "customerreferencenumber_c": "",
        "customer_reference_number_c": null,
        "sap_order_c": 0,
        "_acl": {
            "fields": {}
        },
        "_module": "Quotes"
    }


    Do you by chance have an 
    Regards

    Brendan

  • Can you check in sugar if there are actual quote line items connected to the quote? 

    which version of sugar are we talking about? 

  • Hi Brendan,

    It seems the generic question is  how to deal with Sugar data while having a strong technical background, admin-level knowledge Sugar  but no time to learn how to develop for Sugar

    Actually, necessary data preparations could be configured in Sugar with Logic Builder configurator tool and exposed as the custom endpoint.

    That is very easy for a non-developer to make it, so let me show an example on QLI retrieval case in a low-code approach:

    There are 3 simple steps to achieve a result:
    1) to declare a custom endpoint as Service
    2) To implement Service in a Logic Builder flowchart 
    3) To install the flowchart via Module Loader

    I declared an endpoint with 2 parameters:


    Then I drew a flowchart in Logic Builder (https://logicbuilder.integroscrm.com) to retrieve just a few necessary QLI fields for the QuoteName.
    You may easily read it by following the white line.
    As you can see, you may configure any logic and define the structure for selecting necessary data:


    Then I've generated zip package in a click with Logic Builder and install it  to Sugar via Module Loader 

    Now, if you use Postman to make an authorized request (user jim password  jim)  you will get a ready-to-use response with necessary QLIs data:

    Response:

    This approach works for both Sugar Cloud and on-premise, from version 7.5 and up to the modern one.


    Best Regards,
    Dmytro Chupylka

    integroscrm.com
    We make work in Sugar CRM system faster, more convenient and efficient

  • Hi Dmytro,

    appreciate the detailed response. All im trying to do is connect to sugar and access the Quote and Quote Line Items.

    As detailed above, I can call a quote and this is returning the Quote, but no array / list of items.

    I would have assumed by default this function would return the items of a quote, but for some reason its not doing so.

    Regards

  • I just checked it myself and indeed when you get the quote like this: 

    yourinstance/.../<quoteid> you won't get the bundles / products that are connected. When you add the following query param view=record they are returned. The reason for this I don't know. 

    p.s. A tip from my side. If you work with a new system you don't know anything about and you know it's rest based please open the application itself i your browser and see what developer tools is telling you. 

  • Let me try to help in solving the particular task

    Could you specify what fields per object (Quote/QLI/ect) you would expect Sugar to return and whether any criterion for filtering (e.g. Name, Price, Quantity and LineTotal of the QLIs for Product type A from confirmed Quotes to ship to Arizona, or smth like that)? 



    Best Regards,
    Dmytro Chupylka

    integroscrm.com
    We make work in Sugar CRM system faster, more convenient and efficient

  • Hi  Jeroen,

    Thanks for the tip. Yes passing  the view=record now shows the  bundles.
    Agree its strange why the standard api call doesnt show the line items.

    Appreciate your help