Amazon・楽天商品リンクが切れていた時にメール通知を行う設定方法

Amazon商品リンク
この記事は約2分で読めます。

Cocoon 1.6.6からAmazon商品リンクや、楽天商品リンクのAPIで情報が取得できなかった際に、メールで知らせてくれる機能を追加しました。

\エックスサーバー開発のWordPressテーマ/
エックスサーバー開発のWordPressテーマ

商品リンク切れの際にメール通知する方法

メール通知する方法は簡単で、まずはテーマ設定を開きます。

WordPress管理画面から「Cocoon設定」を選択してください。

Wordpress管理画面からCocoon設定を選択

「API」タブにある「Error設定」項目にある「メール通知」機能を有効にしてください。

APIタブのエラー設定項目

メッセージは、WordPressに登録されているメールアドレス宛に送信されます。

メールを通知するトリガー

メール通知は、API(PA-API、楽天API)にクエリを発行して、商品情報が取得できなかった際に送信されます。

既にエラー状態で「商品リンク」のキャッシュが作成されている場合は、キャッシュの有効期限が切れて再度APIに問い合わせをして、商品リンク取得エラーが出ないとメールは発送されません。

このような仕様にしているのは、以下の理由からです。

  • エラーで商品情報を何度も取得してAPI制限に引っ掛かるのをなるべく防ぐ
  • キャッシュを使用しないとエラーが出る事にメールが届いて邪魔くさい

既にエラーでキャッシュが作成されている場合は、メールは送信されませんが、キャッシュが切れると送信されると思います。

気長にお待ちいただければ幸いです。

ログ出力でも確認可能

商品リンク切れは、ログからも確認可能です。

Amazon商品リンクショートコードのリンク切れを知る方法
Amazon商品リンクのリンク切れ対策。
楽天商品リンクショートコードのリンク切れを知る方法
楽天商品リンクのリンク切れ対策。

メール自体は、ログ出力時と同じタイミングで送信されます。

コメント テーマの質問はフォーラムへ

  1. アマゾネスちゃん より:

    便利そうなので、試してみました!

    早速、「Amazon商品取得エラー」がメールで
    下書きの記事にも来るんですね

    記事内に「商品を取得できませんでした」と表示されるのかと思いきや
    通常のAmazonカードでした。

    クリックしてみると『現在在庫切れです。』でした。

    在庫切れが把握できてチョー便利です

    • わいひら わいひら より:

      動作をご報告していただいて、ありがとうございます。
      僕も「エラーの出る商品情報」が不足していて、「しっかりと動作するかな…」と心配な部分があったので、在庫切れでも動作しているようで、安心しました。
      うまく実装できていたようでよかったです^^

    • わいひら わいひら より:

      記事内に「商品を取得できませんでした」と表示されるのかと思いきや
      通常のAmazonカードでした。

      これは、エラーが出た場合でも、以前取得したバックアップキャッシュから商品情報を取得して、正常表示するような仕様にしているからです。
      こうなっていると、とりあえず見た目の体裁は整うので。

タイトルとURLをコピーしました
'); /* ヘッダーの高さの変化分、paddingで調整しスクロール位置を止まらせる */ $("#header-fixed").css({ 'padding-top': `${threashold}px`, }); /* トップメニュータイプに変更する */ $("#header-container-in").removeClass('hlt-center-logo hlt-center-logo-top-menu').addClass("hlt-top-menu wrap"); $("#header-container").addClass("fixed-header"); $("#header-container").css({ 'position': 'fixed', 'top': '-100px', 'left': '0', 'width': '100%', }); const wpadminbar = document.getElementById('wpadminbar'); const headerContainerTop = wpadminbar ? wpadminbar.clientHeight : 0; $('#header-container').animate( { top: headerContainerTop, }, 500 ); } } /*固定ヘッダーの解除*/ function staticHeader() { if ($("#header-container").hasClass("fixed-header")) { /*センターロゴタイプに戻す*/ $("#header-container-in").removeClass("hlt-top-menu hlt-tm-right hlt-tm-small hlt-tm-small wrap").addClass(" hlt-center-logo"); $("#header-container").removeClass("fixed-header"); $("#header-container").css({ 'position': 'static', 'top': 'auto', 'left': 'auto', 'width': 'auto', }); /* ヘッダーの高さの戻る分、padding削除しスクロール位置を止まらせる */ $("#header-fixed").css({ 'padding-top': '0', }); $("#header-fixed").remove(); } } /* 境界値をヘッダーコンテナに設定 */ var threashold = $('#header-container').height(); var prevScrollTop = -1; var $window = $(window); var mobileWidth = 1023; $window.scroll(function() { var scrollTop = $window.scrollTop(); var s1 = (prevScrollTop > threashold); var s2 = (scrollTop > threashold); var w = $window.width(); /*スクロールエリアの位置調整*/ function adjustScrollArea(selector) { if ($(selector) && $(selector).offset()) { offset = $(selector).offset().top; h = $("#header-container").height(); pt = $(selector).css('padding-top'); if (pt) { pt = pt.replace('px', ''); } else { pt = 0; } if ((scrollTop >= offset - h) && (w > mobileWidth)) { if ((pt <= 1) && $("#header-container").hasClass('fixed-header')) { $(selector).css({ 'padding-top': h + 'px', }); } } else { if (pt > 0) { $(selector).css({ 'padding-top': 0, }); } } } } /*スクロール追従エリアの調整*/ function adjustScrollAreas() { adjustScrollArea('#sidebar-scroll'); adjustScrollArea('#main-scroll'); } /*固定ヘッダーのスタイル決め*/ function adjustFixedHeaderStyle(s1, s2, w, scrollTop, mobileWidth) { if (s1 ^ s2) { if (s2 && (w > mobileWidth)) { stickyHeader(); } } /* 境界値に達したら固定化 */ if (scrollTop <= threashold || w <= mobileWidth) { staticHeader(); } } adjustFixedHeaderStyle(s1, s2, w, scrollTop, mobileWidth); adjustScrollAreas(); prevScrollTop = scrollTop; }); /*ウインドウがリサイズされたら発動*/ $window.resize(function () { /*ウインドウの幅を変数に格納*/ var w = $window.width(); if (w <= mobileWidth) { /*モバイル端末の場合*/ staticHeader(); } else { /*パソコン端末の場合*/ var scrollTop = $window.scrollTop(); if (scrollTop >= 50) { stickyHeader(); } } }); })(jQuery);