-
Notifications
You must be signed in to change notification settings - Fork 52
DEVDOCS-5858:[new] add headless channel doc #715
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from all commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
fd35c2f
DEVDOCS-5858:[new] add headless channel doc
bc-traciporter c981e3a
fix errror
bc-traciporter 6ff4d78
Update docs/b2b-edition/headless.mdx
bc-traciporter f1a3098
Update docs/b2b-edition/headless.mdx
bc-traciporter 0e4df78
Update docs/b2b-edition/headless.mdx
bc-traciporter 33b6ac2
Update docs/b2b-edition/headless.mdx
bc-traciporter 95ebaaf
removed callout
bc-traciporter 975bec9
fix linter errors
bc-traciporter e1cdc33
Merge branch 'main' into DEVDOCS-5858
bc-traciporter File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
# Creating Channels | ||
|
||
<Steps> | ||
|
||
### Prepare | ||
|
||
You will need to create two API tokens for your BigCommerce store. They have different permissions required, so please pay attention to which one is used for the step you are working on. Refer to this [support article](https://support.bigcommerce.com/s/article/Store-API-Accounts?language=en_US#:~:text=Level%20API%20Accounts-,1.,to%20use%20the%20API%20account) for more information on how to create API Accounts. | ||
|
||
* Create a token (TOKEN_A) with modify permissions for the following resources: | ||
- Channel listings | ||
- Channel settings | ||
- Sites & routes | ||
|
||
* Create a token (TOKEN_B) with modify permissions for the following resources: | ||
- Carts | ||
- Storefront API tokens | ||
- Storefront API customer impersonation tokens | ||
|
||
<Callout type="info"> | ||
Tokens are created using the API path `https://{storehash}.mybigcommerce.com/manage/settings/api-account`. | ||
</Callout> | ||
|
||
Also check that you have multi-storefront feature enabled and available seats. | ||
|
||
### Create the channel | ||
|
||
Send a request to the [Create a channel](/docs/rest-management/channels#create-a-channel) endpoint using TOKEN_A to create a channel for your headless platform. Note the channel ID returned in the response; you'll use it in successive steps. | ||
|
||
```http filename="Example request: Create channel" showLineNumbers copy | ||
POST https://api.bigcommerce.com/stores/{store_hash}/v3/channels | ||
Accept: application/json | ||
Content-Type: application/json | ||
X-Auth-Token: {{TOKEN_A}} | ||
|
||
{ | ||
"name": "<the name you want for your channel>", | ||
"platform": "<desired platform>", | ||
"type": "storefront", | ||
"status": "active", | ||
"is_listable_from_ui": true, | ||
"is_visible": true | ||
} | ||
``` | ||
|
||
<Callout type="info"> | ||
Currently we’re working with [Vercel template, and that uses NextJS](https://github.com/B3BC/b2b-headless-example). | ||
</Callout> | ||
|
||
### Generate an impersonation token | ||
|
||
[Generate an impersonation token](/docs/storefront-auth/tokens/customer-impersonation-token) by using the next cURL as base and using TOKEN_B. | ||
|
||
```http filename="Example request: Create an impersonation token" showLineNumbers copy | ||
POST https://api.bigcommerce.com/stores/{store_hash}/v3/storefront/api-token-customer-impersonation | ||
Accept: application/json | ||
Content-Type: application/json | ||
X-Auth-Token: {{TOKEN_B}} | ||
|
||
{ | ||
"channel_id": <channel returned on the first request>, | ||
"expires_at": <Unix timestamp (UTC time) defining when the token should expire. Supports seconds, but does not support milliseconds, microseconds, or nanoseconds.> | ||
} | ||
``` | ||
|
||
### Create a site for the channel | ||
|
||
[Create the site for the channel](/docs/rest-management/sites#create-a-site), you should use TOKEN_A. | ||
|
||
```http filename="Example request: Create an impersonation token" showLineNumbers copy | ||
POST https://api.bigcommerce.com/stores/{store_hash}/v3/sites | ||
Accept: application/json | ||
Content-Type: application/json | ||
X-Auth-Token: {{TOKEN_A}} | ||
|
||
{ | ||
"url": <url you want to point>, | ||
"channel_id": <the channel id returned on step 1> | ||
} | ||
``` | ||
|
||
### Update script tag information | ||
|
||
Add the following script tag on your application. | ||
|
||
```html copy | ||
<script> | ||
type="module" | ||
data-storehash="{STORE_HASH}" | ||
data-channelid="{CHANNEL_ID}" | ||
src="https://cdn.bundleb2b.net/b2b/production/storefront/headless.js"> | ||
</script> | ||
``` | ||
### Enable headless channel on the B2B dashboard | ||
|
||
In the B2B dashboard, go to **Storefronts** > **Headless Storefronts** and select **Activate B2B** for the storefront channel. | ||
|
||
### Make products available on your new channel | ||
|
||
In the control panel, go to **Products** > **View** and select all the products you want to make available on the new channel. Then click **Bulk Actions** > **Add to channels**. Next, select the desired channels and click **Add**. | ||
|
||
</Steps> |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.