Anchor to section titled 'undefined'

publishablePublish
mutation

Requires write_publications access scope. Also: The user must have permission to create and edit products or create and edit catalogs.

Publishes a resource to a channel. If the resource is a product, then it's visible in the channel only if the product status is active. Products that are sold exclusively on subscription (requiresSellingPlan: true) can be published only on online stores.


Anchor to id
id
required

The resource to create or update publications for.

Specifies the input fields required to publish a resource.


Was this section helpful?

Resource that has been published.

The user's shop.

The list of errors that occurred from executing the mutation.


Was this section helpful?

Examples

Hide code
Copy
mutation PublishablePublish($collectionId: ID!, $publicationId: ID!) {
publishablePublish(id: $collectionId, input: {publicationId: $publicationId}) {
publishable {
publishedOnPublication(publicationId: $publicationId)
}
userErrors {
field
message
}
}
}
curl -X POST \
https://your-development-store.myshopify.com/admin/api/2025-01/graphql.json \
-H 'Content-Type: application/json' \
-H 'X-Shopify-Access-Token: {access_token}' \
-d '{
"query": "mutation PublishablePublish($collectionId: ID!, $publicationId: ID!) { publishablePublish(id: $collectionId, input: {publicationId: $publicationId}) { publishable { publishedOnPublication(publicationId: $publicationId) } userErrors { field message } } }",
"variables": {
"collectionId": "gid://shopify/Collection/636030761",
"publicationId": "gid://shopify/Publication/762454635"
}
}'

const { admin } = await authenticate.admin(request);

const response = await admin.graphql(
`#graphql
mutation PublishablePublish($collectionId: ID!, $publicationId: ID!) {
publishablePublish(id: $collectionId, input: {publicationId: $publicationId}) {
publishable {
publishedOnPublication(publicationId: $publicationId)
}
userErrors {
field
message
}
}
}`,
{
variables: {
"collectionId": "gid://shopify/Collection/636030761",
"publicationId": "gid://shopify/Publication/762454635"
},
},
);

const data = await response.json();

session = ShopifyAPI::Auth::Session.new(
shop: "your-development-store.myshopify.com",
access_token: access_token
)
client = ShopifyAPI::Clients::Graphql::Admin.new(
session: session
)

query = <<~QUERY
mutation PublishablePublish($collectionId: ID!, $publicationId: ID!) {
publishablePublish(id: $collectionId, input: {publicationId: $publicationId}) {
publishable {
publishedOnPublication(publicationId: $publicationId)
}
userErrors {
field
message
}
}
}
QUERY

variables = {
"collectionId": "gid://shopify/Collection/636030761",
"publicationId": "gid://shopify/Publication/762454635"
}

const client = new shopify.clients.Graphql({session});
const data = await client.query({
data: {
"query": `mutation PublishablePublish($collectionId: ID!, $publicationId: ID!) {
publishablePublish(id: $collectionId, input: {publicationId: $publicationId}) {
publishable {
publishedOnPublication(publicationId: $publicationId)
}
userErrors {
field
message
}
}
}`,
"variables": {
"collectionId": "gid://shopify/Collection/636030761",
"publicationId": "gid://shopify/Publication/762454635"
},
},
});

use Shopify\Clients\Graphql;

$client = new Graphql("your-development-store.myshopify.com", $accessToken);
$query = <<<QUERY
mutation PublishablePublish($collectionId: ID!, $publicationId: ID!) {
publishablePublish(id: $collectionId, input: {publicationId: $publicationId}) {
publishable {
publishedOnPublication(publicationId: $publicationId)
}
userErrors {
field
message
}
}
}
QUERY;

$variables = [
"collectionId" => "gid://shopify/Collection/636030761",
"publicationId" => "gid://shopify/Publication/762454635",
];

$response = $client->query(["query" => $query, "variables" => $variables]);

Hide code
Input variables
Copy
{
"collectionId": "gid://shopify/Collection/636030761",
"publicationId": "gid://shopify/Publication/762454635"
}

Hide code
Response
JSON
{
"publishablePublish": {
"publishable": {
"publishedOnPublication": true
},
"userErrors": []
}
}