Last modified by admin on 2023/02/14 14:43

<
From version < 34.1 >
edited by jns
on 2012/12/03 10:33
To version < 61.2
edited by admin
on 2023/02/14 14:43
Change comment: add cache macro

Summary

Details

Page properties
Title
... ... @@ -1,1 +1,1 @@
1 -Home
1 +Spreadshirt Public Shop API Documentation
Parent
... ... @@ -1,0 +1,1 @@
1 +API.WebHome
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.jns
1 +XWiki.admin
Content
... ... @@ -1,31 +1,67 @@
1 -{{section}}
1 +{{cache timeToLive="2592000"}}
2 += Preface =
2 2  
3 -{column:width=50%}
4 -Spreadshirt is your place to create and buy customized apparel, such as T-shirts, cups or stickers. In order to allow developers to make use of this functionality in their own applications, we now provide a new Spreadshirt API. The Spreadshirt API provides access to a set of Spreadshirt's platform functionality, such as product creation, design upload or basket creation, and allows you to start building your own shops, mass-customization applications and integrations on top of our platform.
4 +Spreadshirt provides several ways to offer an online shop experience to your customers and earn money through commission:
5 5  
6 -To get started in using the Spreadshirt API:
6 +1. The standalone Spreadshop ([[this>>url:https://shop.spreadshirt.com/SpreadShop||rel="nofollow" shape="rect" class="external-link"]], for example). This application is officially developed, hosted and maintained by Spreadshirt. Running a Spreadshop requires zero technical skills and is always the recommended approach.
7 +1. JavaScript integration (described [[here>>url:https://help.spreadshop.com/hc/en-us/articles/360010529039-Website-Integration-with-JavaScript||shape="rect"]]). If you have an existing website, you can embed a piece of JavaScript into it that manipulates your website in order to embed the Spreadshop into your site. This requires a decent understanding of HTML and CSS in order to resolve any conflicts between your site and the Spreadshop that may arise.
8 +1. CMS plugins for [[WordPress>>url:https://wordpress.org/plugins/spreadshop/#developers||rel="nofollow" shape="rect" class="external-link"]] and others (currently just [[Joomla>>url:https://extensions.joomla.org/extension/spreadshop/||rel="nofollow" shape="rect" class="external-link"]]) that embed the JavaScript snippet mentioned in (2.) for you. If you run a website based on such CMS, these plugins can make your life a bit easier. An understanding of HTML and CSS is nonetheless important.
9 +1. An independent, custom built web application based on the **Public Shop API** described in this document. This interface is for web developers only (or people who can afford to hire one). Going for this approach is only feasible for people who have a solid understanding of server side & client side programming, HTTP, HTML and CSS.
7 7  
8 -* [Watch the YouTube Video about Spreadshirt's REST API|http://www.youtube.com/watch?v=6IlGvHPq9D4], that gives and introduction to the API and tells you about the opportunities for you.
9 -* [Browse our API documentation|API:API] to become familiar with our API, i.e. REST API urls and representations and status codes.
10 -* Conduct API calls using your [Web browser|http://api.spreadshirt.net/api/v1/shops/205909] or our [API browser|http://demoapp.spreadshirt.net/apibrowser/].
11 -* Register for an API key with your Spreadshirt user id in case you need access to special features, such as product creation, design upload or basket creation.
12 -** [Register for an API key (EU platform)|https://www.spreadshirt.de/-C7120]
13 -** [Register for an API key (NA platform)|https://www.spreadshirt.com/-C6840]
14 -* [Register for a Spreadshirt shop|http://www.spreadshirt.net/open-t-shirt-shop-C5781], in case you don't have one yet.
15 -* [Checkout the applications section|API:Applications] to get sample code, find out what other people did with our API and get some fresh ideas. Checkout the [Simplomat (Simple Shirt Designer)|Simplomat (Simple Shirt Designer Demo)] demos in case you work with Javascript.
16 -* In case you have questions or problems, visit the [Spreadshirt API forum|http://forum.spreadshirt.net/forumdisplay.php?f=133].
11 += Prerequisites =
17 17  
18 -To stay up to date on API changes and development news follow the [Spreadshirt developer blog|http://blog.spreadshirt.net/developer/].
13 +Spreadshirt runs a European and a North American platform that are independent from another. You need to:
19 19  
20 -Please note that *Spreadshirt API is beta* right now.
15 +* Choose a platform
16 +* Register a Spreadshop:
17 +** Europe: [[here>>url:https://www.spreadshirt.net/start-selling-C5780||shape="rect"]]
18 +** North America: [[here>>url:https://www.spreadshirt.com/start-selling-shirts-C3598||shape="rect"]]
19 +* Visit this partner area page of the appropriate platform to retrieve your API Key:
20 +** Europe: [[here>>url:https://partner.spreadshirt.net/apiKey||shape="rect"]]
21 +** North America: [[here>>url:https://partner.spreadshirt.com/apiKey||shape="rect"]]
21 21  
22 -[Legal Information|API:Legal Information]
23 += Basics =
23 23  
24 -{column}
25 -{column:width=5%}
26 -{column}
27 -{column:width=45%}
28 -{recently-updated}
29 -{column}
25 +* The API described here is loosely based on [[REST>>url:https://en.wikipedia.org/wiki/Representational_state_transfer||shape="rect"]] principles. This means among other things that all endpoints can be accessed via HTTPS and HTTP clients like [[curl>>url:https://curl.haxx.se/||shape="rect"]] or [[postman>>url:https://www.getpostman.com/||shape="rect"]] can be used directly to explore the API.
26 +* The base url for all requests is [[https:~~/~~/api.spreadshirt.net>>url:https://api.spreadshirt.net||shape="rect"]] for eu or [[https:~~/~~/api.spreadshirt.com>>url:https://api.spreadshirt.com||shape="rect"]] for na. (This only applies to REST resources, images are retrieved from [[https:~~/~~/image.spreadshirtmedia.net>>url:https://image.spreadshirtmedia.net||shape="rect"]] or [[https:~~/~~/image.spreadshirtmedia.com>>url:https://image.spreadshirtmedia.com||shape="rect"]].)
27 +* (((
28 +(% class="auto-cursor-target" %)
29 +All requests have to be made with HTTP headers "Authorization" and "User-Agent". The authorization header must include your API key and the user agent header must include the name of your application, then its version, followed by a domain and a contact email address:
30 30  
31 -{{/section}}
31 +|=(((
32 +Header Key
33 +)))|=(((
34 +Header Value Format
35 +)))|=(((
36 +Example Header Value
37 +)))
38 +|(((
39 +Authorization
40 +)))|(((
41 +SprdAuth apiKey="<apikey>"
42 +)))|(((
43 +SprdAuth apiKey="dd30b4db-8cd6-4fb8-86b3-e680984b9e18"
44 +)))
45 +|(((
46 +User-Agent
47 +)))|(((
48 +<YourApplication>/<YourApplicationVersion> ([[https:~~/~~/www.yourdomain.com>>url:https://www.yourdomain.com/||shape="rect"]]; [[yourname@yourdomain.com>>mailto:yourname@yourdomain.com||shape="rect"]])
49 +)))|(((
50 +WordPress-Plugin/1.0 ([[https:~~/~~/www.deinblog.com>>url:https://www.deinblog.com/||shape="rect"]]; [[admin@deinblog.com>>mailto:admin@deinblog.com||shape="rect"]])
51 +)))
52 +
53 +(% class="auto-cursor-target" %)
54 +Failing to provide this information may result in your requests getting blocked at any point in time because traffic of unknown source can be considered illegitimate.
55 +)))
56 +* All requests should be performed with a ?mediaType=json query parameter to get the responses in the recommended JSON format. Leaving the parameter out may or may not result in a response in XML format which is harder to work with.
57 +* All REST resources return HTTP status code 200 or 201 in case of successful requests. Status codes from the 4xx range indicate a mistake on your side while errors from the 5xx range indicate an error on ours.
58 +* Timestamps are returned in ISO8601 format.
59 +
60 += Next Steps =
61 +
62 +There is a [[tutorial>>doc:API.Spreadshirt Public Shop API Documentation.API Tutorials.Build your own shop system.WebHome]] available showing the use of this API in order to **implement an own shop system**.
63 +
64 += [[doc:API.Spreadshirt Public Shop API Documentation.Legal Information.WebHome]] =
65 +
66 +(% class="auto-cursor-target" %)
67 +{{/cache}}
api-parts.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.XWikiGuest
Size
... ... @@ -1,0 +1,1 @@
1 +17.4 KB
Content
Confluence.Code.ConfluencePageClass[0]
id
... ... @@ -1,1 +1,1 @@
1 -5210117
1 +819217
url
... ... @@ -1,1 +1,1 @@
1 -https://developer.spreadshirt.net/wiki/spaces/API/pages/5210117/Home
1 +https://developer.spreadshirt.net/wiki/spaces/API/pages/819217/Spreadshirt Public Shop API Documentation