ShopifyLメタ拡張

ShopifyLメタ拡張

Shopify+Laravel連携の概要

Shopify+Laravelは、ShopifyのAPIとLaravelのエコシステムを組み合わせて、柔軟なバックエンドを構築する手法です。LaravelのEloquentやサービスプロバイダを活用し、Shopifyのデータを効率的に取得・更新できます。

Metafield APIでカスタムデータを扱う

Metafield APIは、商品や顧客などに対して独自のメタデータを追加できる強力な機能です。LaravelからはHTTPクライアントを使い、POST /admin/api/2026-01/metafields.json でカスタムデータを保存します。

データ定義と独自項目の設計

データ定義は、namespace App\Metafields; 内にクラスを作成し、namespacekey を明確にします。独自の項目は、名前空間を分けることで衝突を防ぎ、再利用性を高めます。

商品情報拡張の実装例

商品情報拡張では、product.metafields に「保証期間」や「素材情報」を追加します。Laravelのコントローラで取得したデータをビューに渡し、フロント表示に反映させます。

店舗設定とAPI保存

店舗設定は、ShopifyApp パッケージを利用して、OAuth認証後にアクセストークンを安全に保存します。API保存は、Metafield API を通じて行い、設定値を永続化します。

フロント表示への反映

フロント表示では、Bladeテンプレートで{{ $product->metafields->get('custom:material') }} のように呼び出し、ユーザーにカスタムデータを提示します。レスポンシブデザインを意識し、モバイルでも見やすいレイアウトを実装します。

データ構造のベストプラクティス

データ構造は、階層化されたJSONを採用し、namespace: key で一意に管理します。これにより、メタフィールドの検索や更新が高速化され、スケーラビリティが向上します。

この記事はAIによって作成されました。

Shopify Laravel連携術

Shopify Laravel連携術

Shopify+Laravel連携の概要

Shopify+Laravel は、Shopify の API と Laravel のフレームワークを組み合わせて、オンラインストアのデータを効率的に管理するための統合ソリューションです。Laravel の豊富なエコシステムと、Shopify の豊富な機能を活かすことで、商品情報や注文情報をリアルタイムで同期し、ビジネスプロセスを自動化できます。

この連携を実現するためには、まず データベース連携 を確立し、Shopify から取得したデータを Laravel の Eloquentモデル にマッピングします。さらに、マイグレーション を使ってテーブル構造を定義し、独自テーブル を作成することで、Shopify のデータをカスタムに保存できます。

データベース連携とマイグレーション

まず、マイグレーションを作成して、Shopify のデータを格納するテーブルを定義します。以下は、Shopモデル用のマイグレーション例です。

php artisan make:migration create_shops_table --create=shops
Schema::create('shops', function (Blueprint $table) {
    $table->id();
    $table->string('shopify_id')->unique();
    $table->string('name');
    $table->string('domain')->unique();
    $table->timestamps();
});

同様に、Userモデルと連携するためのテーブルも作成します。Shopify のユーザー情報を 独自テーブル に保存し、リレーション を設定することで、ユーザーとショップの関係を簡単に管理できます。

マイグレーションを実行すると、データベースにテーブルが作成され、Laravel の Eloquentモデル から直接操作できるようになります。

Eloquentモデルとリレーション

ShopモデルとUserモデルを Eloquent で定義し、リレーションを設定します。以下は、Shopモデルの例です。

class Shop extends Model
{
    protected $fillable = ['shopify_id', 'name', 'domain'];

    public function users()
    {
        return $this->hasMany(User::class);
    }
}

Userモデルは次のように定義します。

class User extends Model
{
    protected $fillable = ['name', 'email', 'shop_id'];

    public function shop()
    {
        return $this->belongsTo(Shop::class);
    }
}

このリレーションにより、データ保存時に Shop と User を結びつけることができます。例えば、Shopify から取得した注文情報を保存する際に、関連するユーザーを自動で紐付けることが可能です。

設定保存とキャッシュの活用

Shopify の API キーやシークレットキー、Webhook の設定などは、設定保存の対象です。Laravel の config ディレクトリに設定ファイルを作成し、env 変数で管理します。

// config/shopify.php
return [
    'api_key' => env('SHOPIFY_API_KEY'),
    'secret' => env('SHOPIFY_SECRET'),
    'scopes' => env('SHOPIFY_SCOPES', 'read_products,write_orders'),
];

設定値は頻繁に読み込まれるため、キャッシュを利用して高速化します。Laravel のキャッシュファサードを使い、設定をメモリに保持することで、API 呼び出し時のオーバーヘッドを削減できます。

$apiKey = Cache::remember('shopify_api_key', 3600, function () {
    return config('shopify.api_key');
});

さらに、Shopify から取得した商品情報や注文情報もキャッシュに保存し、同じデータへの重複リクエストを防止します。これにより、API レートリミットを超えるリスクを低減し、アプリケーションの安定性を向上させます。

この記事はAIによって作成されました。

Shopify Laravel Webhook非同期

Shopify Laravel Webhook非同期

Shopify+LaravelでWebhookを受け取る

Shopifyは注文が発生するとWebhookで通知を送信します。Laravel側では、routes/web.phpにエンドポイントを定義し、ShopifyWebhookControllerで処理します。ここでは、POST /shopify/webhookを想定し、Shopifyから送られるJSONペイロードを取得します。

Route::post('/shopify/webhook', [ShopifyWebhookController::class, 'handle']);

Laravelのリクエストオブジェクトからヘッダーとボディを取得し、後続の処理へ渡します。

署名検証とセキュリティ

ShopifyはX-Shopify-Hmac-Sha256ヘッダーに署名を付与します。Laravel側で検証することで、改ざんや偽装を防止します。以下は検証ロジックの例です。

$hmacHeader = $request->header('X-Shopify-Hmac-Sha256');
$calculatedHmac = base64_encode(hash_hmac('sha256', $request->getContent(), config('shopify.secret'), true));
if (!hash_equals($hmacHeader, $calculatedHmac)) {
    abort(401, 'Invalid signature');
}

署名検証に失敗したリクエストは即座に拒否し、ログに記録します。

イベントリスナーと非同期処理

Webhook受信後、イベントを発火させます。ShopifyOrderCreatedイベントを定義し、OrderCreatedListenerで非同期ジョブをキューに投入します。これにより、HTTPレスポンスは即座に返却され、Shopify側のタイムアウトを回避します。

event(new ShopifyOrderCreated($orderData));

イベントリスナーはShouldQueueを実装し、handleメソッドでProcessOrderJobをdispatchします。

Jobs/OrdersCreate と Queue の連携

ProcessOrderJobOrdersCreateジョブを呼び出し、Shopifyの注文情報をローカルDBへ保存します。ジョブはqueue:workで実行され、retryUntilで最大再試行時間を設定します。

public function handle()
{
    try {
        // 注文データをDBへ保存
        Order::create($this->orderData);
    } catch (\Exception $e) {
        // 失敗時は再試行
        throw $e;
    }
}

QueueはRedisやAmazon SQSを利用し、スケールアウトが容易です。

失敗時の再試行とログ記録

LaravelのジョブはtriesretryAfterを設定できます。失敗時にfailedメソッドでログを残し、Slackやメールで通知します。

public function failed(\Exception $exception)
{
    Log::error('Order processing failed', [
        'order_id' => $this->orderData['id'],
        'exception' => $exception->getMessage(),
    ]);
}

再試行は指数バックオフで行い、過負荷を防止します。

タイムアウト対策とデータ同期の最適化

ShopifyはWebhook送信時に5秒以内にレスポンスを返す必要があります。非同期ジョブを使用することで、処理時間を短縮し、タイムアウトを回避します。また、queue:retryで失敗したジョブを再投入し、データ同期を確実にします。

さらに、Cacheを利用して重複注文を検知し、同一注文の二重処理を防止します。これにより、データ整合性が保たれます。

この記事はAIによって作成されました。

ショピファイ+ララベル課金実装

ショピファイ+ララベル課金実装

Shopify+Laravelでの課金実装概要

ShopifyのアプリをLaravelで構築する際、課金実装は重要な要素です。ShopifyはBilling APIを提供し、アプリ側でサブスクリプションや単発課金を管理できます。LaravelのEloquentやサービスプロバイダを活用すれば、課金ロジックをシンプルに保つことが可能です。

Billing APIとRecurringApplicationChargeの使い方

Billing APIはRESTfulエンドポイントで、POST /admin/api/2024-01/recurring_application_charges.json を呼び出すことでRecurringApplicationChargeを作成します。リクエストボディにはプラン名、価格、期間、試用期間などを設定し、Shopify側で支払い承認を促します。承認後はactiveステータスが付与され、アプリは利用可能になります。

プラン作成と課金フロー設計

プラン作成は、まずLaravel側でプラン情報をDBに保存し、Billing APIに送るJSONを生成します。課金フローは以下のように設計します。

  1. ユーザーがアプリをインストール
  2. プラン選択画面でRecurringApplicationChargeを作成
  3. Shopifyが支払い承認を要求
  4. 承認後、Laravelでactiveを確認し、機能を有効化

試用期間とアップグレード処理

試用期間はtrial_daysパラメータで設定できます。試用終了時に自動で課金が開始されるようにWebhookを利用し、charge_activatedイベントを監視します。アップグレードは既存のRecurringApplicationChargeをキャンセルし、新しいプランを作成することで実現します。

課金ステータスの監視と支払い承認

課金ステータスはstatusフィールドで確認できます。pendingacceptedactiveの遷移を追跡し、失敗時はdeclinedをハンドリングします。支払い承認はShopify側で完了した後、Webhookで通知されるため、Laravel側で即座に機能を切り替えることが可能です。

この記事はAIによって作成されました。

Shopify Laravel GraphQLで高速取得

Shopify Laravel GraphQLで高速取得

Shopify+LaravelでGraphQL APIを活用する

ShopifyはREST APIだけでなくGraphQL APIを提供しており、Laravelとの組み合わせで高速かつ柔軟なデータ取得が可能です。GraphQL APIは必要なフィールドだけをリクエストできるため、ネットワーク帯域を節約し、レスポンス時間を短縮します。LaravelではHTTPクライアントを使って簡単にGraphQLエンドポイントへリクエストを送ることができ、認証にはShopifyのアクセストークンを利用します。

GraphqlQueryとMutationの実装例

GraphqlQueryは読み取り専用のクエリ、Mutationはデータ変更を行う操作です。Laravelのサービスクラスで以下のように実装します。

public function getProducts()
{
    $query = <<<'GRAPHQL'
{
  products(first: 10) {
    edges {
      node {
        id
        title
        variants(first: 5) {
          edges { node { id price } }
        }
      }
    }
  }
}
GRAPHQL;
    return $this->client->post('/admin/api/2026-01/graphql.json', [
        'json' => ['query' => $query]
    ]);
}

Mutationの例として、商品を作成するリクエストは次のようになります。

public function createProduct($title, $price)
{
    $mutation = <<<'GRAPHQL'
mutation ($input: ProductInput!) {
  productCreate(input: $input) {
    product { id title }
    userErrors { field message }
  }
}
GRAPHQL;
    $variables = ['input' => ['title' => $title, 'variants' => [['price' => $price]]]];
    return $this->client->post('/admin/api/2026-01/graphql.json', [
        'json' => ['query' => $mutation, 'variables' => $variables]
    ]);
}

データ取得とクエリ作成のベストプラクティス

GraphqlQueryを作成する際は、必要なフィールドだけを指定し、不要なデータを排除します。これにより、API制限に引っかかりにくく、レスポンスサイズを小さく保てます。また、Laravelのキャッシュ機能を利用して頻繁にアクセスされるデータをローカルに保存し、API呼び出し回数を削減することも重要です。

エラーハンドリングとページネーション

GraphQL APIはレスポンスにerrorsフィールドを含む場合があります。Laravel側で例外を捕捉し、ユーザーに分かりやすいメッセージを返すようにします。ページネーションはedgespageInfoを利用し、hasNextPageendCursorで次ページの取得を制御します。

if ($response['data']['products']['pageInfo']['hasNextPage']) {
    $cursor = $response['data']['products']['pageInfo']['endCursor'];
    // 次ページを取得
}

カーソルと効率的な取得、API制限への対策

カーソルベースのページネーションは、インデックスベースよりも安定したデータ取得を可能にします。Shopifyは1分あたりのリクエスト数に制限があるため、カーソルを使って必要なデータだけを順次取得し、リクエスト数を最小化します。さらに、batch機能を活用して複数のクエリを1回のリクエストで送ることで、API制限を超えにくくなります。

この記事はAIによって作成されました。

Shopify Laravel ルート設

Shopify Laravel ルート設計

Shopify+Laravelの概要

ShopifyとLaravelを組み合わせることで、eコマースサイトのバックエンドを高速に構築できます。Laravelの豊富な機能(Eloquent、ミドルウェア、サービスプロバイダー)を活用し、ShopifyのAPIと連携することで、商品管理や注文処理をシームレスに行えます。まずは、Shopifyのアプリを作成し、OAuth認証を設定して、Laravel側でアクセストークンを取得します。

ルーティングとコントローラーの実装

Laravelでは、routes/web.phpにルート定義を記述します。ShopifyからのWebhookや認証コールバックを受け取るエンドポイントを設定し、Auth Middlewareで保護します。以下は典型的なルート定義例です。

Route::middleware(['auth', 'signed'])->group(function () {
    Route::post('/shopify/webhook', [ShopifyWebhookController::class, 'handle']);
    Route::get('/shopify/callback', [ShopifyAuthController::class, 'callback']);
});

ここでAuth MiddlewareはLaravelの認証ガードを利用し、signedミドルウェアは署名付きリクエストを検証します。コントローラー実装では、リクエストを受け取り、ビジネスロジックを実行し、レスポンスを返します。例としてWebhookハンドラを示します。

class ShopifyWebhookController extends Controller
{
    public function handle(Request $request)
    {
        // 署名検証済み
        $payload = $request->all();
        // 受信データを処理
        // ...
        return response('OK', 200);
    }
}

レスポンスはシンプルに文字列を返すだけでなく、JSONやXMLを返すことも可能です。リダイレクト処理が必要な場合は、redirect()ヘルパーを使用します。

認証と署名付きリクエストの処理

ShopifyのWebhookは署名付きリクエストで送信されます。Laravelのsignedミドルウェアを使うと、リクエストヘッダーに含まれるHMACを自動で検証できます。検証に失敗した場合は403が返されます。認証ガードは、Shopifyのアクセストークンをセッションやデータベースに保存し、Auth::guard('shopify')->user()で取得します。

リダイレクト処理は、認証が必要なページにアクセスした際にShopifyの認可ページへ誘導する際に重要です。以下はリダイレクト例です。

public function redirectToShopify()
{
    $url = config('shopify.auth_url') . '?client_id=' . config('shopify.api_key')
        . '&scope=read_products,write_orders&redirect_uri=' . route('shopify.callback')
        . '&state=' . Str::random(40);
    return redirect()->away($url);
}

このように、ルート定義、コントローラー実装、Auth Middleware、認証ガード、署名付きリクエスト、レスポンス、リダイレクト処理を組み合わせることで、Shopify+Laravelアプリケーションは堅牢かつ拡張性の高い構造になります。

この記事はAIによって作成されました。

shopifyのCustomerAccesstokenの有効期限

公式には記載されているのがないので、

メモがてら記載しておきます。

実際にcustomerAccessTokenCreateを利用して確認した所。

expiresAtの値を見た所、42日となってました。


12月8日 18時00分(日本時間) (2025-12-08T09:00:00Z)に実行した所、

1月19日 18時00分(日本時間)(2026-01-19T09:00:00Z)と返って来ました


参考になればと思います。

SimpleLoggerをSPMに公開しました — コツコツ、ここからはじまる

SimpleLoggerをSPMに公開しました — コツコツ、ここからはじまる

勢いで作った小さなライブラリを、ついにSwift Package Manager (SPM)に公開しました。
名前は「SimpleLogger」。
その名の通り、ただログを出すだけの、とてもシンプルなロガーです。


なんで作ったのか

開発中、print()でログを出すことが多いんですが、
「もう少しだけ使いやすく、ちょっと整った形で出したい」
そんな軽い気持ちで書き始めたのがきっかけです。

機能的にはとても単純。
ログレベルを分けたり、日付を出したり。
どれも“便利”と呼ぶにはまだまだなレベルですが、
「自分がよく使う形」に整えるのは意外と楽しい。


SPMに登録してみた

「せっかくだし公開してみよう」と思い、勢いでSPM対応にしました。
手順自体は簡単なんですが、
実際に「パッケージ名で検索して出てくる」のは、なんだか少し嬉しい瞬間ですね。


これから

正直、今のSimpleLoggerは本当にシンプルです。
でも、こういう“ちょっとした自作ツール”が積み重なっていくと、
自分専用の開発環境がどんどん育っていく気がしています。

これが、コツコツ始める第一歩。
時間をかけて少しずつ、使える形に育てていきます。


📦 SimpleLogger on GitHub
👉 https://github.com/kixking/SimpleLogger


※AIに書いてもらいました。

Google Pixel紹介プログラム

 

Pixel紹介プログラムで友だちと一緒にお得に!10%割引キャンペーン

Google Pixel を購入するなら、今がチャンス!
Google が実施している Pixel紹介プログラム を使えば、あなたも友だちもお得にPixelを手に入れられます。

Pixel紹介プログラムとは?

Pixel紹介プログラムは、既にPixelを持っている人が紹介コードを友だちに伝えることで、
紹介された友だちは10%割引でPixelを購入できる特典がもらえるキャンペーンです。

さらに、紹介した側も後日 Google ストアで使えるクレジットをゲットできます。
つまり、お互いにメリットがあるWin-Winなキャンペーンなんです。

私の紹介コード(先着順)

👇以下の紹介コードのいずれかを購入画面で入力すると、あなたも10%オフでPixelを購入できます。

お一人さま1コード限りで有効です。すでに使用済みのコードは利用できません。

REF-VJW48WWY8XVGN4FYLLCEYYQ
REF-RO582HST4OW0MIXE04A6867
REF-5JP468T53JGW3TCWIQ6ET35
REF-3KICWALMM2CEKFBRCTYRS5Q
REF-UCQAVRRPC1A1GRVI7MF8M8U

REF-SF91P74N7SPRGWRFBGMA2OR
REF-SK31IMQ8245Y32RJDGW1BJ6
REF-EV5PPVWG3BTZ5XWN0QP1165
REF-83ML3ERHXS8TWYGEQHXCCTI
REF-J1L5TD2XBV5RTGTAA7BSQ1P

有効なコードがなくなる前にお早めにご利用ください!

利用方法はかんたん

  1. Google ストアにアクセス

  2. 欲しい Pixel をカートに追加

  3. 購入手続きの途中で「紹介コードを入力」の欄に、上記のいずれかのコードを入力

  4. 自動で10%割引が適用されます

注意点

  • 紹介コードには有効期限があります

  • コードは先着順で使用され、使用済みのコードは無効となります。

  • 在庫状況によってはキャンペーンが早期終了する可能性があります。

まとめ

Pixelはカメラ性能やGoogle独自のAI機能が魅力的なスマートフォンです。
どうせ買うなら、紹介プログラムを使ってお得に購入しましょう。

紹介コードをシェアして、10%オフの特典を賢く活用してください!

DCJPYについて考えてみる。

 ゆうちょ銀行もDCJPYに参加するらしく、2026年には対応開始するとの事

日本最大の口座数を持つ、銀行が対応する事でどのような、メリット・デメリットが発生するのか?まとめてみました。


メリット

1. 利用者の裾野が一気に広がる

  • ゆうちょ銀行は 約1億2,000万口座約190兆円の預金残高 を持つ日本最大級の銀行。

  • DCJPY対応により、他銀行と比べて桁違いの潜在ユーザー層が一気にデジタル通貨を利用可能に。

2. 新しい金融サービスの普及加速

  • DCJPYを使った デジタル証券投資NFT購入自治体給付金のデジタル配布 などが現実的に広がる。

  • 特にゆうちょ銀行は高齢者層の利用も多いため、「デジタル通貨が生活に浸透する」大きな契機になる。

3. 資金移動の効率化

  • 従来の銀行振込では時間がかかる場合もあるが、DCJPYなら 即時決済 が可能。

  • 振込手数料削減や、地方自治体からの給付金・補助金を即座に配布できるメリットがある。

4. 金融DX(デジタル化)の推進

  • 銀行預金をトークン化することで、ブロックチェーン上でのプログラマブルマネー が可能に。

  • 例)「特定用途のみで使える補助金」「時間制限つき商品券」などが簡単に実装可能。


デメリット

1. 高齢者層への利用ハードル

  • ゆうちょ銀行はシニアユーザーが非常に多い。

  • DCJPYの仕組み(口座連携、アプリ、ブロックチェーン利用)が理解されにくく、利用者教育やサポート体制が課題になる。

2. システム統合コスト

  • ゆうちょ銀行の既存システムは巨大でレガシー色が強い。

  • DCJPY対応のためのシステム改修・セキュリティ強化に 莫大なコスト が発生する可能性。

3. 利用者保護・規制の整備

  • DCJPYは「預金をトークン化」するため安全性は高いが、利用者が詐欺やハッキング被害に遭うリスクは残る。

  • 法的な消費者保護の枠組み(返金対応や補償制度)が不可欠。

4. ネットワーク間の相互運用性

  • DCJPYは基本的に「許可制ブロックチェーン」で動作する。

  • 他の銀行・他のトークン化ネットワークとどうつなぐか(インターオペラビリティ)が普及の鍵になる。

5. 手数料・収益モデル

  • 即時決済で従来の振込手数料が減少する可能性があり、銀行の収益構造を圧迫する懸念。

  • 逆に新サービス手数料で補う必要がある。



まとめ

メリット
  • 巨大な利用者層が参加することでDCJPYの普及が一気に加速
  • 即時決済・補助金配布など金融DXの実用化が進む

デメリット

  • 高齢者層の利用ハードル
  • 巨大システム改修コストやセキュリティ対策の負担
  • 規制・利用者保護、異なるネットワークとの互換性課題