← Linear (API key) + Shopify (OAuth) integrations

Update Product Variant with Shopify (OAuth) API on New Issue Status Updated (Instant) from Linear (API key) API

Pipedream makes it easy to connect APIs for Shopify (OAuth), Linear (API key) and 2,500+ other apps remarkably fast.

Trigger workflow on
New Issue Status Updated (Instant) from the Linear (API key) API
Next, do this
Update Product Variant with the Shopify (OAuth) API
No credit card required
Intro to Pipedream
Watch us build a workflow
Watch us build a workflow
8 min
Watch now ➜

Trusted by 1,000,000+ developers from startups to Fortune 500 companies

Adyen logo
Appcues logo
Bandwidth logo
Checkr logo
ChartMogul logo
Dataminr logo
Gopuff logo
Gorgias logo
LinkedIn logo
Logitech logo
Replicated logo
Rudderstack logo
SAS logo
Scale AI logo
Webflow logo
Warner Bros. logo
Adyen logo
Appcues logo
Bandwidth logo
Checkr logo
ChartMogul logo
Dataminr logo
Gopuff logo
Gorgias logo
LinkedIn logo
Logitech logo
Replicated logo
Rudderstack logo
SAS logo
Scale AI logo
Webflow logo
Warner Bros. logo

Developers Pipedream

Getting Started

This integration creates a workflow with a Linear (API key) trigger and Shopify (OAuth) action. When you configure and deploy the workflow, it will run on Pipedream's servers 24x7 for free.

  1. Select this integration
  2. Configure the New Issue Status Updated (Instant) trigger
    1. Connect your Linear (API key) account
    2. Select a Team ID
    3. Optional- Select a Project
    4. Optional- Select a State (Status)
  3. Configure the Update Product Variant action
    1. Connect your Shopify (OAuth) account
    2. Select a Product ID
    3. Select a Product Variant ID
    4. Optional- Select one or more Options
    5. Optional- Configure Price
    6. Optional- Configure Image
    7. Optional- Configure Sku
    8. Optional- Configure Barcode
    9. Optional- Configure Weight
    10. Optional- Select a Weight Unit
    11. Optional- Configure Metafields
  4. Deploy the workflow
  5. Send a test event to validate your setup
  6. Turn on the trigger

Details

This integration uses pre-built, source-available components from Pipedream's GitHub repo. These components are developed by Pipedream and the community, and verified and maintained by Pipedream.

To contribute an update to an existing component or create a new component, create a PR on GitHub. If you're new to Pipedream component development, you can start with quickstarts for trigger span and action development, and then review the component API reference.

Trigger

Description:Emit new event when the status of an issue is updated. [See the documentation](https://developers.linear.app/docs/graphql/webhooks)
Version:0.1.10
Key:linear_app-new-issue-status-updated

Linear (API key) Overview

Linear helps streamline software project management, bug tracking, and task coordination. By using the Linear (API key) API with Pipedream, you can automate routine tasks, sync issues across platforms, and trigger custom workflows. Think auto-assignment of tasks based on specific triggers or pushing updates to a Slack channel when an issue's status changes. These automations save time and ensure that your development team stays focused on coding rather than on administrative overhead.

Trigger Code

import common from "../common/webhook.mjs";
import constants from "../../common/constants.mjs";
import utils from "../../common/utils.mjs";

export default {
  ...common,
  key: "linear_app-new-issue-status-updated",
  name: "New Issue Status Updated (Instant)",
  description: "Emit new event when the status of an issue is updated. [See the documentation](https://developers.linear.app/docs/graphql/webhooks)",
  type: "source",
  version: "0.1.10",
  dedupe: "unique",
  props: {
    linearApp: common.props.linearApp,
    db: "$.service.db",
    teamId: {
      label: "Team ID",
      type: "string",
      propDefinition: [
        common.props.linearApp,
        "teamId",
      ],
      reloadProps: true,
    },
    projectId: {
      propDefinition: [
        common.props.linearApp,
        "projectId",
      ],
    },
    stateId: {
      propDefinition: [
        common.props.linearApp,
        "stateId",
        ({ teamId }) => ({
          teamId,
        }),
      ],
      description: "Emit issues that are updated to this state",
    },
  },
  methods: {
    ...common.methods,
    _getPreviousStatuses() {
      return this.db.get("previousStatuses") || {};
    },
    _setPreviousStatuses(previousStatuses) {
      this.db.set("previousStatuses", previousStatuses);
    },
    getResourceTypes() {
      return [
        constants.RESOURCE_TYPE.ISSUE,
      ];
    },
    getWebhookLabel() {
      return "Issue status updated";
    },
    getResourcesFn() {
      return this.linearApp.listIssues;
    },
    getResourcesFnArgs() {
      return {
        sortBy: "updatedAt",
        filter: {
          team: this.teamId && {
            id: {
              in: [
                this.teamId,
              ],
            },
          },
          project: {
            id: {
              eq: this.projectId,
            },
          },
          state: {
            id: {
              eq: this.stateId,
            },
          },
        },
      };
    },
    isRelevant(body) {
      return body?.updatedFrom?.stateId && (!this.stateId || body.data.stateId === this.stateId);
    },
    getResource(issue) {
      return this.linearApp.getIssue({
        issueId: issue.id,
      });
    },
    getMetadata(resource) {
      const {
        delivery,
        title,
        data,
        updatedAt,
      } = resource;
      const ts = Date.parse(updatedAt);
      return {
        id: delivery || `${resource.id}-${ts}`,
        summary: `Issue status updated: ${data?.title || title}`,
        ts,
      };
    },
    async emitPolledResources() {
      const previousStatuses = this._getPreviousStatuses();
      const newStatuses = {};

      // Use the specified limit or default to a reasonable number
      const maxLimit = this.limit || constants.DEFAULT_NO_QUERY_LIMIT;

      const stream = this.linearApp.paginateResources({
        resourcesFn: this.getResourcesFn(),
        resourcesFnArgs: this.getResourcesFnArgs(),
        useGraphQl: this.useGraphQl(),
        max: maxLimit, // Use the configured limit instead of hardcoded 1000
      });
      const resources = await utils.streamIterator(stream);

      const updatedResources = [];
      for (const issue of resources) {
        newStatuses[issue.id] = issue.state.id;
        if (issue.createdAt === issue.updatedAt) {
          continue;
        }
        if (previousStatuses[issue.id] !== issue.state.id) {
          updatedResources.push(issue);
        }
      }

      this._setPreviousStatuses(newStatuses);

      updatedResources
        .reverse()
        .forEach((resource) => {
          this.$emit(resource, this.getMetadata(resource));
        });
    },
  },
};

Trigger Configuration

This component may be configured based on the props defined in the component code. Pipedream automatically prompts for input values in the UI and CLI.
LabelPropTypeDescription
Linear (API key)linearAppappThis component uses the Linear (API key) app.
N/Adb$.service.dbThis component uses $.service.db to maintain state between executions.
Team IDteamIdstringSelect a value from the drop down menu.
ProjectprojectIdstringSelect a value from the drop down menu.
State (Status)stateIdstringSelect a value from the drop down menu.

Trigger Authentication

Linear (API key) uses API keys for authentication. When you connect your Linear (API key) account, Pipedream securely stores the keys so you can easily authenticate to Linear (API key) APIs in both code and no-code steps.

About Linear (API key)

Linear helps streamline software projects, sprints, tasks, and bug tracking. It's built for high-performance teams.

Action

Description:Update an existing product variant. [See the documentation](https://shopify.dev/docs/api/admin-graphql/latest/mutations/productVariantsBulkUpdate)
Version:0.0.16
Key:shopify-update-product-variant

Shopify (OAuth) Overview

Shopify provides a powerful API that enables developers to build a wide range
of applications and tools for merchants. Some examples of what you can build
using the Shopify API include:

  • Merchant tools: tools that help merchants manage their stores, such as order
    management, product administration, and reporting
  • E-commerce applications: applications that enable merchants to sell their
    products online, such as shopping carts, product catalogs, and order
    management
  • Integration tools: tools that helps integrate Shopify with other systems,
    such as accounting, inventory, and shipping

Action Code

import shopify from "../../shopify.app.mjs";
import utils from "../../common/utils.mjs";
import {
  MAX_LIMIT, WEIGHT_UNITS,
} from "../../common/constants.mjs";
import { ConfigurationError } from "@pipedream/platform";

export default {
  key: "shopify-update-product-variant",
  name: "Update Product Variant",
  description: "Update an existing product variant. [See the documentation](https://shopify.dev/docs/api/admin-graphql/latest/mutations/productVariantsBulkUpdate)",
  version: "0.0.16",
  type: "action",
  props: {
    shopify,
    productId: {
      propDefinition: [
        shopify,
        "productId",
      ],
    },
    productVariantId: {
      propDefinition: [
        shopify,
        "productVariantId",
        (c) => ({
          productId: c.productId,
        }),
      ],
    },
    optionIds: {
      propDefinition: [
        shopify,
        "productOptionIds",
        (c) => ({
          productId: c.productId,
        }),
      ],
      optional: true,
    },
    price: {
      type: "string",
      label: "Price",
      description: "The price of the product variant",
      optional: true,
    },
    image: {
      type: "string",
      label: "Image",
      description: "The URL of an image to be added to the product variant",
      optional: true,
    },
    sku: {
      type: "string",
      label: "Sku",
      description: "A unique identifier for the product variant in the shop",
      optional: true,
    },
    barcode: {
      type: "string",
      label: "Barcode",
      description: "The barcode, UPC, or ISBN number for the product",
      optional: true,
    },
    weight: {
      type: "string",
      label: "Weight",
      description: "The weight of the product variant in the unit system specified with Weight Unit",
      optional: true,
    },
    weightUnit: {
      type: "string",
      label: "Weight Unit",
      description: "The unit of measurement that applies to the product variant's weight. If you don't specify a value for weight_unit, then the shop's default unit of measurement is applied.",
      optional: true,
      options: WEIGHT_UNITS,
    },
    metafields: {
      propDefinition: [
        shopify,
        "metafields",
      ],
    },
  },
  methods: {
    async getOptionValues() {
      const { product: { options } } = await this.shopify.getProduct({
        id: this.productId,
        first: MAX_LIMIT,
      });
      const productOptions = {};
      for (const option of options) {
        for (const optionValue of option.optionValues) {
          productOptions[optionValue.id] = option.id;
        }
      }
      const optionValues = this.optionIds.map((id) => ({
        id,
        optionId: productOptions[id],
      }));
      return optionValues;
    },
  },
  async run({ $ }) {
    if ((this.weightUnit && !this.weight) || (!this.weightUnit && this.weight)) {
      throw new ConfigurationError("Must enter both Weight and Weight Unit to set weight");
    }

    const response = await this.shopify.updateProductVariant({
      productId: this.productId,
      variants: [
        {
          id: this.productVariantId,
          optionValues: this.optionIds && await this.getOptionValues(),
          price: this.price,
          mediaSrc: this.image,
          barcode: this.barcode,
          inventoryItem: (this.sku || this.weightUnit || this.weight) && {
            sku: this.sku,
            measurement: (this.weightUnit || this.weight) && {
              weight: {
                unit: this.weightUnit,
                value: +this.weight,
              },
            },
          },
          metafields: this.metafields && utils.parseJson(this.metafields),
        },
      ],
    });
    if (response.productVariantsBulkUpdate.userErrors.length > 0) {
      throw new Error(response.productVariantsBulkUpdate.userErrors[0].message);
    }
    $.export("$summary", `Created new product variant \`${response.productVariantsBulkUpdate.productVariants[0].title}\` with ID \`${response.productVariantsBulkUpdate.productVariants[0].id}\``);
    return response;
  },
};

Action Configuration

This component may be configured based on the props defined in the component code. Pipedream automatically prompts for input values in the UI.

LabelPropTypeDescription
Shopify (OAuth)shopifyappThis component uses the Shopify (OAuth) app.
Product IDproductIdstringSelect a value from the drop down menu.
Product Variant IDproductVariantIdstringSelect a value from the drop down menu.
OptionsoptionIdsstring[]Select a value from the drop down menu.
Pricepricestring

The price of the product variant

Imageimagestring

The URL of an image to be added to the product variant

Skuskustring

A unique identifier for the product variant in the shop

Barcodebarcodestring

The barcode, UPC, or ISBN number for the product

Weightweightstring

The weight of the product variant in the unit system specified with Weight Unit

Weight UnitweightUnitstringSelect a value from the drop down menu:KILOGRAMSGRAMSPOUNDSOUNCES
Metafieldsmetafieldsstring[]

An array of objects, each one representing a metafield. If adding a new metafield, the object should contain key, value, type, and namespace. Example: {{ [{ "key": "new", "value": "newvalue", "type": "single_line_text_field", "namespace": "global" }] }}. To update an existing metafield, use the id and value. Example: {{ [{ "id": "28408051400984", "value": "updatedvalue" }] }}

Action Authentication

Shopify (OAuth) uses OAuth authentication. When you connect your Shopify (OAuth) account, Pipedream will open a popup window where you can sign into Shopify (OAuth) and grant Pipedream permission to connect to your account. Pipedream securely stores and automatically refreshes the OAuth tokens so you can easily authenticate any Shopify (OAuth) API.

Pipedream requests the following authorization scopes when you connect your account:

About Shopify (OAuth)

Shopify is a complete commerce platform that lets anyone start, manage, and grow a business. You can use Shopify to build an online store, manage sales, market to customers, and accept payments in digital and physical locations.

More Ways to Connect Shopify (OAuth) + Linear (API key)

Create Issue with Linear (API key) API on New Abandoned Cart from Shopify (OAuth) API
Shopify (OAuth) + Linear (API key)
 
Try it
Create Issue with Linear (API key) API on New Article from Shopify (OAuth) API
Shopify (OAuth) + Linear (API key)
 
Try it
Create issue with Linear (API key) API on New Customer from Shopify API
Shopify (OAuth) + Linear (API key)
 
Try it
Create issue with Linear (API key) API on New Events from Shopify API
Shopify (OAuth) + Linear (API key)
 
Try it
Create issue with Linear (API key) API on New Order from Shopify API
Shopify (OAuth) + Linear (API key)
 
Try it
New Created Comment (Instant) from the Linear (API key) API

Emit new event when a new comment is created. See the documentation

 
Try it
New Created Issue (Instant) from the Linear (API key) API

Emit new event when a new issue is created. See the documentation

 
Try it
New Issue Status Updated (Instant) from the Linear (API key) API

Emit new event when the status of an issue is updated. See the documentation

 
Try it
New Project Update Written (Instant) from the Linear (API key) API

Project updates are short status reports on the health of your projects. Emit new event when a new Project Update is written. See the documentation

 
Try it
New Updated Issue (Instant) from the Linear (API key) API

Emit new event when an issue is updated. See the documentation

 
Try it
Create Issue with the Linear (API key) API

Create an issue (API Key). See the docs here

 
Try it
Get Issue with the Linear (API key) API

Get an issue by ID (API Key). See the docs here

 
Try it
Get Teams with the Linear (API key) API

Get all the teams (API Key). See the docs here

 
Try it
Search Issues with the Linear (API key) API

Search issues (API Key). See the docs here

 
Try it
Update Issue with the Linear (API key) API

Update an issue (API Key). See the docs here

 
Try it

Explore Other Apps

1
-
24
of
2,500+
apps by most popular

HTTP / Webhook
HTTP / Webhook
Get a unique URL where you can send HTTP or webhook requests
Node
Node
Anything you can do with Node.js, you can do in a Pipedream workflow. This includes using most of npm's 400,000+ packages.
Python
Python
Anything you can do in Python can be done in a Pipedream Workflow. This includes using any of the 350,000+ PyPi packages available in your Python powered workflows.
Pipedream Utils
Pipedream Utils
Utility functions to use within your Pipedream workflows
OpenAI (ChatGPT)
OpenAI (ChatGPT)
OpenAI is an AI research and deployment company with the mission to ensure that artificial general intelligence benefits all of humanity. They are the makers of popular models like ChatGPT, DALL-E, and Whisper.
Premium
Salesforce
Salesforce
Cloud-based customer relationship management (CRM) platform that helps businesses manage sales, marketing, customer support, and other business activities, ultimately aiming to improve customer relationships and streamline operations.
Premium
HubSpot
HubSpot
HubSpot's CRM platform contains the marketing, sales, service, operations, and website-building software you need to grow your business.
Premium
Zoho CRM
Zoho CRM
Zoho CRM is an online Sales CRM software that manages your sales, marketing, and support in one CRM platform.
Premium
Stripe
Stripe
Stripe powers online and in-person payment processing and financial solutions for businesses of all sizes.
Shopify
Shopify
Shopify is a complete commerce platform that lets anyone start, manage, and grow a business. You can use Shopify to build an online store, manage sales, market to customers, and accept payments in digital and physical locations.
Premium
WooCommerce
WooCommerce
WooCommerce is the open-source ecommerce platform for WordPress.
Premium
Snowflake
Snowflake
A data warehouse built for the cloud
Premium
MongoDB
MongoDB
MongoDB is an open source NoSQL database management program.
Supabase
Supabase
Supabase is an open source Firebase alternative.
MySQL
MySQL
MySQL is an open-source relational database management system.
PostgreSQL
PostgreSQL
PostgreSQL is a free and open-source relational database management system emphasizing extensibility and SQL compliance.
Premium
AWS
AWS
Amazon Web Services (AWS) offers reliable, scalable, and inexpensive cloud computing services.
Premium
Twilio SendGrid
Twilio SendGrid
Send marketing and transactional email through the Twilio SendGrid platform with the Email API, proprietary mail transfer agent, and infrastructure for scalable delivery.
Amazon SES
Amazon SES
Amazon SES is a cloud-based email service provider that can integrate into any application for high volume email automation
Premium
Klaviyo
Klaviyo
Email Marketing and SMS Marketing Platform
Premium
Zendesk
Zendesk
Zendesk is award-winning customer service software trusted by 200K+ customers. Make customers happy via text, mobile, phone, email, live chat, social media.
Premium
ServiceNow
ServiceNow
The smarter way to workflow
Notion
Notion
Notion is a new tool that blends your everyday work apps into one. It's the all-in-one workspace for you and your team.
Slack
Slack
Slack is a channel-based messaging platform. With Slack, people can work together more effectively, connect all their software tools and services, and find the information they need to do their best work — all within a secure, enterprise-grade environment.