setGuestEmailOnCart mutation
For guest customers, you must assign an email to the cart before you place the order.
A logged-in customer specifies an email address when they create an account. Therefore, you can place the order without explicitly setting the email.
Syntax
1
2
3
4
5
6
7
mutation {
  setGuestEmailOnCart(
    input: SetGuestEmailOnCartInput
  ) {
    SetGuestEmailOnCartOutput
  }
}
Example usage
Request:
1
2
3
4
5
6
7
8
9
10
11
12
mutation {
  setGuestEmailOnCart(
    input: {
      cart_id: "4JQaNVJokOpFxrykGVvYrjhiNv9qt31C"
      email: "jdoe@example.com"
    }
  ) {
    cart {
      email
    }
  }
}
Response:
1
2
3
4
5
6
7
8
9
{
  "data": {
    "setGuestEmailOnCart": {
      "cart": {
        "email": "jdoe@example.com"
      }
    }
  }
}
Input attributes
The SetGuestEmailOnCartInput object must contain the following attributes.
| Attribute | Data Type | Description | 
|---|---|---|
| cart_id | String! | The unique ID that identifies the customer’s cart | 
| email | String! | The guest user’s email | 
Output attributes
The SetGuestEmailOnCartOutput object contains the Cart object.
| Attribute | Data Type | Description | 
|---|---|---|
| cart | Cart! | Describes the contents of the specified shopping cart | 
Cart object
| Attribute | Data Type | Description | 
|---|---|---|
| applied_coupon | AppliedCoupon | Deprecated. Use applied_couponsinstead | 
| applied_coupons | [ AppliedCoupon] | An array of AppliedCouponobjects. Each object contains thecodetext attribute, which specifies the coupon code | 
| applied_gift_cards | [ AppliedGiftCard] | An array of AppliedGiftCardobjects. AnAppliedGiftCardobject contains thecodetext attribute, which specifies the gift card code.applied_gift_cardsis a Commerce-only attribute, defined in the GiftCardAccountGraphQl module | 
| applied_store_credit | AppliedStoreCredit | Contains store credit information applied to the cart. applied_store_creditis a Commerce-only attribute, defined in the CustomerBalanceGraphQl module | 
| available_payment_methods | [AvailablePaymentMethod] | Available payment methods | 
| billing_address | BillingCartAddress | Contains the billing address specified in the customer’s cart | 
| email | String | The customer’s email address | 
| id | ID! | The ID of the cart | 
| is_virtual | Boolean! | Indicates whether the cart contains only virtual products | 
| items | [CartItemInterface] | Contains the items in the customer’s cart | 
| prices | CartPrices | Contains subtotals and totals | 
| selected_payment_method | SelectedPaymentMethod | Selected payment method | 
| shipping_addresses | [ShippingCartAddress]! | Contains one or more shipping addresses | 
| total_quantity | Float! | Total Quantity of products in the cart | 
Cart query output provides more information about the Cart object.
Errors
| Error | Description | 
|---|---|
| Could not find a cart with ID "XXX" | The ID specified in the cartargument does not exist. | 
| Invalid email format | The value specified in the emailargument has an incorrect format. | 
| Required parameter "cart_id" is missing | The cart_idargument was omitted or contains an empty value. | 
| Required parameter "email" is missing | The emailargument was omitted or contains an empty value. | 
| The current user cannot perform operations on cart "XXX" | An unauthorized user (guest) tried to set the email address on the customer’s cart. | 
| The request is not allowed for logged in customers | An authorized user (customer) is not allowed to use the setGuestEmailOnCartmutation. |