Skip to main content

Fourthwall APIs (v1.0)

Download OpenAPI specification:Download

Overview

Auth: Platform OAuth

Right now, Platform OAuth is invite only. Please contact us to get access.

We will need to know:

  1. Your redirect URL
  2. The permissions you need for the app

Authorize url

Link your users to this url to start the login process for your app.

https://my-shop.fourthwall.com/admin/platform-apps/<YOUR_CLIENT_ID>/connect

Getting an access token

After the user has authorized your app, they will be redirected to your redirect URL with an authorization code. You will need to exchange this code for an access token.

curl example:

curl -XPOST https://auth.fourthwall.com/auth/realms/Fourthwall/protocol/openid-connect/token \
  -H "Content-Type: application/x-www-form-urlencoded" \
  -d "grant_type=authorization_code&redirect_uri=<YOUR_REDIRECT_URL>&client_id=<YOUR_CLIENT_ID>&client_secret=<YOUR_CLIENT_SECRET>&code=<AUTHORIZATION_CODE>" 

The response will contain an access_token, refresh_token, and other information.

Using the access token

curl example:

curl -XGET https://api.fourthwall.com/open-api/v1/order/{YOUR_ORDER_ID} \
  -H "Authorization: Bearer YOUR_ACCESS_TOKEN"

Refreshing the access token

Access tokens expire rather quickly (within 1 hour). You can use the refresh_token to get a new access token without having to re-authorize the user.

curl example:

curl -XPOST https://auth.fourthwall.com/auth/realms/Fourthwall/protocol/openid-connect/token \
  -H "Content-Type: application/x-www-form-urlencoded" \
  -d "grant_type=refresh_token&client_id=<YOUR_CLIENT_ID>&client_secret=<YOUR_CLIENT_SECRET>&refresh_token=<YOUR_REFRESH_TOKEN>"

Auth: API key

Getting credentials

Note that the creation of API credentials is reserved for users with the SUPER ADMIN role.

  1. Navigate to For developers to create an API user.
  2. If API credentials haven't been generated yet, you will find a "Create API User" button under the "Open API" section. Click on it, and shortly after, the Username and Password for the Open API User will be provided. Keep your API credentials confidential and do not share them with unauthorized personnel. These credentials grant access to sensitive data and actions within our system. Always use HTTPS/SSL for encrypted communication when making API requests.

Authorizing with credentials

After Open API User was created, you can authorize your request by using Basic Access Authentication.

This can be achieved by constructing an Authorization header with the format Basic . The base64-encoded credentials should be passed with each request to gain access to the protected resources.

curl example:

curl -u "your_username:your_password" http://api.fourthwall.com/open-api/v1/order/{YOUR_ORDER_ID}

Javascript example:

const username = "your_username";
const password = "your_password";

// Combine username and password with a colon
const combinedCredentials = `${username}:${password}`;

// Encode the combined credentials to Base64
const base64Credentials = btoa(combinedCredentials);

const apiUrl = "http://api.fourthwall.com/open-api/v1/order/{YOUR_ORDER_ID}";
const requestOptions = {
  method: "GET",
  headers: {
    "Authorization": `Basic ${base64Credentials}`,
    "Content-Type": "application/json"
  }
};

fetch(apiUrl, requestOptions)
  .then(response => response.json()) // Parse the JSON response directly
  .then(data => {
  // Handle the API response data here
  console.log(data);
})
  .catch(error => {
  // Handle errors
  console.error("Error:", error);
});

Rate limiting policy

To ensure fair usage and maintain optimal system performance, we have implemented rate limiting for API requests. This means that each user is allowed a maximum of 100 requests within a 10-second rolling window.

What it means for you:

  • You can make up to 100 requests within any 10-second period.
  • If you exceed this limit, any additional requests will be delayed until the 10-second window is reset.

Please plan your API usage accordingly to avoid interruptions and ensure the smooth functioning of our services.

Products RSS feed

If you're just looking to read public product information, you do not need to use Open API. All sites publish a Merchant Center Feed under an RSS address:

{$shop_url}/.well-known/merchant-center/rss.xml

Example: for https://shop.fourthwall.com the RSS feed url would be https://shop.fourthwall.com/.well-known/merchant-center/rss.xml

BETA: Webhooks

Update a webhook

Update a webhook

Authorizations:
oauthbasicAuth
path Parameters
webhookConfigurationId
required
string
Request Body schema: application/json
required
url
required
string
allowedTypes
required
Array of strings
Items Enum: "ORDER_PLACED" "ORDER_UPDATED" "GIFT_PURCHASE" "PRODUCT_CREATED" "PRODUCT_UPDATED" "DONATION" "SUBSCRIPTION_PURCHASED" "SUBSCRIPTION_EXPIRED" "SUBSCRIPTION_CHANGED" "NEWSLETTER_SUBSCRIBED" "THANK_YOU_SENT" "GIFT_DRAW_STARTED" "GIFT_DRAW_ENDED"

Responses

Request samples

Content type
application/json
{
  • "url": "string",
  • "allowedTypes": [
    ]
}

Response samples

Content type
application/json
{
  • "id": "string",
  • "url": "string",
  • "allowedTypes": [
    ],
  • "apiVersion": "V1"
}

Delete a webhook

Delete a webhook

Authorizations:
oauthbasicAuth
path Parameters
webhookConfigurationId
required
string

Responses

Get webhooks

Get webhooks

Authorizations:
oauthbasicAuth

Responses

Response samples

Content type
application/json
{
  • "results": [
    ]
}

Create a webhook

Create a webhook

Authorizations:
oauthbasicAuth
Request Body schema: application/json
required
url
required
string
allowedTypes
required
Array of strings
Items Enum: "ORDER_PLACED" "ORDER_UPDATED" "GIFT_PURCHASE" "PRODUCT_CREATED" "PRODUCT_UPDATED" "DONATION" "SUBSCRIPTION_PURCHASED" "SUBSCRIPTION_EXPIRED" "SUBSCRIPTION_CHANGED" "NEWSLETTER_SUBSCRIBED" "THANK_YOU_SENT" "GIFT_DRAW_STARTED" "GIFT_DRAW_ENDED"

Responses

Request samples

Content type
application/json
{
  • "url": "string",
  • "allowedTypes": [
    ]
}

Response samples

Content type
application/json
{
  • "id": "string",
  • "url": "string",
  • "allowedTypes": [
    ],
  • "apiVersion": "V1"
}

Streaming

Set streaming status to started

Sets streaming status to started for specified services

Authorizations:
basicAuth
Request Body schema: application/json
required
required
Array of com.fourthwall.app.openapi.StreamingStartedRequest$Service$Twitch (object)
Array
One of
type
required
string
broadcasterId
required
string
broadcasterLogin
required
string
thumbnailUrl
string

Responses

Request samples

Content type
application/json
{
  • "services": [
    ]
}

Response samples

Content type
application/json
{
  • "shopId": "string",
  • "services": [
    ]
}

Set streaming status to ended

Sets streaming status to ended for specified services

Authorizations:
basicAuth
Request Body schema: application/json
required
services
required
Array of strings
Items Value: "TWITCH"

Responses

Request samples

Content type
application/json
{
  • "services": [
    ]
}

Response samples

Content type
application/json
{
  • "shopId": "string",
  • "services": [
    ]
}

Get streaming status

Returns streaming status for all services

Authorizations:
basicAuth

Responses

Response samples

Content type
application/json
{
  • "shopId": "string",
  • "services": [
    ]
}

Products (offers)

Update product (offer) availability by id

Updates a product (offer) availability

Authorizations:
oauthopenapibasicAuth
path Parameters
productId
required
string
Example: 00aa4abd-5778-4199-8161-0b49b2f212e5
Request Body schema: application/json
required
available
required
boolean

Responses

Request samples

Content type
application/json
{
  • "available": true
}

Response samples

Content type
application/json
{
  • "id": "00aa4abd-5778-4199-8161-0b49b2f212e5",
  • "name": "My t-shirt",
  • "slug": "my-t-shirt",
  • "description": "My t-shirt description",
  • "state": {
    },
  • "access": {
    },
  • "images": [],
  • "variants": [
    ],
  • "createdAt": "2020-08-13T09:05:36.939Z",
  • "updatedAt": "2020-08-13T09:05:36.939Z"
}

Get all products (offers)

Authorizations:
oauthopenapibasicAuth
query Parameters
page
integer <int32>
Default: 0
size
integer <int32>
Default: 20
Example: size=5

Responses

Response samples

Content type
application/json
{
  • "results": [
    ]
}

Get product (offer) by id

Authorizations:
oauthopenapibasicAuth
path Parameters
productId
required
string
Example: 00aa4abd-5778-4199-8161-0b49b2f212e5

Responses

Response samples

Content type
application/json
{
  • "id": "00aa4abd-5778-4199-8161-0b49b2f212e5",
  • "name": "My t-shirt",
  • "slug": "my-t-shirt",
  • "description": "My t-shirt description",
  • "state": {
    },
  • "access": {
    },
  • "images": [],
  • "variants": [
    ],
  • "createdAt": "2020-08-13T09:05:36.939Z",
  • "updatedAt": "2020-08-13T09:05:36.939Z"
}

Gifting

Finish draw

Finish draw and select winners

Authorizations:
basicAuth
path Parameters
id
required
string
Request Body schema: application/json
required
required
Array of com.fourthwall.app.openapi.DrawFinishedRequest$Participant$Twitch (object)
Array
One of
service
required
string
userId
required
string
userName
required
string

Responses

Request samples

Content type
application/json
{
  • "participants": [
    ]
}

Response samples

Content type
application/json
{
  • "id": "gdr_EdJvIXu3SEiXe_QkPavHSA",
  • "type": "INITIAL",
  • "giveawayId": "giv_EdJvIXu3SEiXe_QkPavHSA",
  • "giveawayFriendlyId": "D3XZFWPP",
  • "shopId": "sh_c689d374-22ca-43d3-8d29-9ef0805cc4cb",
  • "offer": {
    },
  • "amounts": {
    },
  • "email": "supporter@fourthwall.com",
  • "username": "Johnny123",
  • "message": "Sample message",
  • "gifts": [
    ],
  • "createdAt": "2019-08-24T14:15:22Z",
  • "durationSeconds": 0
}

Get draw

Get draw details

Authorizations:
basicAuth
path Parameters
id
required
string

Responses

Response samples

Content type
application/json
{
  • "id": "gdr_EdJvIXu3SEiXe_QkPavHSA",
  • "type": "INITIAL",
  • "giveawayId": "giv_EdJvIXu3SEiXe_QkPavHSA",
  • "giveawayFriendlyId": "D3XZFWPP",
  • "shopId": "sh_c689d374-22ca-43d3-8d29-9ef0805cc4cb",
  • "offer": {
    },
  • "amounts": {
    },
  • "email": "supporter@fourthwall.com",
  • "username": "Johnny123",
  • "message": "Sample message",
  • "gifts": [
    ],
  • "createdAt": "2019-08-24T14:15:22Z",
  • "durationSeconds": 0
}

BETA: Promotions

Create a promotion

Creates a promotion

Authorizations:
oauthbasicAuth
Request Body schema: application/json
required
One of
type
required
string

Responses

Request samples

Content type
application/json
Example
{
  • "type": "string"
}

Response samples

Content type
application/json
Example
{
  • "type": "string",
  • "id": "string",
  • "title": "string",
  • "code": "string",
  • "discount": {
    },
  • "status": "Live",
  • "requirements": {
    },
  • "usageCount": 0,
  • "limits": {
    },
  • "appliesTo": {
    }
}

Get all giveaway packages

Authorizations:
basicAuth

Responses

Response samples

Content type
application/json
{
  • "packages": [
    ]
}

Get giveaway links

Authorizations:
basicAuth
path Parameters
packageId
required
string
Example: 00aa4abd-5778-4199-8161-0b49b2f212e5

Responses

Response samples

Content type
application/json
{}

BETA: Fulfillment

Create a fulfillment for an order

Creates a fulfillment with a shipment tracker for provided order items. When trackers change their state, order.status will change to IN_PRODUCTION, PARTIALLY_IN_PRODUCTION, PARTIALLY_SHIPPED, SHIPPED depending on the shipping tracker info. Order updated webhooks will be triggered.

Authorizations:
oauthopenapibasicAuth
Request Body schema: application/json
required
orderId
required
string <uuid>
required
Array of objects (com.fourthwall.app.openapi.FulfillmentItem)
required
object (com.fourthwall.app.openapi.ShippingLabel)

Responses

Request samples

Content type
application/json
{
  • "orderId": "b3e1eced-f2bd-4d8c-9765-fbc9d1d222d5",
  • "items": [
    ],
  • "shippingLabel": {
    }
}

Response samples

Content type
application/json
{
  • "fulfillmentId": "string"
}

Add shipping label to fulfillment

Takes fulfillment_id, carrier name, tracking number and adds new shipping label to fulfillment. Optionally you can provide shipping method, tracker url and list items contained in particular shipping label.

Authorizations:
oauthopenapibasicAuth
path Parameters
fulfillmentId
required
string
Request Body schema: application/json
required
trackingCompany
required
string
trackingService
string
trackingNumber
string
labelUrl
string
required
Array of objects (com.fourthwall.fulfillment.model.FulfillmentShippingLabelItem)

Responses

Request samples

Content type
application/json
{
  • "trackingCompany": "string",
  • "trackingService": "string",
  • "trackingNumber": "string",
  • "labelUrl": "string",
  • "items": [
    ]
}

Response samples

Content type
application/json
{
  • "id": "string",
  • "shopId": "string",
  • "orderId": "b3e1eced-f2bd-4d8c-9765-fbc9d1d222d5",
  • "status": "OPEN",
  • "fulfillmentService": "FULFILLED_BY_CREATOR",
  • "items": [
    ],
  • "createdAt": "2019-08-24T14:15:22Z",
  • "updatedAt": "2019-08-24T14:15:22Z",
  • "shippingLabels": [
    ],
  • "orderShipmentId": "string",
  • "fulfillmentServiceShopConfigId": 0
}

Find fulfillments ids by friendly ids and fulfillment service

Find fulfillments ids by friendly ids and fulfillment service

Authorizations:
oauthopenapibasicAuth
Request Body schema: application/json
required
friendlyIds
required
Array of strings
fulfillmentService
required
string
Enum: "FULFILLED_BY_CREATOR" "FULFILLED_BY_FOURTHWALL" "FULFILLED_BY_MANUFACTURER" "WLM" "CTC" "WLM_3PL" "PRINTFUL" "SPOKE" "GNARLYWOOD" "DIGITAL_ITEM" "WHIPLASH_3PL" "WHIPLASH_FREE" "COSMOPOLITAN" "BOLT_STITCH" "SUPER_CULTURE" "SEVENTY_EIGHT_STRANGE" "MOGUL_MERCH_LOCAL" "MOGUL_MERCH_SHIP_BOB" "RVLT_SHIP_HERO" "OFFLINE_TV_SHIPSTATION" "HOMEMADE_MERCH" "DUBOW" "DUBOW_ORDER_DESK" "TRIBE" "OPTIGER" "OVERCAST" "MWW" "P3" "P3_ORDER_DESK" "CHIVA_TOYS" "USOURCED" "KNITWISE" "SHIP_MONK" "DOD"

Responses

Request samples

Content type
application/json
{
  • "friendlyIds": [
    ],
  • "fulfillmentService": "FULFILLED_BY_CREATOR"
}

Response samples

Content type
application/json
[
  • {
    }
]

Bulk add shipping label to fulfillment

Takes a list of fulfillment_id, carrier name, tracking number and adds new shipping label to fulfillment. Similar to saveFulfillmentShippingLabel but in bulk.

Authorizations:
oauthopenapibasicAuth
query Parameters
required
object (com.fourthwall.app.openapi.OpenApiFulfillmentEndpoint$BulkSaveFulfillmentsShippingLabelsRequest)

Responses

Response samples

Content type
application/json
{
  • "result": [
    ]
}

Thank yous

Get Thank You by id

Authorizations:
openapibasicAuth
path Parameters
thankYouId
required
string
Example: ty_EdJvIXu3SEiXe_QkPavHSA

Responses

Response samples

Content type
application/json
{
  • "id": "ty_EdJvIXu3SEiXe_QkPavHSA",
  • "contribution": {
    }
}

Shop

Get current shop

Returns the current shop

Authorizations:
oauthbasicAuth

Responses

Orders

Get all orders

Authorizations:
oauthopenapibasicAuth
query Parameters
page
integer <int32>
Default: 0
size
integer <int32>
Default: 20
Example: size=5
createdAt[gt]
string <date-time>
Example: createdAt[gt]=2020-08-13T09:05:36.939Z
createdAt[lt]
string <date-time>
Example: createdAt[lt]=2020-08-13T09:05:36.939Z
updatedAt[gt]
string <date-time>
Example: updatedAt[gt]=2020-08-13T09:05:36.939Z
updatedAt[lt]
string <date-time>
Example: updatedAt[lt]=2020-08-13T09:05:36.939Z
status
Array of strings unique
Items Enum: "CONFIRMED" "PARTIALLY_IN_PRODUCTION" "IN_PRODUCTION" "PARTIALLY_SHIPPED" "SHIPPED" "PARTIALLY_DELIVERED" "DELIVERED" "CANCELLED" "COMPLETED"
Example: status=CONFIRMED

Responses

Response samples

Content type
application/json
{
  • "results": [
    ]
}

Get order by id

Authorizations:
oauthopenapibasicAuth
path Parameters
orderId
required
string
Example: 00aa4abd-5778-4199-8161-0b49b2f212e5

Responses

Response samples

Content type
application/json
{
  • "id": "00aa4abd-5778-4199-8161-0b49b2f212e5",
  • "shopId": "sh_c689d374-22ca-43d3-8d29-9ef0805cc4cb",
  • "friendlyId": "D3XZFWPP",
  • "checkoutId": "ch_BV44UYrXQA2T_Xcf1288tw",
  • "promotionId": "prm_EdJvIXu3SEiXe_QkPavHSA",
  • "status": "CONFIRMED",
  • "email": "supporter@fourthwall.com",
  • "emailMarketingOptIn": true,
  • "username": "Johnny123",
  • "message": "Sample message",
  • "amounts": {
    },
  • "billing": {
    },
  • "shipping": {
    },
  • "offers": [
    ],
  • "source": {
    },
  • "createdAt": "2020-08-13T09:05:36.939Z",
  • "updatedAt": "2020-08-13T09:05:36.939Z"
}

Twitch gift purchases

Get gift purchase by id

Authorizations:
basicAuth
path Parameters
giftPurchaseId
required
string
Example: giv_EdJvIXu3SEiXe_QkPavHSA

Responses

Response samples

Content type
application/json
{
  • "id": "giv_EdJvIXu3SEiXe_QkPavHSA",
  • "friendlyId": "D3XZFWPP",
  • "shopId": "sh_c689d374-22ca-43d3-8d29-9ef0805cc4cb",
  • "offer": {
    },
  • "amounts": {
    },
  • "email": "supporter@fourthwall.com",
  • "username": "Johnny123",
  • "message": "Sample message",
  • "gifts": [
    ],
  • "createdAt": "2019-08-24T14:15:22Z"
}

Donations

Get all donations

Authorizations:
oauthopenapibasicAuth
query Parameters
page
integer <int32>
Default: 0
size
integer <int32>
Default: 20
Example: size=5

Responses

Response samples

Content type
application/json
{
  • "results": [
    ]
}

Get donation by id

Authorizations:
oauthopenapibasicAuth
path Parameters
donationId
required
string
Example: 00aa4abd-5778-4199-8161-0b49b2f212e5

Responses

Response samples

Content type
application/json
{
  • "id": "don_Kpcjx4HIQ1e4bTIOjX9CsA",
  • "shopId": "sh_c689d374-22ca-43d3-8d29-9ef0805cc4cb",
  • "status": "OPEN",
  • "email": "supporter@fourthwall.com",
  • "username": "Johnny123",
  • "message": "Sample message",
  • "amounts": {
    },
  • "createdAt": "2020-08-13T09:05:36.939Z",
  • "updatedAt": "2020-08-13T09:05:36.939Z"
}