FROM CACHE - jp_header
このコミュニティはピアツーピアサポートに移行しました。Shopify サポートは今後、このコミュニティへのサービスを提供いたしません。これからもぜひ、他のマーチャントやパートナーとつながり、サポートし合い、経験を共有してください。 当社の行動規範に違反する行動や削除を希望するコンテンツがありましたら、引き続きご報告ください

Lambda から Shopify Admin API を叩く方法

解決済

Lambda から Shopify Admin API を叩く方法

EijiSaito
Shopify Partner
27 2 2

@junichiokamura 
【質問】
Amazon EventBridge で実行される Lambda 関数から Shopify Admin API を叩く方法はありますでしょうか?

 

【背景】
現在、Shopify アプリの作成を行っております。
アプリの機能で、Amazon EventBridge, Lambda を使用して商品情報を取得、更新する処理(定期実行)を行いたいと考えております。

 

アプリをインストールしているストアのアクセストークン等をどのようにして取得、保存するのか(保存する必要がある、ない等)をご教授いただけますと幸いです。

株式会社UnReact


Shopify Expertとして、Shopify ストア構築・運用やアプリ開発に至るまで幅広く活動しています。

1 件の受理された解決策

junichiokamura
Community Manager
1201 280 509

成功

AWS Lambda + API Gatewayを使えば可能です。

 

ただし、Shopify CLIが作成するRemix Templateやその他のTemplateは、フロントとバックエンドが一体でスタンドアロンで動くことを想定しており、Paas(Heroku、Vercel、Beanstalk、Render、Fly.io, etc.) やEC2向けなので、Lambdaではそのまま使えません。

 

AWS Lambdaなど、Faasのレイヤーでホスティングするには、基本的にご自身で一から(スクラッチで)アプリを作っていただくことになります。

参考までに私のスクラッチから作ったアプリのコードですが、ここのルートとコールバックの処理は、LambdaのNode.jsの雛形に移植可能かと思います。

https://github.com/benzookapi/shopify-barebone-app-sample/blob/main/app.js

アプリインストールのOAuthがpublicなURLを求めるので、Lambda単体では作れませんが、APIのURLをAPI Gatewayなどのフロントのものにすることで可能です。

取得したアクセストークンは、DynamoDBなどでストアごとに格納(自分のコードではRDBやMongoDBに格納していますが、同じようにできます)、アプリのUIはPolarisとApp Bridgeを単独で利用して(自分のコードではReact + viteを使っています)、それをS3 Bucketにホストして、同じくAPI Gatewayと通信してLambdaの処理を呼び出すこと可能です。

いずれにしても、CLIのtemplateのscaffoldの恩恵は失われるので、以下の公式サイトを見ながら、使われている技術や実装を細かく把握する必要があります。
https://shopify.dev/

 

(私のアプリは機能自体がチュートリアルになっているので、よかったらビルド、インストールしてお試しください)

 

Senior Partner Solutions Engineer

元の投稿で解決策を見る

2件の返信2

テックギーク運営者
Shopify Partner
33 3 12

Shopifyアプリ開発スクールのテックギークを運営している森本と言います。

 

まず、アプリインストール時にアクセストークンを含むセッショントークンをDynamoDBなど、ご自身で用意したDBに保存する必要があります。

Node.jsのShopifyアプリのテンプレートをお使いであれば、MySQL, PostgreSQL, DynamoDBなどのDBに保存できるモジュールが用意されています。

Node.jsのテンプレートを使っている場合、EventBridge経由でShopify Admin API を実行するには、ストアのドメインがわかればリクエスト可能になります。

例:

const { admin } = await shopify.unauthenticated.admin(ストアドメイン); 
const response = await admin.graphql( `
  #graphql query {
    shop {
      name
    }
  }
}`);
const responseJson = await response.json();

 

junichiokamura
Community Manager
1201 280 509

成功

AWS Lambda + API Gatewayを使えば可能です。

 

ただし、Shopify CLIが作成するRemix Templateやその他のTemplateは、フロントとバックエンドが一体でスタンドアロンで動くことを想定しており、Paas(Heroku、Vercel、Beanstalk、Render、Fly.io, etc.) やEC2向けなので、Lambdaではそのまま使えません。

 

AWS Lambdaなど、Faasのレイヤーでホスティングするには、基本的にご自身で一から(スクラッチで)アプリを作っていただくことになります。

参考までに私のスクラッチから作ったアプリのコードですが、ここのルートとコールバックの処理は、LambdaのNode.jsの雛形に移植可能かと思います。

https://github.com/benzookapi/shopify-barebone-app-sample/blob/main/app.js

アプリインストールのOAuthがpublicなURLを求めるので、Lambda単体では作れませんが、APIのURLをAPI Gatewayなどのフロントのものにすることで可能です。

取得したアクセストークンは、DynamoDBなどでストアごとに格納(自分のコードではRDBやMongoDBに格納していますが、同じようにできます)、アプリのUIはPolarisとApp Bridgeを単独で利用して(自分のコードではReact + viteを使っています)、それをS3 Bucketにホストして、同じくAPI Gatewayと通信してLambdaの処理を呼び出すこと可能です。

いずれにしても、CLIのtemplateのscaffoldの恩恵は失われるので、以下の公式サイトを見ながら、使われている技術や実装を細かく把握する必要があります。
https://shopify.dev/

 

(私のアプリは機能自体がチュートリアルになっているので、よかったらビルド、インストールしてお試しください)

 

Senior Partner Solutions Engineer