NAV

Starter Site

Ecwid API features several endpoints to control the presentation of Starter site. Learn more about the Ecwid Starter site

Get starter site content details

Get starter site content details of an Ecwid store.

Request

Request example

GET /api/v3/4870020/startersite?token=123abcd HTTP/1.1
Host: app.ecwid.com
Cache-Control: no-cache

GET https://app.ecwid.com/api/v3/{storeId}/startersite?token={token}

NameTypeDescription
storeIdnumberEcwid store ID
tokenstringoAuth token

Response

Response example (JSON)

{
  "coverImageUrl": "https://d1howb1wwyap5o.cloudfront.net/startersite/desktop.jpg",
  "coverImageThumbnail": "",
  "coverImageMobileUrl": "https://d1howb1wwyap5o.cloudfront.net/startersite/mobile.jpg",
  "coverImageMobileThumbnail": "",
  "coverTitle": "Your store name here",
  "coverSubtitle": "Write a brief explanation about your store. It can be a brief description, slogan, motto, etc.<br>Example: &quot;Your one stop gift shop for any occasion&quot;.",
  "whyusTitle": "Why Choose Us?",
  "whyusContent": "<p>Use this section to provide information for your customers about why your store is the best place to purchase the type of goods you sell. Be sure to highlight the things that make your products and store services unique. For example, are your items made locally, sourced from special ingredients, unique or customized? This is the section to tell your customers how great your products and services are. Free shipping? Let them know here!</p>",
  "quoteContent": "Insert a customer testimonial or a favorite quote that describes your business motto.",
  "quotePersonName": "Mary Smith",
  "quotePersonTitle": "local celebrity",
  "quotePersonImageUrl": "https://d1howb1wwyap5o.cloudfront.net/startersite/quote-portrait.png",
  "meetownerTitle": "About",
  "meetownerContent": "<p>Here you can let your customers get to know you. Tell them a little bit about yourself and why you have chosen to create this particular business. Do you have a passion, hobby or life experience that inspired you to create your business? Help customers feel connected to your purpose and inspire trust in your brand.</p>",
  "meetownerOwnerImageUrl": "https://d1howb1wwyap5o.cloudfront.net/startersite/owner-pic.png",
  "meetownerOwnerName": "Joan Doe,",
  "meetownerOwnerTitle": "store owner",
  "locationTitle": "Location",
  "locationDescription": "<p>How customers can find your offline store? Give some more details about your location: your address, store hours, and the easiest way to get to you. Leave this section empty if you do not have offline location.</p>",
  "locationAddress": "144 West D Street, Encinitas, CA 92024 USA",
  "locationLong": "-117.2967266",
  "locationLat": "33.0460986",
  "locationHours": "{\"hours\": [{\"dayto\": \"Friday\", \"hourto\": \"9:30 PM\", \"dayfrom\": \"Monday\", \"hourfrom\": \"10:00 AM\"}, {\"hourto\": \"7:00 PM\", \"dayfrom\": \"Saturday\", \"hourfrom\": \"Noon\"}, {\"dayfrom\": \"Sunday\", \"hourfrom\": \"Closed\"}], \"title\": \"Store Hours\"}",
  "contactusFacebook": "https://www.facebook.com/ecwid",
  "contactusTwitter": "https://twitter.com/ecwid",
  "contactusInstagram": "https://www.instagram.com/ecwid",
  "contactUsList": "{\"title\": \"Contact us\", \"channels\": [{\"type\": \"phone\", \"title\": \"Phone\", \"value\": \"1-800-555-0123\"}, {\"type\": \"email\", \"title\": \"Email\", \"value\": \"john.doe@example.com\"}], \"channelsTitle\": \"Connect with us\"}",
  "showCoverImage": true,
  "showWhyUs": true,
  "showQuote": true,
  "showInstagram": true,
  "showMeetowner": true,
  "showLocation": true,
  "showContactus": true
}

A JSON object of type ‘StarterSiteInfo’ with the following fields:

StarterSiteInfo

FieldTypeDescription
coverImageUrlstringURL to the main image, displayed in background when starter site is opened.
coverImageThumbnailbase64Thumbnail cover image.
coverImageMobileUrlstringURL to the main image, displayed in background when starter site is opened on mobiles.
coverImageMobileThumbnailbase64Thumbnail cover image for mobile devices
coverTitlestringThe main title displayed on top of cover image
coverSubtitlestringSubtitle displayed under the coverTitle
whyusTitlestringTitle for “Why us?” section
whyusContentstringText for “Why us?” section. HTML tags allowed: p,u,b,i,sup,a
quoteContentstringCustomer testimonial about a store. HTML tags allowed: p,u,b,i,sup,a
quotePersonNamestringCustomer name, who left a testimonial
quotePersonTitlestringTitle or occupance of customer with testimonial
quotePersonImageUrlstringURL to a photo of a customer with testimonial
meetownerTitlestringStore owner “About owner” section title
meetownerContentstringText for the “About owner” section. HTML tags allowed: p,u,b,i,sup,a
meetownerOwnerImageUrlstringURL to owner photo in the “About owner” section
meetownerOwnerNamestringStore owner’s name in the “About owner” section
meetownerOwnerTitlestringStore owner’s occupation/title in the “About owner” section
locationTitlestringTitle of the “Location” block
locationDescriptionstringText for the “Location” block. HTML tags allowed: p,u,b,i,sup,a
locationAddressstringAddress line for store’s location
locationLongstringLongitude coordinate of a store
locationLatstringLattitude coordinate of a store
locationHours<LocationHoursInfo>Working hours of a store
contactusFacebookstringURL to store’s Facebook page
contactusTwitterstringURL to store’s Twitter profile
contactusPintereststringURL to store’s Twitter profile
contactusInstagramstringURL to store’s Twitter profile
contactusInstagramIdstringInstagram ID of a store
contactusFoursquarestringURL to store’s Foursquare profile
contactusYelpstringURL to store’s Yelp profile
contactusVkstringURL to store’s Vk profile
contactusTumblrstringURL to store’s Tumblr profile
contactusEtsystringURL to store’s Etsy profile
contactusGooglestringURL to store’s Google+ profile
contactusYoutubestringURL to store’s Youtube profile
contactusVimeostringURL to store’s Vimeo profile
contactusWechatstringURL to store’s Wechat profile
contactusWhatsappstringURL to store’s Whatsapp profile
contactusTelegramstringURL to store’s Telegram profile
contactusMessengerstringURL to store’s Messenger profile
contactusLinestringURL to store’s Line profile
contactusViberstringURL to store’s Viber profile
contactUsList<ContactUsListInfo>Contact a store block
showCoverImagebooleantrue if “Cover image” section is shown. false otherwise. Default is true
showWhyUsbooleantrue if “Why Us?” section is shown. false otherwise. Default is true
showQuotebooleantrue if quote section is shown. false otherwise. Default is true
showInstagrambooleantrue if Instagram feed section is shown. false otherwise. Default is true
showMeetownerbooleantrue if “Meet the Owner” section is shown. false otherwise. Default is true
showLocationbooleantrue if store location section is shown. false otherwise. Default is true
showContactusbooleantrue if “Contact Us” section is shown. false otherwise. Default is true

LocationHoursInfo

FieldTypeDescription
titlestringLocation working hours title
hours<LocationHoursDetailedInfo>Detailed location working hours information

LocationHoursDetailedInfo

FieldTypeDescription
dayfromstringDay of the week at the start of period
daytostringDay of the week at the end of period
hourfromstringOpening hours of a working day
hourtostringClosing hours of a working day

Errors

Error response example

HTTP/1.1 500 Server Error
Content-Type application/json; charset=utf-8

In case of error, Ecwid responds with an error HTTP status code and, optionally, JSON-formatted body containing error description

HTTP codes

HTTP StatusMeaning
403Access token doesn’t have update_store_profile scope
415Unsupported content-type: expected application/json or text/json
500Server error

Error response body (optional)

FieldTypeDescription
errorMessagestringError message

Create and update starter site content details

Update information displayed on starter site of a store

Request

Request example

PUT /api/v3/4870020/startersite?token=123abcd HTTP/1.1
Host: app.ecwid.com
Cache-Control: no-cache

PUT https://app.ecwid.com/api/v3/{storeId}/startersite?token={token}

NameTypeDescription
storeIdnumberEcwid store ID
tokenstringoAuth token

Request example (JSON)

{
  "coverTitle": "Your store name here",
  "coverSubtitle": "Write a brief explanation about your store. It can be a brief description, slogan, motto, etc.<br>Example: &quot;Your one stop gift shop for any occasion&quot;.",
  "whyusTitle": "Why Choose Us?",
  "whyusContent": "<p>Use this section to provide information for your customers about why your store is the best place to purchase the type of goods you sell. Be sure to highlight the things that make your products and store services unique. For example, are your items made locally, sourced from special ingredients, unique or customized? This is the section to tell your customers how great your products and services are. Free shipping? Let them know here!</p>",
  "quoteContent": "Insert a customer testimonial or a favorite quote that describes your business motto.",
  "quotePersonName": "Mary Smith",
  "quotePersonTitle": "local celebrity",
  "quotePersonImageUrl": "https://d1howb1wwyap5o.cloudfront.net/startersite/quote-portrait.png",
  "meetownerTitle": "About",
  "meetownerContent": "<p>Here you can let your customers get to know you. Tell them a little bit about yourself and why you have chosen to create this particular business. Do you have a passion, hobby or life experience that inspired you to create your business? Help customers feel connected to your purpose and inspire trust in your brand.</p>",
  "meetownerOwnerImageUrl": "https://d1howb1wwyap5o.cloudfront.net/startersite/owner-pic.png",
  "meetownerOwnerName": "Joan Doe,",
  "meetownerOwnerTitle": "store owner",
  "locationTitle": "Location",
  "locationDescription": "<p>How customers can find your offline store? Give some more details about your location: your address, store hours, and the easiest way to get to you. Leave this section empty if you do not have offline location.</p>",
  "locationAddress": "144 West D Street, Encinitas, CA 92024 USA",
  "locationLong": "-117.2967266",
  "locationLat": "33.0460986",
  "locationHours": "{\"hours\": [{\"dayto\": \"Friday\", \"hourto\": \"9:30 PM\", \"dayfrom\": \"Monday\", \"hourfrom\": \"10:00 AM\"}, {\"hourto\": \"7:00 PM\", \"dayfrom\": \"Saturday\", \"hourfrom\": \"Noon\"}, {\"dayfrom\": \"Sunday\", \"hourfrom\": \"Closed\"}], \"title\": \"Store Hours\"}",
  "contactusFacebook": "https://www.facebook.com/ecwid",
  "contactusTwitter": "https://twitter.com/ecwid",
  "contactusInstagram": "https://www.instagram.com/ecwid",
  "contactUsList": "{\"title\": \"Contact us\", \"channels\": [{\"type\": \"phone\", \"title\": \"Phone\", \"value\": \"1-800-555-0123\"}, {\"type\": \"email\", \"title\": \"Email\", \"value\": \"john.doe@example.com\"}], \"channelsTitle\": \"Connect with us\"}",
  "showCoverImage": true,
  "showWhyUs": true,
  "showQuote": false,
  "showInstagram": true,
  "showMeetowner": true,
  "showLocation": false,
  "showContactus": true
}

A JSON object of type 'StarterSiteInfo’ with the following fields:

StarterSiteInfo

FieldTypeDescription
coverTitlestringThe main title displayed on top of cover image
coverSubtitlestringSubtitle displayed under the coverTitle
whyusTitlestringTitle for “Why us?” section
whyusContentstringText for “Why us?” section. HTML tags allowed: p,u,b,i,sup,a
quoteContentstringCustomer testimonial about a store. HTML tags allowed: p,u,b,i,sup,a
quotePersonNamestringCustomer name, who left a testimonial
quotePersonTitlestringTitle or occupance of customer with testimonial
meetownerTitlestringStore owner “About owner” section title
meetownerContentstringText for the “About owner” section. HTML tags allowed: p,u,b,i,sup,a
meetownerOwnerNamestringStore owner’s name in the “About owner” section
meetownerOwnerTitlestringStore owner’s occupation/title in the “About owner” section
locationTitlestringTitle of the “Location” block
locationDescriptionstringText for the “Location” block. HTML tags allowed: p,u,b,i,sup,a
locationAddressstringAddress line for store’s location
locationLongstringLongitude coordinate of a store
locationLatstringLattitude coordinate of a store
locationHours<LocationHoursInfo>Working hours of a store
contactusFacebookstringURL to store’s Facebook page
contactusTwitterstringURL to store’s Twitter profile
contactusPintereststringURL to store’s Twitter profile
contactusInstagramstringURL to store’s Twitter profile
contactusInstagramIdstringInstagram ID of a store
contactusFoursquarestringURL to store’s Foursquare profile
contactusYelpstringURL to store’s Yelp profile
contactusVkstringURL to store’s Vk profile
contactusTumblrstringURL to store’s Tumblr profile
contactusEtsystringURL to store’s Etsy profile
contactusGooglestringURL to store’s Google+ profile
contactusYoutubestringURL to store’s Youtube profile
contactusVimeostringURL to store’s Vimeo profile
contactusWechatstringURL to store’s Wechat profile
contactusWhatsappstringURL to store’s Whatsapp profile
contactusTelegramstringURL to store’s Telegram profile
contactusMessengerstringURL to store’s Messenger profile
contactusLinestringURL to store’s Line profile
contactusViberstringURL to store’s Viber profile
contactUsList<ContactUsListInfo>Contact a store block
showCoverImagebooleanSet to false to hide the “Cover image” section. true otherwise. Default is true
showWhyUsbooleanSet to false to hide “Why Us?” section. true otherwise. Default is true
showQuotebooleanSet to false to hide quote section. true otherwise. Default is true
showInstagrambooleanSet to false to hide Instagram feed section. true otherwise. Default is true
showMeetownerbooleanSet to false to hide “Meet the Owner” section. true otherwise. Default is true
showLocationbooleanSet to false to hide store location section. true otherwise. Default is true
showContactusbooleanSet to false to hide “Contact Us” section. true otherwise. Default is true

LocationHoursInfo

FieldTypeDescription
titlestringLocation working hours title
hours<LocationHoursDetailedInfo>Detailed location working hours information

LocationHoursDetailedInfo

FieldTypeDescription
dayfromstringDay of the week at the start of period
daytostringDay of the week at the end of period
hourfromstringOpening hours of a working day
hourtostringClosing hours of a working day

Response

Response example

{
    "id": 1003
}

A JSON object of type 'UpdateStatus’ with the following fields:

UpdateStatus

FieldTypeDescription
idnumberThe store ID of the store where the settings were changed.

Errors

Error response example

HTTP/1.1 500 Server Error
Content-Type application/json; charset=utf-8

In case of error, Ecwid responds with an error HTTP status code and, optionally, JSON-formatted body containing error description

HTTP codes

HTTP StatusMeaning
403Access token doesn’t have update_store_profile scope
415Unsupported content-type: expected application/json or text/json
500Server error

Error response body (optional)

FieldTypeDescription
errorMessagestringError message

Upload cover image

Upload starter site cover. The image itself is to be placed in the request body.

Request example

POST /api/v3/4870020/startersite/cover?token=123456789abcd HTTP/1.1
Host: app.ecwid.com
Content-Type: image/jpeg
Cache-Control: no-cache

binary data

PHP Example

$file = file_get_contents('image.jpg');
$url = 'https://app.ecwid.com/api/v3/1003/startersite/cover?token=abcdefg123456';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_POST,1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $file);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: image/jpeg;'));

$result = curl_exec($ch);
curl_close ($ch);

Python Example

import requests

request_url = "https://app.ecwid.com/api/v3/1003/startersite/cover?token=abcdefg123456"

image_file_data = open('image.jpg', 'rb').read()

result = requests.post(request_url,data=image_file_data)

print(result.status_code)

POST https://app.ecwid.com/api/v3/{storeId}/startersite/cover?token={token}&externalUrl={externalUrl}

NameTypeDescription
storeIdnumberEcwid store ID
tokenstringoAuth token
externalUrlstringExternal file URL available for public download. If specified, Ecwid will ignore any binary file data sent in a request

When uploading a starter site cover, the image itself needs to be sent in the body of your request in a form of binary data. The file that you wish to upload needs to be prepared for that format and then sent to Ecwid API endpoint.

Alternatively, you can specify an externalURL to your file as a request parameter and Ecwid will download it from there.

Response

Response example

{
  "coverImageUrl": "https://s3.amazonaws.com/images.ecwid.com/startersite/images/123456/1468931238307.jpg",
  "coverImageMobileUrl": "https://s3.amazonaws.com/images.ecwid.com/startersite/images/123456/1468931236454.jpg",
  "coverImageThumbnail": "",
  "coverImageMobileThumbnail": ""
}

A JSON object of type 'UploadStatus’ with the following fields:

UploadStatus

FieldTypeDescription
coverImageUrlstringURL to the main image, displayed in background when starter site is opened.
coverImageThumbnailbase64Thumbnail cover image.
coverImageMobileUrlstringURL to the main image, displayed in background when starter site is opened on mobiles.
coverImageMobileThumbnailbase64Thumbnail cover image for mobile devices

Errors

Error response example

HTTP/1.1 500 Server Error
Content-Type application/json; charset=utf-8

In case of error, Ecwid responds with an error HTTP status code and, optionally, JSON-formatted body containing error description

HTTP codes

HTTP StatusDescription
400Request parameters are malformed
415Unsupported content-type: expected application/json or text/json
422The uploaded file is not an image
500Uploading of the image file failed or there was an internal server error while processing a file

Error response body (optional)

FieldTypeDescription
errorMessagestringError message

Upload owner portrait

Upload starter site owner portrait. The image itself is to be placed in the request body.

Request example

POST /api/v3/4870020/startersite/ownerportrait?token=123456789abcd HTTP/1.1
Host: app.ecwid.com
Content-Type: image/jpeg
Cache-Control: no-cache

binary data

PHP Example

$file = file_get_contents('image.jpg');
$url = 'https://app.ecwid.com/api/v3/1003/startersite/ownerportrait?token=abcdefg123456';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_POST,1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $file);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: image/jpeg;'));

$result = curl_exec($ch);
curl_close ($ch);

Python Example

import requests

request_url = "https://app.ecwid.com/api/v3/1003/startersite/ownerportrait?token=abcdefg123456"

image_file_data = open('image.jpg', 'rb').read()

result = requests.post(request_url,data=image_file_data)

print(result.status_code)

POST https://app.ecwid.com/api/v3/{storeId}/startersite/ownerportrait?token={token}&externalUrl={externalUrl}

NameTypeDescription
storeIdnumberEcwid store ID
tokenstringoAuth token
externalUrlstringExternal file URL available for public download. If specified, Ecwid will ignore any binary file data sent in a request

When uploading a starter site owner portrait, the image itself needs to be sent in the body of your request in a form of binary data. The file that you wish to upload needs to be prepared for that format and then sent to Ecwid API endpoint.

Alternatively, you can specify an externalURL to your file as a request parameter and Ecwid will download it from there.

Response

Response example

{
  "meetownerownerimageurl": "https://s3.amazonaws.com/images.ecwid.com/startersite/images/1003/1468931549471.jpg"
}

A JSON object of type 'UploadStatus’ with the following fields:

UploadStatus

NameTypeDescription
meetownerownerimageurlstringURL to owner photo in the “About owner” section

Errors

Error response example

HTTP/1.1 500 Server Error
Content-Type application/json; charset=utf-8

In case of error, Ecwid responds with an error HTTP status code and, optionally, JSON-formatted body containing error description

HTTP codes

HTTP StatusDescription
400Request parameters are malformed
415Unsupported content-type: expected application/octet-stream
422The uploaded file is not an image
500Uploading of the image file failed or there was an internal server error while processing a file

Error response body (optional)

FieldTypeDescription
errorMessagestringError message

Upload quote person image

Upload starter site quote person image. The image itself is to be placed in the request body.

Request example

POST /api/v3/4870020/startersite/quoteperson?token=123456789abcd HTTP/1.1
Host: app.ecwid.com
Content-Type: image/jpeg
Cache-Control: no-cache

binary data

PHP Example

$file = file_get_contents('image.jpg');
$url = 'https://app.ecwid.com/api/v3/1003/startersite/quoteperson?token=abcdefg123456';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_POST,1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $file);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: image/jpeg;'));

$result = curl_exec($ch);
curl_close ($ch);

Python Example

import requests

request_url = "https://app.ecwid.com/api/v3/1003/startersite/quoteperson?token=abcdefg123456"

image_file_data = open('image.jpg', 'rb').read()

result = requests.post(request_url,data=image_file_data)

print(result.status_code)

POST https://app.ecwid.com/api/v3/{storeId}/startersite/quoteperson?token={token}&externalUrl={externalUrl}

NameTypeDescription
storeIdnumberEcwid store ID
tokenstringoAuth token
externalUrlstringExternal file URL available for public download. If specified, Ecwid will ignore any binary file data sent in a request

When uploading a starter site owner portrait, the image itself needs to be sent in the body of your request in a form of binary data. The file that you wish to upload needs to be prepared for that format and then sent to Ecwid API endpoint.

Alternatively, you can specify an externalURL to your file as a request parameter and Ecwid will download it from there.

Response

Response example

{
  "quotepersonimageurl": "https://s3.amazonaws.com/images.ecwid.com/startersite/images/1003/1468931800030.jpg"
}

A JSON object of type 'UploadStatus’ with the following fields:

UploadStatus

NameTypeDescription
quotepersonimageurlstringURL to a photo of a customer with testimonial

Errors

Error response example

HTTP/1.1 500 Server Error
Content-Type application/json; charset=utf-8

In case of error, Ecwid responds with an error HTTP status code and, optionally, JSON-formatted body containing error description

HTTP codes

HTTP StatusDescription
400Request parameters are malformed
415Unsupported content-type: expected application/octet-stream
422The uploaded file is not an image
500Uploading of the image file failed or there was an internal server error while processing a file

Error response body (optional)

FieldTypeDescription
errorMessagestringError message