These fields should be used in preference to the other fields described in this document wherever possible. Through a more complex structure we are able to more accurately represent the industry's available deals and so better communicate them to customers, leading to improved conversion.
Note: The following standard fields should be downloaded alongside all the below fields as they aren't duplicated here:
Note: Majority of the JSON fields are not compatible with Landline, Broadband and TV deals except for [deal_type_json];[deal_extras_json]; [deal_costs_json] and [deal_retailer_json].
The "product" sits at the highest level of our product tree, and describes a conceptual product like an "iPhone" or a "Galaxy" phone. It belongs to a manufacturer/brand, and has a product type.
Note: Using the [product_id] you can group all "Galaxy" products together or all "iPhone" products together (for example).
Note: The [product_name] can be appended to the [product_brand] to arrive at a more complete product name: [product_brand] + [product_name] = "Apple iPhone".
Note: this could be different from the manufacturer, so for instance a "Google Nexus 6" is branded "Google" but is manufactured by Motorola. Wherever possible we will specify the branding rather than the manufacturer. Similarly the "EE Kestrel" is manufactured by Huawei, but will be branded "EE" in our data.
The "product version" sits below the "product" in the product hierarchy and describes at a reasonably high level the product in the range. Examples would be (Apple iPhone) "5s" or (Samsung Galaxy) "S4". Using the [product_version_id], all the different colours and capacities of Samsung Galaxy S4 could be grouped together, or we can filter on just Apple iPhone 5C, and see all the colours and capacities that are available.
The [product_version_name] can be appended to [product_name] and [product_brand] to arrive at the complete product version name: [product_brand] + [product_name] + [product_version_name] = "Apple iPhone 5S".
The "product edition" is the lowest level of the product hierarchy and describes a specific product being sold. Examples would be (Apple iPhone 5S) "16GB White" or (Samsung Galaxy S4) "32GB Blue".
Note: in practice, the capacity and colour will act as the defining features of this edition (separating it from other editions under the same [product_version]), but in future other defining features could emerge.
Note: the capacity and colour are described in a structured way in the [device_features_json] field so there is no need to parse the [product_edition_name] field.
The full product name can be derived by using the [product_brand], [product_name], [product_version_name] and [product_edition_name] together: e.g. "Apple iPhone 5S 16GB White".
More image types could be added in future. A note about images.
This field contains product attributes that can be used for filtering and grouping of products.
Note: the values can be empty for product types where the feature does not apply (for instance Televisions don't have a SIM Card Type), and as a result the key may not appear. See Specifications and Features availability for more information.
Note: this does not relate to the Network or tariff being purchased (as in, it's entirely possible to buy a 3G contract for a 4G device). The contract's data standard is described in [tariff_allowances_json] - cellular speed.
Note: where there is no 'friendly' description is available, the standard description is passed through in its place.
Note: older cameras can show as having a decimal value of less than 1 megapixel ("0.3" is VGA, for example), but all newer cameras will be rounded to the nearest megapixel. If no camera is available, this field will contain the text 'None'.
It is expected that specifications will not be used for filtering or grouping because many of the specifications are free text fields.
Note: that many of the fields below have already been described in Standard Fields - specifications. Those fields that are unique to the JSON representation have been described below.
Note: sub-fields could still be empty if the relevant device does not have a certain specification. Where this is the case, the key will not be included. This is because not all specification types apply to all products. See Specifications and Features availability for more information.
General details of the Mobile Network Operator with whom the customer will have a contract.
Note: In cases where the product does not belong to a Network (i.e. is SIM-Free or not a cellular device), the [name] and [company_id] values will be populated consistently as "No Network" and "76" respectively, but the other values can be blank. See also Skipping fields based on [network_details_json].
Note: that this is not always available for MVNOs.
Tariffs are often grouped by the networks. The tariff group allows for filtering/grouping of tariffs. Similar tariffs often have the same benefits, call charges etc. See also Displaying tariff information.
Note: In cases where the product is sold without a contract (as in the case of SIM-Free phones, or some wearable devices), the [tariff_group_description] field can be empty. In all other cases it should be populated. See also Skipping fields based on network_details_json.
Note: it is important to display promotional information when it is available as it could materially affect the product the customer is purchasing. This field can (and often will) be empty.
Contains details of the specific tariff being purchased. See also Displaying tariff information.
Note: To determine whether or not the device comes with a contract you can check for the value of "11" in [tariff_details_json] - tariff_type_id or "76" in [network_details_json] - company_id. See also Skipping fields based on network_details_json.
Note: The tariff_type_id gives no indication of whether the deal is a "SIM Only" type deal (i.e. without a device included). In order to determine whether the deal comes with or without a device, check the [device_product_json] - product_type_id field for a value of 2 (SIM Card).
Note: it is important to display promotional information when it is available as it could materially affect the product the customer is purchasing. This field can (and often will) be empty.
Contains details of all the allowances that come with this tariff. See also Displaying tariff information.
Note: All these fields are optional, and depend on the type of contract tied to the deal (if any). To determine whether or not it's worth your code checking through this field, you can look for the presence of "11" in [tariff_details_json] - tariff_type_id or "76" in [network_details_json] - company_id. See also Skipping fields based on network_details_json.
Note: Wherever the product does come with a contract, you should find data in these fields, though exactly which ones are populated will depend on the type of contract (for instance Mobile Broadband deals don't come with minutes and texts). In most cases, it is best for your page to 'fail gracefully' - i.e. intelligently show or hide fields based on the presence of a value.
Note: In many cases Pay-as-you-go tariffs can have inclusive minutes/texts/data/etc. when purchased with an appropriate topup, so it's best not to rely on assumptions about contract types (related to the above point).
Note: sometimes unlimited wifi is included as a benefit of being on the network or under certain circumstances like on the london underground. This won't be represented here, but instead will be shown in [deal_extras_json].
Contains details of pence-per-minute or pence-per-MB style charges when the customer uses up all their inclusive allowances (or where there's no inclusive allowance). See also Displaying tariff information.
Note: All these fields are optional, and depend on the type of contract tied to the deal (if any). To determine whether or not it's worth your code checking through this field, you can look for the presence of 11 in [tariff_details_json] - [tariff_type_id] or 76 in [network_details_json] - company_id. See also Skipping fields based on network_details_json.
Note: Wherever the product does come with a contract, you should find data in these fields, though exactly which ones are populated will depend on the type of contract (for instance Mobile Broadband deals don't come with minutes and texts). In most cases, it is best for your page to 'fail gracefully' - i.e. intelligently show or hide fields based on the presence of a value.
Describes the type of sale to allow appropriate filtering. Valid values are currently limited to:
Extras are split into high-level Groups (like "Free Gifts", or "Discounts & Loyalty", for instance), and within those groups Extras are further sub-categorised into Source Types. Everything is given a consistent ID and so Groups and Types can be grouped/filtered as required within your code. See also Displaying tariff information.
Note: Additional Group Types may be added in future. When they are, they will be documented here.
Note: The list of Source Types will grow and change over time as new services and types of service are brought to market. It's therefore best to build your list of Source Types based on the contents of the data feed rather than the extract above, which is provided as an example only.
groups (Top Level) - beneath this is an array of Extra Groups Types and their details.
Note: Each Extra Group is contextually different, and their purposes are discussed below, though their structure is consistent.
extra source type (Second Level) - beneath this is an array of Extra Source Types and their details.
Note: Source Types allow us to subcategorise Extras. The Source Type can appear under more than one Group (for instance, allowances could be part of an inclusive service and/or a loyalty reward.)
extra (Third Level) - beneath this is an array of extras and each extra's details.
Contains details of the merchant (retailer) selling the deal. Note that this can be different from the Network the deal is being sold on.
Contains details of the deal's pricing both including and excluding VAT. Including VAT prices should be shown for consumer deals, whereas convention dictates that business-only deals be sold at exc. VAT prices. We have included both in case you need to mix and match business and consumer deals in the same list.
See Understanding Pricing for more information.
Note: Where the product is not being sold with a contract (check for "76" in [network_details_json] - company_id), any monthly fields should be ignored. See also Skipping fields based on network_details_json.
Note: Any _previous fields can be empty where no previous price exists.monthly_contract_ and monthly_device_ fields will be empty where the contract isn't a split-price deal.
Price-rises object:
Details the discounts available with this deal, split into network and retailer discounts (the two can co-exist). A retailer discount is often supplied on a redemption (customer must claim) or automatic (sent in the post after x days) basis, and payment will usually arrive by cheque or bank transfer. By contrast a network discount is usually discounted at source, and so the customer will see the discount applied to their monthly bill.
See Grouping and Filtering Cashbacks.
Note: Where a promotion code is required to support any given discount, this will be described in the fields: [tariff_group_details_json] - tariff_group_promo_info, [tariff_details_json] - tariff_promo_info or [deal_promo_info]. It is important therefore that all these fields can be passed through unaltered and presented on-site in order to support merchant promotional activity. Whether the promo info is stored at the tariff group, tariff, or deal level depends on to what extent this promotion is shared among other deals offered by the merchant.
Note: Empty entries will be excluded, so if there are no discounts of any sort, this field could be empty.
See Grouping and Filtering Cashbacks.
Note: This field will be empty where no cashbacks are available for this deal.