API URL: https://api.autosyncstudio.com/
API keys may be generated in the portal: https://portal.autosyncstudio.com/
1. Legend
URL query parameter prefixes:
f-
- (filter) denotes a parameter that narrows down the result set or specifies preferred records, e.g.f-year
i-
- (include) denotes a parameter that adds optional data to the result, e.g.i-colors
p-
- (page) denotes a parameter that pertains to pagination, e.g.p-number
s-
- (sort) denotes a parameter that orders a collection by a specified field, e.g.s-price
2. Authorization
All vehicle and wheel endpoints require a valid key to pass authorization. Each key determines which wheel brands are accessible in wheel endpoints.
Append key
parameter to a URL to specify a key:
/vehicles/years?key=secret
If key
parameter is not specified or a provided key is invalid, the API will return the following response for endpoints requiring authorization:
{ "Error": "Invalid API key" }
GET /keys/validate
To test if an API key is valid, you can query the following endpoint:
/keys/validate?key=secret
A successfully validated key passed to the endpoint will result in the following response:
{ "Status": "OK" }
3. Segments
The endpoints are divided into the following segments:
Accessories
Tires
Vehicles
Wheels
Each set of endpoints is guarded by a permission. An attempt to access an endpoint without appropriate permission assigned to an API key will result in the following error:
{ "Error": "Unauthorized access to segment: tires" }
If you see the error and believe this is a mistake, please contact AutoSync.
4. API Key Configuration
GET /keys/config
Configuration set for an API key. This includes theming and filtering.
/keys/config?key=secret
Sample response for a valid key:
{ "BrandIds": [130], "Locations": [{ "Id": 100, "Name": "Vancouver Premium Tire", "Country": "Canada", "Address": "2452 52 Ave", "City": "Vancouver", "State": "BC", "Zip": "V2Y 4B4", "Phone": "(604) 333-4444", "Coordinates": [ 45.133904, -122.584391 ] }, ... ], "MakeIds": [], "Segments": [ "tires", "vehicles", "wheels" ], "VehicleTypes": [], "Visualizer": { "AlignHomeContentToTop": true, "BgImg": "", "BgImgOpacity": 1, "BrandColor": "#ae1016", "BrandLogo": "https://vvs.autosyncstudio.com/static/icons/Autosync-logo-grey.png", "Ga4Key": "UA-213519920-3", "ListVehicleModelsByYear": true, "PaginationSize": 24, "ScrollIntoView": true, "TireLogo": "https://vvs.autosyncstudio.com/static/clients/11/product_logo.071c7.webp", "VehicleLogo": "https://vvs.autosyncstudio.com/static/vehicles.png", "VehicleThumbnails": "color", "WheelLogo": "https://vvs.autosyncstudio.com/static/clients/11/product_logo.071c7.webp" } }
BrandIds
- IDs of allowed brandsLocations
- a list of locations assigned to a retailer or manufacturer; empty if none specifiedCoordinates
- latitude and longitude of the address;null
if not available
MakeIds
- if vehicle makes are filtered, this array will list IDs of allowed makes; otherwise it will be emptySegments
- see “3. Segments” for more informationVehicleTypes
- if vehicle types are filtered, this array will list allowed types; otherwise it will be emptyVisualizer
- configuration for visualizersAlignHomeContentToTop
- home page content should be placed right at the top of the content containerBgImg
- home page background image URLBgImgOpacity
- home page background image opacityBrandColor
- theme accent colorBrandLogo
- URL of the brand logo shown on the home pageGa4Key
- Google Analytics key for tracking eventsListVehicleModelsByYear
- Separate vehicle models by yearPaginationSize
- default pagination sizeScrollIntoView
- scroll container into the viewport on user input when the embedded on a page with more contentTireLogo
- “Shop by Tire” image URLVehicleLogo
- “Shop by Vehicle” image URLVehicleThumbnails
- eithercolor
ormono
WheelLogo
- “Shop by Wheel” image URL
POST /keys/config
Update API key configuration. Propagating changes may take up to 5 minutes.
Data must be submitted in the body and be JSON-encoded:
{ "vehicleModels": { "use": "include", "modelIds": [44, 45, 46, 47] } }
where (* - required):
*
vehicleModels
- vehicle models filter*
use
-include
orexclude
to either*
modelIds
- an array of vehicle model IDs; empty array disables the filter
Example 1. JavaScript code for sending a sample request for quote:
const data = { vehicleModels: { use: "include", modelIds: [44, 45, 46] } }; const resp = await fetch(API_URL + '/keys/config?key=' + API_KEY, { method: 'POST', headers: { 'Accept': 'application/json', 'Content-Type': 'application/json' }, body: JSON.stringify(data) }); console.log(await resp.json());
Response:
{ "Status": "OK" }
5. Errors
In case of an error, HTTP status will be different than 200
and an error message will be included.
Example 1. Invalid path:
/wheels/unknown
Response (HTTP status 404
):
{ "Error": "Unknown endpoint" }
Example 2. Invalid parameter value:
/vehicles/makes?f-year=99999
Response (HTTP status 400
):
{ "Error": "Invalid value for query parameter: f-year" }
Example 3. Implementation error that needs to be addressed by AutoSync (response HTTP status 500
):
{ "Error": "Query error" }
HTTP status 200
and no error
property signify a successful response.
6. Pagination
Every endpoint returning a single collection includes pagination information:
MoreItems
-true
orfalse
denoting the end of a collection or additional records on the next page
By default, collections are limited to 10 records per page.
Example 1. The first page of 10 Ford models (out of 51 in total):
/vehicles/models?f-make=Ford
Response:
{ "Models": [{ "Id": 8791, "Make": "Ford", "Model": "Bronco" }, { "Id": 8070, "Make": "Ford", "Model": "E-150" }, ... ], "MoreItems": true }
All endpoints may include query parameters for specifying pagination settings:
p-number
- page number beginning at 1p-size
- page size, i.e the number of collection items to be fetched (1-500)
Example 2. The last of three 25-item pages of Ford’s models:
/vehicles/models?f-make=Ford&p-size=25&p-number=2
Response:
{ "Models": [{ "Id": 33175, "Make": "Ford", "Model": "F-150 Lightning" }, ... ] }
Endpoints containing objects with multiple collections, e.g. /wheels/filters
, do not include pagination information.
Example 3. No page indicators for collections under filters (models and diameters):
/wheels/filters?i-models&i-diameters&f-brand=Vision
Response:
{ "Filters": { "Models": ["Daytona", "Wizard", "Rage", ...], "Diameters": [15, 17, 20, ...] } }
7. Vehicle Endpoints
All endpoints in this section require authorization. For more information see “2. Authorization”.
GET /vehicles/years
A list of all supported vehicle years.
Optional query parameters:
Filters
f-make
- filter by makef-model
- filter by modelf-submodel
- filter by sub model
Results are sorted by year in ascending order.
Example 1. All supported years (page size increased to 100 to include all results):
/vehicles/years?p-size=100
Response:
{ "Years": [2000, 2001, 2002, ...] }
Example 2. Years for Audi A4 Sport:
/vehicles/years?f-make=Audi&f-model=A4&f-submodel=Sport
Response:
{ "Years": [2010, 2011, 2012, 2013, 2014, 2015, 2016] }
GET /vehicles/makes
A list of vehicle makes.
Optional query parameters:
Data
i-logos
- include URLs to logosi-vehicleCount
- include the number of vehicles for each make (subject to the filters)
Filters
f-year
- filter by yearf-types
- filter by comma-separated vehicle types
Results are sorted by make in ascending order.
Supported vehicle types:
Car
SUV
Truck
UTV
Van
Example 1. A list of all makes:
/vehicles/makes
Response:
{ "Makes": [{ "Make": "Acura" }, { "Make": "Alfa Romeo" }, ... ] }
Example 2. A list of Truck or Van makes:
/vehicles/makes?f-types=Truck,Van
Response:
{ "Makes": [{ "Make": "Buick" }, { "Make": "Cadillac" }, ... ] }
Example 3. A list of makes that manufactured vehicles in 2012 with their logos and the total number of vehicles released that year:
/vehicles/makes?f-year=2012&i-logos&i-vehicleCount
Response:
{ "LogoUrlBase: "https://storage.googleapis.com/autosync-brand-logos/vehicles/", Makes: [{ Make: "Audi", Logo: "Audi.png", VehicleCount": 49 }, ... ] }
Appending Logo
to LogoUrlBase
composes a complete logo image URL, for example:
https://storage.googleapis.com/autosync-brand-logos/vehicles/Audi.png
Do not hardcode LogoUrlBase
or parts of it as it may change.
GET /vehicles/models
A list of vehicle models.
Optional query parameters:
Data
i-img001
- include URLs of side angle images in the default colori-img014
- include URLs of rear angle images in the default colori-img032
- include URLs of front angle images in the default colori-year
- include years for each vehicle modeli-maxYear
- include the latest year for each vehicle model (e.g2019
for Jaguar XJ which was discontinued in 2020); wheni-year
parameter is used,i-maxYear
will have the same valuei-imgYear
- include the year of the vehicle in the image (may be different than the year of the vehicle); takes effect only if any images are includedi-body
- include body type; the same model will be listed multiple times if it’s available in multiple body types (e.g. “Hatchback” and “Sedan”)i-type
- include vehicle type; the same model will be listed multiple times if it’s available in multiple vehicle types (e.g. “Truck” and “SUV”)
Filters
f-year
- filter by yearf-make
- filter by makef-types
- filter by comma-separated vehicle typesf-query
- filter by a full-text search query, e.g. “Ford Mustang”f-imgColor
- specify preferred image colors:rand
– random colors (default),mono
– prefer monochromatic colors; takes effect only if any images are included
Global Filters
gf-vehicleModels
- enable/disable API key-level filter for vehicle models;true
- enable (default),false
- disable
Results are sorted by make and model in ascending order.
For more information on how to filter vehicle models by vehicle types, see /vehicles/makes
.
Example 1. A list of models by year and make:
/vehicles/models?f-year=2012&f-make=Audi
Response:
{ "Models": [{ "Id": 2778, "Make": "Audi", "Model": "A3" }, { "Id": 4365, "Make": "Audi", "Model": "A3 Quattro" }, ... ] }
Example 2. Mustang models:
/vehicles/models?f-query=Mustang
Response:
{ "Models": [{ "Id": 1164, "Make": "Ford", "Model": "Mustang" }, { "Id": 7857, "Make": "Ford", "Model": "Mustang Mach-E" } ] }
Example 3. 2018 Mazda models with body types:
/vehicles/models?f-year=2018&f-make=Mazda&i-body
Response:
{ "Models": [{ "Id": 2487, "Make": "Mazda", "Model": "3", "Body": "Hatchback" }, { "Id": 2487, "Make": "Mazda", "Model": "3", "Body": "Sedan" }, ... ] }
Example 4. 2009 Hummer H2 models with vehicle types:
/vehicles/models?f-query=2009 Hummer H2&i-type
Response:
{ "Models": [{ "Id": 6700, "Make": "Hummer", "Model": "H2", "Type": "SUV" }, { "Id": 6700, "Make": "Hummer", "Model": "H2", "Type": "Truck" } ] }
Example 4. Ford Freestyle model split by year:
/vehicles/models?f-query=Ford Freestyle&i-year
Response:
{ "Models": [{ "Id": 2619, "Make": "Ford", "Model": "Freestyle", "Year": 2007 }, { "Id": 2618, "Make": "Ford", "Model": "Freestyle", "Year": 2006 }, ... ] }
Example 5. Filter by year (2016), make (“BMW”) and include images in the default color for each model together with the years of the vehicles in the images:
/vehicles/models?f-year=2016&f-make=bmw&i-img032&i-imgYear
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-vehicles/", "Models": [{ "Id": 2316, "Make": "BMW", "Model": "228i", "ImgYear": 2016, "Img032": { "240": "10631/10631_240_032_B45.webp", "350": "10631/10631_350_032_B45.webp", "640": "10631/10631_640_032_B45.webp", "960": "10631/10631_960_032_B45.webp", "2400": "10631/10631_2400_032_B45.webp" }, ... ] }
Appending image path to ImgUrlBase
composes a complete image URL, for example:
https://storage.googleapis.com/autosync-vehicles/10631/10631_2400_032_B45.webp
Do not hardcode ImgUrlBase
or parts of it as it may change.
GET /vehicles/submodels
A list of vehicle sub models.
Optional query parameters:
Data
i-img001
- include URLs of side angle images in the default colori-img014
- include URLs of rear angle images in the default colori-img032
- include URLs of front angle images in the default colori-body
- include body type; the same sub model will be listed multiple times if it’s available in multiple body types
Filters
f-year
- filter by yearf-make
- filter by makef-model
- filter by modelf-query
- filter by a full-text search query, e.g. “Volvo V90”f-types
- filter by comma-separated vehicle typesf-imgColor
- specify preferred image colors:rand
– random colors (default),mono
– prefer monochromatic colors; takes effect only if any images are included
Results are sorted by make, model and submodel in ascending order.
For more information on how to filter vehicle sub models by vehicle types, see /vehicles/makes
.
Example 1. A list of 2012 Audi A4 sub models:
/vehicles/submodels?f-year=2012&f-make=Audi&f-model=A4
Response:
{ "Submodels": [{ "Make": "Audi", "Model": "A4", "Submodel": "Base" } ] }
Example 2. A list of 2010 Honda Civic sub models:
/vehicles/submodels?f-year=2010&f-make=Honda&f-model=Civic&i-body
Response:
{ "Submodels": [{ "Make": "Honda", "Model": "Civic", "Submodel": "DX", "Body": "Coupe" }, { "Make": "Honda", "Model": "Civic", "Submodel": "DX", "Body": "Sedan" }, ... ] }
Example 3. Full-text search results for “2020 jag I-Pace“:
/vehicles/submodels?f-query=2020%20jag%20I-Pace
Response:
{ "Submodels": [{ "Make": "Jaguar", "Model": "I-Pace", "Submodel": "HSE" }, ... ] }
Example 4. A list of Ford F-150 sub models manufactured in 2020 with 032 angle images 960 px wide in the default color:
/vehicles/submodels?f-year=2020&f-make=Ford&f-model=F-150&i-img032
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-vehicles/", "Submodels": [{ "Make": "Ford", "Model": "F-150", "Submodel": "King Ranch", "Img032": { "240": "14114/14114_240_032_N1-D1.webp", "350": "14114/14114_350_032_N1-D1.webp", "640": "14114/14114_640_032_N1-D1.webp", "960": "14114/14114_960_032_N1-D1.webp", "2400": "14114/14114_2400_032_N1-D1.webp" }, ... ] }
Appending image path to ImgUrlBase
composes a complete image URL, for example:
https://storage.googleapis.com/autosync-vehicles/14112/14112_2400_032_JS.webp
Do not hardcode ImgUrlBase
or parts of it as it may change.
GET /vehicles
A list of vehicles.
Optional query parameters:
Data
i-img001
- include URLs of side angle images in the default colori-img014
- include URLs of rear angle images in the default colori-img032
- include URLs of front angle images in the default colori-colors
- include a list of available colorsi-coordinates
- include coordinates for selected angles (001
,024
,032
) with wheel anglesi-fitments
- include OE fitmentsi-optionalFitments
- include OE optional fitmentsi-plusSizes
- include an extended range of fitment optionsi-tags
- include tags and niche tag
Filters
f-id
- filter by vehicle IDf-year
- filter by yearf-make
- filter by makef-model
- filter by modelf-submodel
- filter by sub modelf-types
- filter by comma-separated vehicle typesf-body
- filter by body typef-colorId
- specify image color by ID; takes precedence overf-imgColor
f-imgColor
- specify image color:rand
– random color (default),mono
– prefer monochromatic color;f-colorId
parameter takes precedence if both are specified
Results are sorted by year in descending order.
For more information on how to filter vehicles by types, see /vehicles/makes
.
A. Filtering Vehicles
Example 1. Vehicles filtered by year, make, model, and sub model:
/vehicles?f-year=2018&f-make=Mazda&f-model=3&f-submodel=Touring
Response:
{ "Vehicles": [{ "Bed": "", "Body": "Hatchback", "Doors": null, "Drw": false, "Id": 11693, "Make": "Mazda", "Model": "3", "Submodel": "Touring", "Type": "Car", "Year": 2018 }, { "Bed": "", "Body": "Sedan", "Doors": null, "Drw": false, "Id": 11695, "Make": "Mazda", "Model": "3", "Submodel": "Touring", "Type": "Car", "Year": 2018 } ] }
Example 2. Vehicles filtered by year, make, model, sub model, and body type:
/vehicles?f-year=2018&f-make=Mazda&f-model=3&f-submodel=Touring&f-body=Sedan
Response:
{ "Vehicles": [{ "Bed": "", "Body": "Sedan", "Doors": null, "Drw": false, "Id": 11695, "Make": "Mazda", "Model": "3", "Submodel": "Touring", "Type": "Car", "Year": 2018 } ] }
B. Fetching Vehicle by ID
Example. Vehicle with ID equal to 3635:
/vehicles?f-id=3635
Response:
{ "Vehicles": [{ "Bed": "", "Body": "Sedan", "Doors": null, "Drw": false, "Id": 3635, "Make": "Dodge", "Model": "Charger", "Submodel": "SRT Hellcat Widebody", "Type": "Car", "Year": 2021 } ] }
C. Image URLs
Supported sizes (width in pixels):
2400
– 2400 px × 1250 px960
- 960 px × 522 px640
- 640 px × 348 px350
- 350 px × 190 px240
- 240 px × 130 px
Example. Including images of angles 001 and 014:
/vehicles?f-id=5851&i-img001&i-img014
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-vehicles/", "Vehicles": [{ "Bed": "", "Body": "Coupe", "Doors": null, "Drw": false, "Id": 5851, "Img001": { "240": "13780/13780_240_001_E7.webp", "350": "13780/13780_350_001_E7.webp", "640": "13780/13780_640_001_E7.webp", "960": "13780/13780_960_001_E7.webp", "2400": "13780/13780_2400_001_E7.webp" }, "Img014": { "240": "13780/13780_240_014_E7.webp", "350": "13780/13780_350_014_E7.webp", "640": "13780/13780_640_014_E7.webp", "960": "13780/13780_960_014_E7.webp", "2400": "13780/13780_2400_014_E7.webp" }, "ImgColorId": 130664, "Make": "Ford", "Model": "Mustang", "Submodel": "Shelby GT350R", "Type": "Car", "Year": 2019 } ] }
Appending image path to ImgUrlBase
composes a full resource URL, for example:
https://storage.googleapis.com/autosync-vehicles/13780/13780_2400_001_E7.webp
If an image in a given size is not available, null
value will be returned.
Do not hardcode ImgUrlBase
or parts of it as it may change.
ImgColorId
indicates which color was selected for the images.
D. Selecting a Preferred Color
Image URL query parameters may be combined with f-colorId
in order to specify a desired color.
Example. Vehicle ID 5851 in color ID 130664 (“Velocity Blue”):
/vehicles?f-id=5851&i-img032&f-colorId=130664
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-vehicles/", "Vehicles": [{ "Bed": "", "Body": "Coupe", "Doors": null, "Drw": false, "Id": 5851, "Img032": { "240": "13780/13780_240_032_E7.webp", "350": "13780/13780_350_032_E7.webp", "640": "13780/13780_640_032_E7.webp", "960": "13780/13780_960_032_E7.webp", "2400": "13780/13780_2400_032_E7.webp" }, "ImgColorId": 130664, "Make": "Ford", "Model": "Mustang", "Submodel": "Shelby GT350R", "Type": "Car", "Year": 2019 } ] }
If f-colorId
is not specified, the default color of a vehicle will be selected.
E. Available colors
To include a list of available colors for each vehicle, append i-colors
parameter with no value.
Example. A vehicle with a list of its colors:
/vehicles?f-id=5851&i-colors
Response:
{ "SwatchUrlBase": "https://storage.googleapis.com/autosync-colors/", "Vehicles": [{ "Bed": "", "Body": "Coupe", "Colors": [{ "Id": 130662, "Code": "AJ", "Name": "Need For Green", "ShortName": "Green", "Rgb1": "1E7038", "Rgb2": "", "Swatch": "1E7038.png", "Img001": true, "Img014": true, "Img032": true }, ... ] } ] }
Appending Swatch
to SwatchUrlBase
composes a complete color swatch URL, e.g.:
https://storage.googleapis.com/autosync-colors/5E5D63.png
Each object under Colors
includes Img001
, Img014
, and Img032
properties. They signify whether a vehicle image is available for a given angle and in the color.
F. Fitment Data
See the section below for the latest iteration.
See Tire Endpoints section for the definitions of the nomenclature.
To include fitment data—i.e. bolt pattern, general tags, and niche tag—append i-fitment
to the URL.
Niche tags identify wheels (and their corresponding vehicles) that are made for specific vehicles only.
Example. A vehicle with fitment data:
/vehicles?f-id=385&i-fitment
Response:
{ "Vehicles": [{ "Bed": "", "Body": "Coupe", "BoltCircle": 130, "Doors": null, "Drw": false, "Id": 385, "LugCount": 5, "Make": "Porsche", "Model": "911", "NicheTag": "Porsche", "Submodel": "Carrera", "Tags": [ "Luxury", "Replica" ], "Type": "Car", "Year": 2021 } ] }
Beta Functionality – available in development only.
Appending i-fitments
and i-optionalFitments
to the URL includes OE and OE optional fitments. In addition, i-tags
includes tags, and niche tags. Each fitment is compatible with the vehicle without a need for modifications.
Niche tags identify wheels (and their corresponding vehicles) that are made for specific vehicles only. They are used primarily for replica wheels made for specific vehicles.
In addition to OE fitments, plus sizes may be requested with i-plusSizes
parameter. Plus sizes will only be returned if fitments are requested. Plus sizes are intended for the tuning market. They can be used to show the aftermarket wheel fitment sizes, and tire sizes for that wheel size. Plus size notes provide information on special requirements.
Note. Plus sizes must be matched with fitments by ConfigId
.
Typically, a vehicle would have a few fitments sharing the same config and multiple plus size for each config. Each config is identified by ConfigId
and described by ConfigName
. For example, vehicle ID 83184 has two configs:
"ConfigId": 70429, "ConfigName": "19\""
- 2 fitments, 14 plus sizes"ConfigId": 92428, "ConfigName": "Ceramic Brake Package"
- 1 fitment, 9 plus sizes
Depending on which OE fitment is selected by the end user, either the 14 or the 9 plus sizes may be offered with additional wheel/tire sizes.
Example. A vehicle with OE fitments and plus sizes:
/vehicles?f-id=37963&i-fitments&i-tags
Response:
{ "Vehicles": [{ "Bed": "", "Body": "Coupe", "Doors": null, "Drw": false, "Fitments": [{ "AspectRatio": 70, "AspectRatioRear": null, "BoltCircle": 135, "Bore": 87.1, "BoreRear": null, "ConfigId": 58102, "ConfigName": "18\"", "Diameter": null, "DiameterRear": null, "Format": "M", "InchWidth": null, "InchWidthRear": null, "LugCount": 6, "MaxOffset": 44, "MaxOffsetRear": null, "MaxWheelLoad": 930, "MinOffset": 5, "MinOffsetRear": null, "RimDiameter": 17, "RimDiameterRear": null, "RimWidth": 7.5, "RimWidthRear": null, "SectionWidth": 245, "SectionWidthRear": null, "TireSize": "245/70R17", "TireSizeRear": null }, ... ], "Id": 385, "Make": "Porsche", "Model": "911", "NicheTag": "Porsche", "PlusSizes": [{ "AspectRatio": 70, "ConfigurationId": 58102, "Diameter": null, "Format": "M", "InchWidth": null, "MaxOffset": 44, "MinOffset": 5, "Notes": [], "RimDiameter": 17, "RimWidth": 7, "SectionWidth": 245, "TireSize": "245/70R17", "Type": "FR" }, ... ], "Submodel": "Carrera", "Tags": [ "Luxury", "Replica" ], "Type": "Car", "Year": 2021 } ] }
Format
identifies tire format:
M
- metric, e.g. “245/70R17”;SectionWidth
,AspectRatio
, andRimDiameter
will be specifiedF
- flotation, e.g. “37x12.50R17”;Diameter
,RimWidth
, andRimDiameter
will be specified.
Notes
will take a form of an empty array if there are no special requirements for the fitment. Otherwise, a list of strings will be returned, for example:
"Notes": [ "Check fitment, possible clearance issues" ],
G. Wheel coordinates
To include wheel coordinates append i-coordinates=<agnles>
to the URL where <angles>
is a comma-separated list of one or more of the following values:
001
- side angle014
- rear angle032
- front angle
Example. A vehicle with coordinates for angles 014 and 032:
/vehicles?f-id=10030&i-coordinates=014,032
Response:
{ "Vehicles": [{ "Bed": "", "Body": "Sedan", "Coordinates014": [ [0.46637, 0.54876, 0.54435, 0.76919], [0.81365, 0.52738, 0.86377, 0.70683] ], "Coordinates032": [ [0.44379, 0.54001, 0.5214, 0.76462], [0.79236, 0.51067, 0.84276, 0.69037] ], "Doors": null, "Drw": false, "Id": 10030, "InImageWheelDiameters": { "Front": 18, "FrontMax": 20, "Rear": 18, "RearMax": 20 }, "Make": "Audi", "Model": "A4 Quattro", "Submodel": "Ultra sport", "Type": "Car", "WheelAngles014": ["0100", "0100"], "WheelAngles032": ["0100", "0200"], "Year": 2020 } ] }
Wheel coordinates include two sets of four values in the following order:
x1
- top left corner’sx
valuey1
- top left corner’sy
valuex2
- bottom right corner’sx
valuey2
- bottom right corner’sy
value
Each value is expressed in percents, counting vehicle image’s top-left corner as the starting point.
Overlayed front and rear wheel images match original rims best when slightly rotated clockwise on 032
and 014
angles:
Left (larger) wheel - by 2 degrees
Right (smaller) wheel - by 1 degree.
Wheel angles specify preferred wheel angles for each vehicle angle and each wheel. For example:
"WheelAngles032": ["0100", "0200"]
indicates that the vehicle, when shown in angle 032
, should have wheel angle 0100
layered on top of the first (counting from left to right) wheel and angle 0200
over the second wheel (on the right).
Dually trucks, being an exception, and will return 0300Front
and 0300Rear
wheel angles for 001
vehicle angle (instead of 0300
for non-dually vehicles):
"WheelAngles001": ["0300Front", "0300Rear"]
InImageWheelDiameters
is a list of wheel diameters corresponding with vehicle images:
Front
- front wheel diameter as visible in the vehicle imageFrontMax
- maximum front wheel diameter visually fitting the vehicle imageRear
- rear wheel diameter as visible in the vehicle imageRearMax
- maximum rear wheel diameter visually fitting the vehicle image
Wheel coordinates are set for Front
and FrontMax
diameters and need to be proportionally scaled up for diameters between Front
and FrontMax
, and between Rear
and RearMax
.
If information for InImageWheelDiameters
is not available, a null
value will be returned:
"InImageWheelDiameters": null
H. Sample Positioning Implementation
Having the following values returned from /vehicles
endpoint:
"ImgUrlBase": "https://storage.googleapis.com/autosync-vehicles/" ... "Img032": { ... "2300": "11360/11360_2400_032_CI.webp" } ... "Coordinates032": { "Wheel1": [0.44425, 0.5158, 0.5272, 0.74908], "Wheel2": [0.79188, 0.48561, 0.84501, 0.67501] }
and the following data returned from /wheels
endpoint:
"ImgUrlBase": "https://storage.googleapis.com/autosync-wheels/" ... "Img0100": "TSW/Blanchimont_Semi-Gloss_Black_5-lug_0100.png", "Img0200": "TSW/Blanchimont_Semi-Gloss_Black_5-lug_0200.png"
we can overlay the wheels on top of the vehicles with the following HTML and CSS code:
<div class="wrapper"> <img class="vehicle-image" src="https://storage.googleapis.com/autosync-vehicles/11360/11360_2400_032_CI.webp"> <img class="left-wheel" src="https://storage.googleapis.com/autosync-wheels/TSW/Blanchimont_Semi-Gloss_Black_5-lug_0100.png"> <img class="right-wheel" src="https://storage.googleapis.com/autosync-wheels/TSW/Blanchimont_Semi-Gloss_Black_5-lug_0200.png"> </div>
.wrapper { position: relative; } .vehicle-image { width: 100%; } .left-wheel { position: absolute; left: 44.425%; top: 51.58%; width: calc(52.72% - 44.425%); height: calc(74.908% - 51.58%); transform: rotate(2deg); } .right-wheel { position: absolute; top: 48.561%; left: 79.188%; width: calc(84.501% - 79.188%); height: calc(67.501% - 48.561%); transform: rotate(1deg); }
Live CodePen example:
https://codepen.io/m-autosync/pen/BapjrqY
GET /vehicles/vehicle/[vehicleId]/accessories
Beta Functionality – available in development only.
A list of accessories for a requested vehicle.
Required URI parameters:
*
vehicleId
- vehicle ID
Optional query parameters:
Data
i-imgVov
- include accessory VoV images for selected angles together with coordinates and rotation angles; a comma-separated list of one or more of the following values:001
,014
,032
i-vehicleImg
- include vehicle images for selected angles; a comma-separated list of one or more of the following values:001
,014
,032
i-commonMinScale
- some accessories may require different vehicle scales to fit them on top of vehicle images; the scales may differ not only between vehicles but also vehicle angles (for example a hitch bike rack may require a smaller scale for angle001
); this parameter includes at least one scale that is the same for all vehicle angles (001
,014
,032
) for a given vehicle and accessory; it takes effect only ifi-imgVov
is specified
Filters
f-vehicleColorId
- specify vehicle color by ID; takes precedence overf-vehicleColor
f-vehicleColor
- specify vehicle image color:rand
– random color (default),mono
– prefer monochromatic color;f-vehicleColorId
parameter takes precedence if both are specified
Example 1. List accessories with their coordinates and images for all angles for vehicle ID 38050 (2021 Ford F-150 XL Extended Cab):
/vehicles/vehicle/38050/accessories?i-imgVov=32&i-vehicleImg=32
Response:
{ "AccessoriesImgUrlBase": "https://storage.googleapis.com/autosync-accessories/", "Vehicle": { "Accessories": [{ "BaseAccessoryIds": [ 14 ], "Coordinates032": [{ "Coordinates": [ 0.5581, 0.23113, 0.72682, 0.38212 ], "Scale": 0.9 }, { "Coordinates": [ 0.56455, 0.20126, 0.75202, 0.36902 ], "Scale": 1 } ], "Description": "Racks and Carriers by THULE - Cargo Basket, Rack-Mounted With Net", "Id": 3, "ImgVov032": [ "pcw7PhX5J50kfmKFruzyew__.webp", null ], "PartNumber": "VJT4Z7855100C", "Rotation032": 0 } }, ... ]}, "Img032": { "240": "14890/14890_240_032_E7.webp", "350": "14890/14890_350_032_E7.webp", "640": "14890/14890_640_032_E7.webp", "960": "14890/14890_960_032_E7.webp", "2400": "14890/14890_2400_032_E7.webp" } }, "VehicleImgUrlBase": "https://storage.googleapis.com/autosync-vehicles/" }
Base Accessories
Accessories can depend on other accessories to be properly visualized. For example a cargo box may require a roof rack. BaseAccessoryIds
provide a list of IDs of alternative accessories required by the main accessory. Any one from the list may be selected.
"BaseAccessoryIds": [ 14 ],
The image above shows an accessory (green rectangle) with its dependent accessory (orange rectangle).
Coordinates
Visualizing accessories may require scaling down vehicle images. For each angle (001
, 014
or 032
), there may be a set of different vehicle scales. The biggest, is the maximum scale for which the accessory stays within the canvas of the requested vehicle image. Smaller scales are provided to match other accessories that require smaller scales.
"Coordinates001": [{ "Coordinates": [ 0.57587, 0.25752, 0.62611, 0.4054 ], "Scale": 0.8 }, { "Coordinates": [ 0.58536, 0.22721, 0.64188, 0.39358 ], "Scale": 0.9 }, ... ],
In the example above, the accessory requires scaling the vehicle image down to 90% or less. 0.8
coordinates are provided because another accessory returned in the response requires 80% scale. When two accessories are overlaid on a vehicle, the highest common scale should be used.
The values are adjusted for each scale.
Coordinates are provided in four-element arrays: x1, y1, x2, y2:
{ "Coordinates": [ - coordinates for vehicle image when scaled to 90% 0.58536, - x1 0.22721, - y1 0.64188, - x2 0.39358 - y2 ], "Scale": 0.9 - vehicle image scale }
Top left corner of a vehicle image is the (0,0) point.
In some cases, vehicle scales may be different for different vehicle angles. For example Yakima - Hitch Mounted Snow Sport requires a smaller scale on angle 001
.
However, if it’s desired to preserve vehicle scale between different angles, i-commonMinScale
parameter may be added which will ensure at least one common scale will be included between vehicle angles.
A common scale between different accessories is always included.
Images
Two accessory images are returned for each angle:
"ImgVov032": [ "pcw7PhX5J50kfmKFruzyew__.webp", - back null - front ],
Any of them can be null
. The first image (back) is meant to be placed behind a vehicle image and the second (front) on top of it.
When positioning images, their coordinates should be applied to both images in the same way.
In addition to coordinates, accessory images may require rotation. Same as for coordinates, rotation should be applied the same way for both images (back and front). Rotation requirements are provided by Rotation001
, Rotation014
or Rotation032
.
8. Wheel Endpoints
All endpoints in this section require authorization. For more information see “2. Authorization”.
GET /wheels/brands
A list of wheel brands.
Optional query parameters:
Data
i-logos
- include brand logosi-about
- include brand’s about informationi-wheelCount
- include the total number of wheels for each brand
Example 1. All brands:
/wheels/brands
Response:
{ "Brands": [{ "Id": 9, "Brand": "Black Rhino" }, { "Id": 11, "Brand": "Bravado" }, ... ] }
Example 2. All brands with their logos and the number of wheels:
/wheels/brands?i-logos&i-wheelCount
Response:
{ "BrandLogosUrlBase": "https://storage.googleapis.com/autosync-brand-logos/wheels/", "Brands": [{ "Id": 9, "Brand": "Black Rhino", "Logo": "Black_Rhino.png", "WheelCount": 4119 }, ... ] }
Appending Logo
to BrandLogosUrlBase
composes a complete logo image URL, for example:
https://storage.googleapis.com/autosync-brand-logos/wheels/Black_Rhino.png
Do not hardcode BrandLogosUrlBase
or parts of it as it may change.
GET /wheels/filters
A list of wheel filters.
Optional query parameters:
Data
i-brands
- include a list of brandsi-brandLogos
- include brand logos together with brand namesi-shortFinishes
- include a list of short (simplified) finishesi-tags
- include a list of tagsi-diameters
- include a list of diametersi-widths
- include a list of widthsi-offsets
- include a list of offsetsi-prices
- include a price range
Filters
f-brand
- filter by brandf-diameters
- filter by comma-separated diameters [inch]f-widths
- filter by comma-separated widths [inch]f-tags
- filter by tags; commas (,
) act as OR operators and plus signs (+
) or spaces as AND operators (e.g.suv,truck+luxury
for SUV or truck wheels that are labeled as luxury)f-lugCount
- filter by lug count (e.g.5
or6
)f-boltCircle
- filter by either of the bolt circles: bolt circle 1 or bolt circle 2 (e.g.139.70
or114.30
); values are in mmf-shortFinishes
- filter by comma-separated short (simplified) finishes (e.g.satin
orgloss
)
Example 1. All diameters:
/wheels/filters?i-diameters
Response:
{ "Filters": { "Diameters": [8, 10, 11, 12, ...] } }
Example 2. Diameters filtered by “TNT” brand:
/wheels/filters?i-diameters&f-brand=TNT
Response:
{ "Filters": { "Diameters": [16, 17, 18, 20] } }
Example 3. Brands, short finishes, diameters, offsets, and price range filtered by “Vision” brand:
/wheels/filters?i-brands&i-shortFinishes&i-diameters&i-offsets&i-prices&f-brand=Vision
Response:
{ "Filters": { "Brands": ["Vision"], "ShortFinishes": ["Chrome", "Gloss", "Machined", ...], "Diameters": [10, 12, 13, ...], "Offsets": [-143, -137, -76, ...], "Prices": { "Min": 165, "Max": 349 } } }
Example 4. Brands with logos filtered by “Classic” tag:
/wheels/filters?i-brands&i-brandLogos&f-tags=Classic
Response:
{ "BrandLogosUrlBase": "https://storage.googleapis.com/autosync-brand-logos/products/", "Filters": { "Brands": [{ "Brand": "Allied", "Logo": "Allied.png" }, { "Brand": "American Legend", "Logo": "American_Legend.png" }, ... ] } }
Example 5. Brands that have wheels with bolt circle 1 or bolt circle 2 equal to 114 mm:
/wheels/filters?i-brands&f-boltCircle=114
Response:
{ "Filters": { "Brands": ["Ace Alloy", "Kansei", "Momo", ...] } }
GET /wheels/filters/combinations
A list of combinations of wheel filter values. It’s meant for building UI filters that don’t need to send requests as users make selections, since all possible combinations are known.
Sample UI powered by filter combinations:
Optional query parameters:
Data
i-brand
- include all combinations of brandsi-brandLogo
- include brand logos; it requires brand to be includedi-diameter
- include all combinations of diametersi-width
- include all combinations of widthsi-accent
- include all combinations of accentsi-shortColor
- include all combinations of short colorsi-shortFinish
- include all combinations of short finishesi-tags
- include all combinations of tagsi-wheelStyleCount
- include the number of wheel styles for each combination
Filters
f-brand
- filter by brandf-diameters
- filter by comma-separated diameters [inch]f-widths
- filter by comma-separated widths [inch]f-tags
- filter by tags; commas (,
) act as OR operators and plus signs (+
) or spaces as AND operators (e.g.suv,truck+luxury
for SUV or truck wheels that are labeled as luxury)f-lugCount
- filter by lug count (e.g.5
or6
)f-boltCircle
- filter by either of the bolt circles: bolt circle 1 or bolt circle 2 (e.g.139.70
or114.30
); values are in mmf-minBore
- filter by minimum bore [mm]f-nicheTag
- filter by niche tag;N/A
– only wheels for vehicles with no niche tag set, any other value will include wheels with the specified niche tag and with no niche tag set, e.g.Lexus ES
– wheels with either no niche tag set or for Lexus ES vehicles
Example 1. All brand, diameter, short color, and tag combinations of 5-lug off-road wheels with bolt circle 112 mm for trucks or SUVs:
/wheels/filters/combinations?i-brand&i-diameter&i-shortColor&i-tags&f-lugCount=5&f-boltCircle=112&f-tags=Truck,SUV+Off-road&p-size=500
Response:
{ "FilterCombinations": [{ "Brand": "Method", "Diameter": 16, "ShortColor": "Black", "Tags": ["Off-Road", "Truck", "SUV"] }, ... ] }
Some filter combinations (and lack thereof) may exceed the maximum page size and the results will have to be fetched with multiple requests.
GET /wheels/styles
A list of wheel styles.
Optional query parameters:
Data
i-img0001
- include a URL of 0001 angle (standard) imagei-img0002
- include a URL of 0002 angle (beauty) imagei-img0003
- include a URL of 0003 angle (face) imageDEPRICATED
i-imgSelectedValues
- renamed toi-imgDetails
i-imgDetails
- include details of the selected images that represent the style (e.g. color, diameter or short finish); wheel styles may include wheels of multiple colors or diametersi-wheelCount
- include the total number of wheels for each wheel stylei-specs
- include specification datai-tags
- include tagsi-description
- include descriptioni-features
- include feature benefits (1-4)i-diameters
- include a list of diameters for each stylei-offsets
- include a list of offsets for each stylei-sizes
- include a list of sizes for each style; a size is a combination of diameter and width, e.g. “18x9”i-shortColors
- include a list of short colors for each stylei-shortFinishes
- include a list of short finishes for each style
Filters
f-id
- filter by wheel style IDf-brand
- filter by brandf-boltCircle
- filter by either of the bolt circles: bolt circle 1 or bolt circle 2 (e.g.139.70
or114.30
); values are in mmf-diameters
- filter by comma-separated diameters [inch]f-diameters2
- filter by secondary comma-separated diameters [inch]; specifyingf-diameters
andf-diameters2
will list only wheel styles with wheels of both diameters; intended for vehicles with staggered fitmentf-widths
- filter by comma-separated widths [inch]f-widths2
- filter by secondary comma-separated widths [inch]; specifyingf-widths
andf-widths2
will list only wheel styles with wheels of both widths; intended for vehicles with staggered fitmentf-minBore
- filter by minimum bore [mm]f-minLoadRating
- filter by minimum load rating [lbs]f-minOffset
- filter by minimum offsetf-maxOffset
- filter by maximum offsetf-material
- filter by material (e.g. “Cast Aluminum”)f-shortColors
- filter by comma-separated short (simplified) colors (e.g.black
orgold
)f-shortFinishes
- filter by comma-separated short (simplified) finishes (e.g.satin
orgloss
)f-structure
- filter by structure (e.g. “1-Piece”)f-lugCount
- filter by lug count (e.g.5
or6
)f-lugType
- filter by lug type (e.g. “Conical”)f-exposedLugs
- filter by exposed or covered lugs;0
- false (covered),1
- true (exposed)f-tags
- filter by tags; commas (,
) act as OR operators and plus signs (+
) or spaces as AND operators (e.g.suv,truck+luxury
for SUV or truck wheels that are labeled as luxury)f-nicheTag
- filter by niche tag;N/A
– only wheels for vehicles with no niche tag set, any other value will include wheels with the specified niche tag and with no niche tag set, e.g.Lexus ES
– wheels with either no niche tag set or for Lexus ES vehiclesf-query
- filter by a full-text search query based on the following fields: part number, brand, model, sub model, bolt pattern (e.g.5x130
), short color, short finish, tags, and niche tag
Sorting
s-model
- sort by model (asc
ordesc
)
Example 1. Styles filtered by “Black Rhino” brand with wheel count:
/wheels/styles?f-brand=Black%20Rhino&i-wheelCount
Response:
{ "WheelStyles": [{ "Brand": "Black Rhino", "Id": 149, "Model": "Coyote", "Submodel": null, "WheelCount": 37 }, ... ] }
Example 2. A list of styles with forged aluminum wheels that includes specification data, 0001 angle images and a list of short colors:
/wheels/styles?f-material=Forged Aluminum&i-specs&i-img0001&i-shortColors&i-imgDetails
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-wheels/", "WheelStyles": [{ "Brand": "Victor Equipment", "ExposedLugs": true, "Id": 1128, "Img0001": "Victor_Equipment/Lohner-Forged_Matte_Black_5-lug_0001.png", "ImgAccent": "", "ImgColor": "Black", "ImgDiameter": 19, "ImgFinish": "Matte", "ImgOffset": 36, "ImgShortColor": "Black", "ImgShortFinish": "Matte", "ImgWheelId": 29797, "ImgWidth": 11, "LugType": "Conical", "Material": "Forged Aluminum", "Model": "Lohner Forged", "ShortColors": ["Black"], "Structure": "1-Piece", "Submodel": null }, ... ] }
Appending Img<angle>
to ImgUrlBase
composes a complete image URL, for example:
https://storage.googleapis.com/autosync-wheels/Vision/Assassin_396_Matte_Black_6-lug_0001.png
Do not hardcode ImgUrlBase
or parts of it as it may change.
When i-imgDetails
query parameter is present and at least one image URL is requested, results will include additional information describing the image:
ImgWheelId
ImgDiameter
ImgOffset
ImgAccent
ImgColor
ImgShortColor
ImgFinish
ImgShortFinish
Example 3. Styles filtered by “Drag” brand with specs:
/wheels/styles?f-brand=Drag&i-specs&i-tags
Response:
{ "WheelStyles": [{ "Brand": "Drag", "ExposedLugs": true, "Id": 11574, "LugType": "Conical", "Material": "Cast Aluminum", "Model": "DR-11", "Structure": "1-Piece", "Submodel": "GBML", "Tags": ["Car", "Luxury"] }, ... ] }
Example 4. Off-road wheel styles for trucks and SUVs:
/wheels/styles?f-tags=Off-Road+Truck,SUV
Response:
{ "WheelStyles": [{ "Brand": "American Racing", "Id": 3, "Model": "AR767", "Submodel": null }, ... ] }
Example 5. Wheel styles with no niche tag assigned and those with niche tag set to “Porsche 911-991”:
/wheels/styles?f-nicheTag=Porsche 911-991
Response:
{ "WheelStyles": [{ "Brand": "American Racing", "Id": 6983, "Model": "Fast Back", "Submodel": "VN806 GY" }, ... ] }
Niche tags link aftermarket wheels made for specific vehicles only with the vehicles. Some examples include:
Beyern - BMW
Coventry - Jaguar
Mandrus - Mercedes
Factory Reproductions FR 54 - Ford Mustang
Factory Reproductions FR 85 - Audi
Factory Reproductions FR 62 - Dodge Challenger
Example 6. Black Rhino wheel styles with sizes, offsets and short finishes:
/wheels/styles?f-brand=Black Rhino&i-shortFinishes&i-offsets&i-sizes
Response:
{ "WheelStyles": [{ "Brand": "Black Rhino", "Id": 149, "Model": "Coyote", "Offsets": [-18, 2, 6, 12], "ShortFinishes": ["Gloss"], "Sizes": ["17x9", "18x9", "20x9"], "Submodel": null }, ... ] }
Example 7. ATX wheels styles with 205x130 bolt pattern:
/wheels/styles?f-query=ATX 6x135
Response:
{ "WheelStyles": [{ "Brand": "ATX", "Id": 101, "Model": "AX203", "Submodel": null } ] }
Example 8. Fuel wheels styles that have wheels of two specified widths:
/wheels/styles?f-brand=Fuel&f-widths=8&f-widths2=10&i-diameters&i-offsets&i-sizes&i-wheelCount
Response:
{ "WheelStyles": [{ "Brand": "Fuel", "Diameters": [15, 16, 18], "Diameters2": [15, 20], "Id": 395, "Model": "Anza", "Offsets": [-18, 1, 27], "Offsets2": [-43, -18], "Sizes": ["15x8", "16x8", "18x8"], "Sizes2": ["15x10", "20x10"], "Submodel": "D557", "WheelCount": 4, "WheelCount2": 4 } ] }
When two diameters and/or two widths are specified, values that may differ between wheels of the two sizes will be listed separately, for example Offsets
will list all offsets of the first size, and Offsets2
will list all offsets of the second size.
Example 9. Fuel wheels styles that have 15” wheels of two specified widths (same as above but restricting wheel diameter):
/wheels/styles?f-brand=Fuel&f-diameters=15&f-diameters2=15&f-widths=8&f-widths2=10&i-diameters&i-offsets&i-sizes&i-wheelCount
Response:
{ "WheelStyles": [{ "Brand": "Fuel", "Diameters": [15], "Diameters2": [15], "Id": 395, "Model": "Anza", "Offsets": [-18], "Offsets2": [-43], "Sizes": ["15x8"], "Sizes2": ["15x10"], "Submodel": "D557", "WheelCount": 1, "WheelCount2": 3 } ] }
GET /wheels
A list of wheels.
Optional query parameters:
Data
i-specs
- include specificationi-cap
- include center cap informationi-description
- include descriptioni-features
- include feature benefits (1-4)i-tags
- include tagsi-img0001
- include a URL of 0001 angle (standard) imagei-img1001
- include a URL of 1001 angle (high resolution standard) imagei-img0002
- include a URL of 0002 angle (beauty) imagei-img0003
- include a URL of 0003 angle (face) imagei-img0100
- include a URL of 0100 angle (VoV front) imagei-img0200
- include a URL of 0200 angle (VoV rear) imagei-img0300
- include a URL of 0300 angle (VoV face) image;0300
in case of regular wheels,0300Front
and0300Rear
in case of dually wheels
Filters
f-ids
- filter by comma-separated wheel IDs (e.g.11503,11499
)f-styleId
- filter by style IDf-pn
- filter by part numberf-brand
- filter by brandf-boltCircle
- filter by either of the bolt circles: bolt circle 1 or bolt circle 2 (e.g.139.70
or114.30
); values are in mmf-lugCount
- filter by lug count (e.g.5
or6
)f-model
- filter by modelf-submodel
- filter by sub modelf-shortColors
- filter by comma-separated short (simplified) colors (e.g.black
orgold
)f-shortFinishes
- filter by comma-separated short (simplified) finishes (e.g.satin
orgloss
)f-diameters
- filter by comma-separated diameters [inch]f-widths
- filter by comma-separated widths [inch]f-minBore
- filter by minimum bore [mm]f-minLoadRating
- filter by minimum load rating [lbs]f-minOffset
- filter by minimum offsetf-maxOffset
- filter by maximum offsetf-minPrice
- filter by minimum pricef-maxPrice
- filter by maximum pricef-tags
- filter by tags; commas (,
) act as OR operators and plus signs (+
) or spaces as AND operators (e.g.suv,truck+luxury
for SUV or truck wheels that are labeled as luxury)f-nicheTag
- filter by niche tag;N/A
– only wheels for vehicles with no niche tag set, any other value will include wheels with the specified niche tag and with no niche tag set, e.g.Lexus ES
– wheels with either no niche tag set or for Lexus ES vehiclesf-query
- filter by a full-text search query based on the following fields: part number, brand, model, sub model, bolt pattern (e.g.5x130
), short color, short finish, tags, and niche tag
Sorting
s-model
- sort by model (asc
ordesc
)
Example 1. Wheels by style ID 416 (Fuel Contra D615):
/wheels?f-styleId=416
Response:
{ "Wheels": [{ "Brand": "Fuel", "Id": 10486, "Model": "Contra", "Pn": "D64318909845", "StyleId": 416, "Submodel": "D643" }, ... ] }
Example 2. Wheels by style ID 416 with specification data and tags:
/wheels?f-styleId=416&i-specs&i-tags&i-cap
Response:
{ "Wheels": [{ "Accent": "Milled", "BoltCircle1": 135, "BoltCircle2": 139.7, "Bore": 106.1, "Brand": "Fuel", "Bsm": null, "Cap": { "Id": 428, "Pn": "1003-81GBQ HR93.1/87.1/78.1" }, "Color": "Red", "Diameter": 18, "ExposedLugs": false, "FaceStyle": "Multi Spoke", "Finish": "Gloss", "Gtin": null, "Id": 10486, "LipSize": null, "LoadRating": 2500, "LugCount": 6, "LugType": "Conical", "Material": "Cast Aluminum", "Model": "Contra", "Msrp": null, "Offset": -12, "Orientation": "N/A", "Pn": "D64318909845", "Position": "N/A", "ShortColor": "Red", "ShortFinish": "Gloss", "Structure": "1-Piece", "StyleId": 416, "Submodel": "D643", "Tags": ["Off-Road", "SUV", "Truck"], "Upc": null, "Weight": 32, "Width": 9 }, ... ] }
Example 3. A wheel with vendor part number equal “531147“ with description and feature benefit data:
/wheels?f-pn=531147&i-description&i-features
Response:
{ "Wheels": [{ "Brand": "Velox", "Description": "The Sterling from Velox Wheels is a multi-spoke wheel that is a part of the Nordica series. This wheel is specifically engineered for resilience in tough winter driving conditions. The Sterling wheel is available in two sleek finishes, matte black and silver. This wheel features a black snap-in center cap and spoke lines which extend to the lip of the wheel, making the face of the wheel look larger and more imposing. If you are looking to enhance the look of your vehicle while providing winter driving durability, the Velox Sterling may be the wheel for you.", "FeatureBenefit1": "", "FeatureBenefit2": "", "FeatureBenefit3": "", "FeatureBenefit4": "", "Id": 54832, "Model": "Sterling", "Pn": "531147", "StyleId": 10016, "Submodel": "SL" } ] }
Example 4. A wheel with ID equal “2945“ with 0001, 1001 and 0002 angle images:
/wheels?f-ids=2945&i-img0001&i-img1001&i-img0002
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-wheels/", "Wheels": [{ "Brand": "Beyern", "Id": 2945, "Img0001": "Beyern/Aviatic_Matte_Gunmetal_Gloss-Black-Lip_5-lug_0001.png", "Img0002": "Beyern/Aviatic_Matte_Gunmetal_Gloss-Black-Lip_5-lug_0002.png", "Img1001": "Beyern/Aviatic_Matte_Gunmetal_Gloss-Black-Lip_5-lug_1001.jpg", "Model": "Aviatic", "Pn": "1780BYA155120B72", "StyleId": 7195, "Submodel": "GY" } ] }
Appending Img<angle>
to ImgUrlBase
composes a complete image URL, for example:
https://storage.googleapis.com/autosync-wheels/Beyern/Aviatic_Matte_Gunmetal_Gloss-Black-Lip_5-lug_0001.png
Do not hardcode ImgUrlBase
or parts of it as it may change.
Example 5. Wheels for American muscle vehicles:
/wheels?f-tags=Muscle
Response:
{ "Wheels": [{ "Brand": "American Racing", "Id": 1, "Model": "Fast Back", "Pn": "VN80629012440", "StyleId": 6983, "Submodel": "VN806 GY" }, ... ] }
Example 6. Full-text search for BMW replica wheels:
/wheels?f-query=replica BMW&i-tags
Response:
{ "Wheels": [{ "Brand": "Replica Alloys", "Id": 63773, "Model": "BMW", "Pn": "067-880-5120-13 SMF", "StyleId": 11230, "Submodel": "TT 67 SL", "Tags": ["Car", "Replica", "SUV"] }, ... ] }
Example 7. Specs and images of a front dually wheel:
/wheels?&f-ids=11499&i-img0100&i-img0200&i-img0300&i-specs
Response:
{ "Wheels": [{ "Id": 11499, ... "Img0100": "Fuel/Maverick-Dually_D538_Black_Milled_Front_0100.png", "Img0200": "Fuel/Maverick-Dually_D538_Black_Milled_Rear_0200.png", "Img0300Front": "Fuel/Maverick-Dually_D538_Black_Milled_Front_0300.png", "Img0300Rear": "Fuel/Maverick-Dually_D538_Black_Milled_Rear_0300.png", "LinkedDuallyWheels": { "Front": 11499, "Inner": 189179, "Outer": [ 11503, 11500 ] }, ... } ] }
Front dually wheels, when queried for images of angle 0300, include two paths (instead of one):
"Img0300Front": "Fuel/Maverick-Dually_D538_Black_Milled_Front_0300.png" "Img0300Rear": "Fuel/Maverick-Dually_D538_Black_Milled_Rear_0300.png",
That’s to accommodate different VoV (view on vehicle) profile images:
When i-spec
parameter is added to the URL, front dually wheels include LinkedDuallyWheels
section:
"LinkedDuallyWheels": { "Front": 11499, "Inner": 189179, "Outer": [ 11503, 11500 ] }
This section lists IDs of all other related dually wheels, i.e. a matching inner dually wheel and matching outer dually wheels.
POST /wheels/favorites
Mark a wheel as added to the favorites through the visualizer app.
Data must be submitted in the body and be JSON-encoded:
{ "wheelId": ... }
where (* - required):
*
wheelId
- ID of the wheel added to favorites
Example 1. JavaScript code for sending a sample request for quote:
const data = { vehicleId: 1234, }; const resp = await fetch(API_URL + '/wheels/favorites?key=' + API_KEY, { method: 'POST', headers: { 'Accept': 'application/json', 'Content-Type': 'application/json' }, body: JSON.stringify(data) }); console.log(await resp.json());
Response:
{ "Status": "OK" }
9. Tire Endpoints
All endpoints in this section require authorization. For more information see “2. Authorization”.
Definitions
Metric Tires – Standard tire size format. For example “235/45R18”.
Flotation Tires – An alternative tire size format often used for larger truck and ATV/UTV tires. For example “42X15-16LT“.
Square Fitment – All four tires are the same size. All four wheels are the same diameter. All four wheels are the same diameter, width, and offset.
Staggered Fitment – Two wheels (typically the drive wheels) are wider.
GET /tires/brands
A list of tire brands.
Optional query parameters:
Data
i-logos
- include brand logosi-about
- include brand’s about informationi-tireCount
- include the total number of tires for each brand
Filters
f-format
- filter by size format (M
- metric orF
- flotation)
Example 1. All brands:
/tires/brands
Response:
{ "Brands": [{ "Id": 265, "Brand": "Bfgoodrich" }, { "Id": 262, "Brand": "Bridgestone" }, ... ] }
Example 2. All brands with their logos and the number of tires:
/tires/brands?i-logos&i-tireCount
Response:
{ "BrandLogosUrlBase": "https://storage.googleapis.com/autosync-brand-logos/products/", "Brands": [{ "Id": 265, "Brand": "Bfgoodrich", "Logo": "Bfgoodrich.png", "TireCount": 966 }, ... ] }
Appending Logo
to BrandLogosUrlBase
composes a complete logo image URL, for example:
https://storage.googleapis.com/autosync-brand-logos/products/Bfgoodrich.png
Do not hardcode BrandLogosUrlBase
or parts of it as it may change.
GET /tires/filters
A list of tire filters.
Optional query parameters:
M - the parameter applies to metric tires only
F - the parameter applies to floatation tires only
Data
i-aspectRatios
M - include a list of aspect ratiosi-diameters
F - include a list of diametersi-inchWidths
F - include a list of inch widthsi-rimDiameters
- include a list of rim diametersi-sectionWidths
M - include a list of section widthsi-tags
- include a list of tags
Filters
f-brand
- filter by brandf-aspectRatio
- filter aspect ratio (metric tires only)f-diameter
- filter by diameter (flotation tires only)f-inchWidth
- filter by inch width (flotation tires only)f-rimDiameter
- filter by rim diameterf-sectionWidth
- filter by section width (metric tires only)f-format
- filter by size format (M
- metric orF
- flotation)
Example 1. All rim diameters:
/tires/filters?i-rimDiameters
Response:
{ "Filters": { "RimDiameters": [6, 8, 9, ...] } }
Example 2. Rim diameters filtered by “Goodyear” brand:
/tires/filters?i-rimDiameters&f-brand=Goodyear
Response:
{ "Filters": { "Diameters": [14, 15, 16, ...] } }
GET /tires/filters/combinations
A list of combinations of tire filter values. It’s meant for building UI filters that don’t need to send requests as users make selections, since all possible combinations are known.
Sample UI powered by filter combinations:
Optional query parameters:
M - the parameter applies to metric tires only
F - the parameter applies to floatation tires only
Data
i-aspectRatios
M - include a list of aspect ratiosi-diameters
F - include a list of diametersi-inchWidths
F - include a list of inch widthsi-rimDiameters
- include a list of rim diametersi-sectionWidths
M - include a list of section widthsi-tags
- include a list of tags
Filters
f-brand
- filter by brandf-aspectRatio
M - filter aspect ratiof-diameter
F - filter by diameterf-inchWidth
F - filter by inch widthf-rimDiameter
- filter by rim diameterf-sectionWidth
M - filter by section widthf-format
- filter by size format (M
- metric orF
- flotation)
Example 1. All section widths, aspect ratios, rim diameters, and tag combinations of 18”-rim-diameter tires:
/tires/filters/combinations?i-sectionWidth&i-aspectRatio&i-rimDiameter&i-tags&f-rimDiameter=18&p-size=500
Response:
{ "FilterCombinations": [{ "AspectRatio": 60, "RimDiameter": 18, "SectionWidth": 245, "Tags": ["All Season", "Highway Terrain", "SUV/Light Truck"] }, ... ], }
Some filter combinations (and lack thereof) will exceed the maximum page size and the results will have to be fetched with multiple requests.
GET /tires/models
A list of tire models.
Optional query parameters:
M - the parameter applies to metric tires only
F - the parameter applies to floatation tires only
Data
i-img
- include URLs of all available imagesi-imgDetails
- include details of the selected images that represent the model (e.g. rim size or diameter); tire models may include tires of multiple widths, aspect ratios, diameters etci-specs
- include description, features and benefitsi-displayNames
- include all unique display names for the tire modeli-tireCount
- include the total number of tires for each model
Filters
f-id
- filter by tire model IDf-brand
- filter by brandf-brandId
- filter by brand IDf-query
- filter by a full-text search, e.g. “Michelin Crossclimate”; searched fields: brand, model, model description, part number and display name; maximum length: 50 charactersf-sectionWidth
M - filter by tire section width, e.g. “235“f-sectionWidth2
M - filter by secondary tire section width, e.g. “245“; specifyingf-sectionWidth
andf-sectionWidth2
will list only tire models with tires of both widths; intended for vehicles with staggered fitmentf-aspectRatio
M - filter by tire aspect ration, e.g. “45”f-aspectRatio2
M - filter by secondary tire aspect ration, e.g. “55”; specifyingf-aspectRatio
andf-aspectRatio2
will list only tire models with tires of both aspect ratios; intended for vehicles with staggered fitmentf-rimDiameter
- filter by rim diameter, e.g. “22”f-rimDiameter2
- filter by rim diameter, e.g. “24”; specifyingf-rimDiameter
andf-rimDiameter2
will list only tire models with tires of both rim diameters; intended for vehicles with staggered fitmentf-inchWidth
F - filter by tire width in inches, e.g. “12.5”f-inchWidth2
F - filter by secondary tire width in inches, e.g. “10.5”; specifyingf-inchWidth
andf-inchWidth2
will list only tire models with tires of both inch widths; intended for vehicles with staggered fitmentf-diameter
F - filter by tire external diameter in inches, e.g. “33”f-diameter2
F - filter by secondary tire external diameter in inches, e.g. “35”; specifyingf-diameter
andf-diameter2
will list only tire models with tires of both diameters; intended for vehicles with staggered fitmentf-format
- filter by size format (M
- metric orF
- flotation)
Sorting
s-brand
- sort by brand (asc
ordesc
)s-model
- sort by model (asc
ordesc
); when both orders are applied, results are sorted first by brand and then by model
Example 1. Tire models with wheel count sorted by brand first and then by model:
/tires/models?i-tireCount&s-brand=asc&s-model=asc
Response:
{ "TireModels": [{ "Brand": "Amp", "Id": 17213, "Model": "MUD TERRAIN ATTACK M/T A", "TireCount": 29 }, ... ] }
Example 2. Tire models filtered by “Michelin” brand with their specification and images:
/tires/models?i-specs&i-img&f-brand=Michelin
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-tires/", "RotationImgUrlBase": "https://storage.googleapis.com/autosync-tire-spins/", "TireModels": [{ "Benefits": null, "Brand": "Michelin", "Description": "Ultra-High Performance Passenger Car Summer tire. Original Equipment on Renowned Sports Cars like BMW M3, Porsche 911 and Chevrolet Corvette ZR1. ZP (Zero Pressure) Run Flat Technology on Select Sizes.", "Features": null, "Id": 291, "ImgAngle": "c4857df1f52eae568218d7ca98fa0bae.webp", "ImgFront": "a0a429690e6147bdf2af507735b1def1.webp", "ImgRotationDir": null, "ImgSide1": "7e03541741604bfdec8e543a38e3c6fb.webp", "ImgSide2": null, "ImgThumb": "b34043a718877c81db3e20438141c0b3.webp", "Model": "PILOT SPORT PS2" }, ... ] }
Appending image path (ImgThumb
, ImgAngle
, ImgFront
, ImgSide1
, ImgSide2
) to ImgUrlBase
composes a full resource URL, for example:
https://storage.googleapis.com/autosync-tires/c4857df1f52eae568218d7ca98fa0bae.webp
If an angle is not available, null
value will be returned.
Do not hardcode BrandLogosUrlBase
or RotationImgUrlBase
as the URLs may change.
GET /tires
A list of tires.
Optional query parameters:
M - the parameter applies to metric tires only
F - the parameter applies to floatation tires only
Data
i-img
- include URLs of all available imagesi-specs
- include tire specification
Filters
f-id
- filter by tire IDf-brand
- filter by brandf-brandId
- filter by brand IDf-model
- filter by modelf-modelId
- filter by model IDf-sectionWidth
M - filter by section width, e.g. “235“f-aspectRatio
M - filter by aspect ration, e.g. “45”f-rimDiameter
- filter by rim diameter, e.g. “22”f-inchWidth
F - filter by width in inches, e.g. “12.5”f-diameter
F - filter by external diameter in inches, e.g. “33”f-query
- filter by a full-text search, e.g. “Michelin 225/50R17”; searched fields: brand, model, model description, part number and display name; maximum length: 50 charactersf-format
- filter by size format (M
- metric orF
- flotation)
Sorting
s-brand
- sort by brand (asc
ordesc
)s-model
- sort by model (asc
ordesc
)
Example 1. 225/50R17 size Michelin tires sorted by tire model:
/tires?f-brand=Michelin&f-query=225/50R17&s-model=asc
Response:
{ "Tires": [{ "Brand": "Michelin", "BrandId": 264, "DisplayName": "225/50R17 XL CROSSCLIMATE +", "Id": 245753, "Model": "CROSSCLIMATE +", "ModelId": 18304, "PartNumber": "72199" }, { "Brand": "Michelin", "BrandId": 264, "DisplayName": "225/50R17 XL CROSSCLIMATE 2", "Id": 445332, "Model": "CROSSCLIMATE 2", "ModelId": 29768, "PartNumber": "69757" }, ... ] }
Example 2. Michelin Crossclimate 2 tires with images and specification:
/tires?f-brand=Michelin&f-model=Crossclimate%202&i-img&i-specs
Response:
{ "ImgUrlBase": "https://storage.googleapis.com/autosync-tires/", "RotationImgUrlBase": "https://storage.googleapis.com/autosync-tire-spins/", "Tires": [{ "ApprovedRimWidthMax": 8.5, "ApprovedRimWidthMin": 6.5, "Asin": null, "AspectRatio": 65, "Benefits": null, "Brand": "Michelin", "BrandId": 264, "Description": "All-Season Performance Touring Passenger Car, SUV/CUV tire.", "Diameter": null, "DisplayName": "235/65R17 CROSSCLIMATE 2", "Ean": null, "Features": null, "GmCode": 19427825, "Id": 445315, "ImgAngle": "2363aea9629e696f8ca6983e61bec53e.webp", "ImgFront": "f6b36e63f0d92516cc6251f207f6f4cd.webp", "ImgRotationDir": null, "ImgSide1": "c16898f82820d7c788c0242c1ceb0447.webp", "ImgSide2": null, "ImgThumb": "edeee0cbf32f83e2d04849f8a84715e3.webp", "InchWidth": null, "LoadCapacityDual": null, "LoadCapacitySingle": "1984", "LoadRange": "SL", "LoadRating": "104", "LoadedWidth": null, "MaxInflationPressure": 51, "MeasuringRimWidth": "7.0", "MetricRimDiameter": null, "MinDualSpacing": null, "Model": "CROSSCLIMATE 2", "ModelId": 29768, "OriginCountry": null, "OverallDiameter": 29.12, "OverallWidth": 9, "PartNumber": "74077", "PlyRating": null, "RevolutionsPerMile": 716, "RimDiameter": 17, "RollingCircumference": null, "SectionWidth": 235, "Sidewall": "BSW", "SpeedRating": "H", "StarRating": null, "StaticLoadedRadius": null, "TraCode": null, "TreadDepth": 10, "TreadWidth": null, "Upc": "086699740779", "Utqg": null, "Warranty": 60000, "Weight": 30.73 }, ... ] }
Appending image path (ImgThumb
, ImgAngle
, ImgFront
, ImgSide1
, ImgSide2
) to ImgUrlBase
composes a full resource URL, for example:
https://storage.googleapis.com/autosync-tires/2363aea9629e696f8ca6983e61bec53e.webp
If an angle is not available, null
value will be returned.
Do not hardcode BrandLogosUrlBase
or RotationImgUrlBase
as the URLs may change.
If ImgRotationDir
is not null
, its value represents a folder with rotation images. For example:
{ "RotationImgUrlBase": "https://storage.googleapis.com/autosync-tire-spins/", "Tires": [{ ... "ImgRotationDir": "fb887ecb39f711c09fa50d8e27a27fb3", ... } ] }
Append ImgRotationDir
to RotationImgUrlBase
to form a URL to a folder with rotation images. Each folder contains 36 WebP images. For example, to access the first image:
https://storage.googleapis.com/autosync-tire-spins/fb887ecb39f711c09fa50d8e27a27fb3/1.webp
For time-effective deployments, it is recommend to use a library for spins provided by AutoSync.
Live CodePen example:
https://codepen.io/m-autosync/pen/mdXrdjy
10. Request for Quote Endpoint
The endpoint in this section requires authorization. For more information see “2. Authorization”.
POST /request-for-quote
Submit a request for quote. Email notifications will be sent to all email addresses linked to the API key and a confirmation email will be sent to the customer.
Data must be submitted in the body and be JSON-encoded:
{ "customer": {"firstName": ..., "lastName": ..., "phone": ..., "email": ...}, "locationId": ..., "vehicleId": ..., "products": [ {"type": ..., "id": ..., "qty": ...}, ], "message": ... }
where (* - required):
*
customer
- customer information*
firstName
- between 1 and 30 characters*
lastName
- between 1 and 30 characters*
phone
- between 10 and 20 characters*
email
- maximum 50 characters
locationId
- ID of a retailer or manufacturer location; if specified, email addresses to be notified will be taken from the location (instead of the API key settings)vehicleId
- ID of the selected vehicle*
products
- an array of objects*
type
- product type; possible values:wheel
,tire
*
id
- product IDqty
- product quantity
message
- customer notes; maximum 500 characters
Example 1. JavaScript code for sending a sample request for quote:
const data = { customer: { firstName: "James", lastName: "Smith", phone: "360-555-6666", email: "james.smith@gmail.com", message: "This is a test", }, locationId: 101, vehicleId: 1234, products: [ {type: "wheel", id: 445566, qty: 2}, ], }; const resp = await fetch(API_URL + '/request-for-quote?key=' + API_KEY, { method: 'POST', headers: { 'Accept': 'application/json', 'Content-Type': 'application/json' }, body: JSON.stringify(data) }); console.log(await resp.json());
Response:
{ "Status": "OK" }
Sample email sent to a customer:
Sample email sent to a retailer: