要件・仕様

最低技術要件

実装が必要なWebhook

Webhook
アプリの提供形態 インストール アンインストール 再決済期限超過
(2024.06.04追加)
自由決済成功/失敗
(2024.06.28追加)
無料 - -
有料
※自由決済APIを利用し、makeshop appsを介した決済
有料
※makeshop apps外での独自決済
- -

詳細はシーケンス図をご確認ください。

アプリ側で必要な制御

アンインストール後に再インストールした場合のデータ使用の制御(2024.07.01追加)

アプリをアンインストール後、同ショップIDから再インストールがあった場合、ショップIDにて一意に識別し過去のデータを紐づけることによって、以前のデータを使用可能とするかはアプリ側でご判断ください。

有料アプリを提供される場合のアプリの利用制限の制御

アプリの利用状態に応じて、利用制限をアプリ側で制御してください。

「利用終了」の場合、アプリの利用制限はアプリ側で制御してください。

「再決済中」の場合、アプリを利用可能とするか利用制限をかけるかはアプリ側で制御してください。

  • ※ショップ様の状況によっては、料金が未収のまま強制的に利用停止となることがあります。
  • ※利用規約に支払い等に関する事項を含めていただくようお願いいたします。

その他必須要件

アプリ内データのショップオーナーへの提供

アプリ利用の中で生成 または連携されたデータのうち、ショップオーナーに所有権があるデータはご要望があった場合には提供のご対応をお願いいたします。
提供形態は自由ですが、ダウンロード機能の設定や運用におけるデータ提供等のご対応をご準備いただきますようお願いいたします。

再決済(2024.06.04追加)

再決済の対象、再決済可能な期間

再決済の対象
・自由決済APIで決済失敗したもの(2024.06.28追加)

再決済が実行されるタイミング
・ショップオーナーが以下画面にて、対象アプリに表示された再決済ボタンより手続き後
ショップ管理画面)アプリ管理 > アプリ一覧 > 利用中のアプリ

再決済可能な期間
・決済失敗の当日を1日目として14日間は再決済が可能(例:12/1に失敗の場合、12/15以降は不可)
※再決済期限の超過後、再決済を希望する場合はサポート対応が必要

再決済中の制限

  • ・再決済が完了するまで対象アプリのアンインストール不可
    ※決済失敗していない他のアプリは制限されません
  • ・再決済期限切れ後に再決済する場合はサポート対応が必要
  • ・再決済期限切れ後はAPIは利用不可となる

再決済のメール・Webhook

    再決済誘導メール
    ・ショップオーナーに、自動更新の決済失敗時に再決済へ誘導するメールを通知

    再決済成功メール
    ・ショップオーナーに、決済完了メールの送信

    再決済期限のリマインドメール
    ・ショップオーナーに、再決済期限の「7日前」「1日前」「当日」にメール通知

    再決済のWebhook
    ・再決済期限が超過した際にリクエスト
    ※詳細はWebhookをご確認ください。

自由決済API(アプリ内課金)(2024.06.28追加)

  • ・自由決済APIを用いて、従量課金や初期費用、オプション費用等のアプリの様々な費用形態に合わせて決済可能

決済予約

  • 「決済予約登録」で決済日を指定し、 「決済予約明細登録」で金額や決済名目を登録してください。
    ※登録した決済名目は、 管理画面)アプリ決済情報の「内訳」に表示されます。
  • ・決済タイミングは指定した決済日の0:10となります。
  • ・決済予約の日付指定は最大1年後まで可能です。
    例)2024/6/1にリクエストする場合、2025/6/1まで指定可能。

決済失敗時

  • 再決済の対象となります。
    ※ショップ契約満了日/アンインストール日を超えた際の決済失敗は再決済の対象にはなりません。

決済対象の申し込み/キャンセル

  • ・自由決済APIの決済対象とするプラン、オプション費用等の申込/キャンセルの受付や動線はアプリ側でご用意ください。
  • ・キャンセル受付後、対象が未決済であれば決済予約削除をしてください。
  • ・決済後の返金/予約削除は不可となります。

決済対象の日付/金額等の変更

ショップ契約終了後/アンインストール後の決済予約

  • ・ショップ契約満了日/アンインストール日から翌月末以内であれば決済予約は実行されます。
    ※上記ケースで決済失敗となった場合、ショップ様の状況によっては料金が未収となることがあります。
    利用規約に支払い等に関する事項を含めていただくようお願いいたします。

SSO(シングルサインオン)

SSOについて

makeshopをIdPとして、makeshop管理画面のユーザ認証(ログイン)を行うことでアプリ(サービス)のユーザー認証も行うための仕組みです。

事前準備

redirect_uriの登録申請

「アプリ開発申請」及び「アプリ公開申請」にてredirect_uriの登録申請をお願いします。
※redirect_uriのプロトコルはhttpsである必要があります。

SSO実行時に必要な情報

クライアントID redirect_uri 登録時に発行されたクライアントID
クライアント シークレット redirect_uri 登録時に発行されたクライアントシークレット
SSO ログインURL アプリケーションがSSOログインをする URL
https://console.makeshop.jp/apps/sso
一時トークン発行 URL 認可コードから一時トークン、IDトークン及びリフレッシュトークンを発行する URL
  https://app-auth.makeshop.jp/oauth2/token

※一時トークンの有効期限は5分となります

APIエンドポイント API実行時のエンドポイント
「アプリ開発申請」及び「アプリ公開申請」の手続き完了メールで通知しています
API キー アプリケーション登録時に発行されたAPIキー
トークンリフレッシュ URL 新しい一時トークン、IDトークン及びリフレッシュトークンを発行する URL
https://app-auth.makeshop.jp/oauth2/token

※リフレッシュトークンの有効期限は12時間となります

シーケンス図

シーケンス図

1. 一時トークンの有無を判定

アプリケーション起動で一時トークンが発行されているか判定し、発行されていればその一時トークンを利用できます。
一時トークンが発行されていない場合、SSOログインへリダイレクトをします。
一時トークンの有効期限を超えている場合、トークンリフレッシュを実行してください。

※APIリクエスト方法は、以下でご確認ください。
https://developers.makeshop.jp/api/graphql/index.html#introduction-item-1

2. SSOログインへリダイレクト

パラメータを付与してSSOログインへリダイレクトします。

リダイレクト先URL

https://console.makeshop.jp/apps/sso

クエリ

パラメータ 必須 説明
response_type 必須
code
固定
client_id 必須 redirect_uri 登録時に発行されたクライアントID
redirect_uri 必須 登録申請したredirect_uri
state 必須 クロスサイトリクエストフォージェリ防止用の固有な英数字の文字列(8文字以上)。
ログインセッションごとにWebアプリでランダムに生成してください。
なお、URLエンコードされた文字列は使用できません。
code_challenge 任意 PKCE対応するために必要なパラメータ。
一意のcode_verifierをSHA256でハッシュ化したうえで、Base64URL形式にエンコードした値。
デフォルト値はnullです。
(値を指定しない場合、リクエストはPKCE対応されません)
code_challenge_method 任意
S256
固定

※code_challengeを設定する場合は必須となります。

nonce 任意 リプレイアタックを防止するための文字列。
この値はレスポンスで返されるIDトークンに含まれます。

3. 認可コードの受け取り

redirect_uriに認可コード等のクエリパラメータが付与された状態でリクエストされます。

クエリ

パラメータ 説明
code 一時トークン発行で使用する認可コードです。
scope アプリケーションに設定されているAPIの利用権限を返します。
state SSOログインURLのstateパラメータを返却します。

エラー

エラーが発生した場合、error及びerror_descriptionをパラメータに付与しredirect_uriへリダイレクトします。

4. 一時トークン発行

認可コードを利用し、一時トークンを取得します。
以降、APIへアクセスする際に一時トークンを利用します。
一時トークンの有効期限を超えた場合、「5. トークンリフレッシュ」をご参照ください。

リクエスト

POST

https://app-auth.makeshop.jp/oauth2/token

ヘッダー

名前
Authorization
Basic クライアントID:クライアントシークレット

クライアントID:クライアントシークレットは(コロン含め)Base64エンコード
Content-Type
application/x-www-form-urlencoded
固定

ボディ

パラメータ 必須 説明
grant_type 必須
authorization_code
固定
client_id 必須 redirect_uri 登録時に発行されたクライアントID
code 必須 リダイレクトのパラメータ 認可コード
redirect_uri 必須 登録申請したredirect_uri
code_verifier 任意 SSOログインURL code_challenge の基となる code_verifier

レスポンス

リクエストが認可されるとJSONフォーマットでトークン情報を返します。

フィールド名
token_type
bearer
固定
access_token リソースへのアクセスを認可するための一時トークンです。
makeshop apps APIを実行する際に使用します。
id_token ユーザが認証されたことを証明するためのトークンです。
nonceの検証はこのトークンをJWTデコードしたJSON の nonce と SSO ログイン URLのnonce と一致するか確認します。

※JWSの検証をする場合、以下のURLよりJWK Setを取得してください。
auth-facadeのurl/.well-known/jwks.json
refresh_token トークンをリフレッシュする際に使用します。
scope アプリケーションに設定されているAPIの利用権限を返します。
expires_in 一時トークンの有効期限を返します。

エラー

HTTPステータス
400 Bad Request
401 Unauthorized
500 Internal Server Error
[レスポンス例]
{
  "error": "internal server error",
  "error_description": "The server encountered an error and could not complete your request" 
}

5. トークンリフレッシュ

一時トークンの有効期限が切れた際に、リフレッシュトークンを利用して新たな一時トークンの要求をします。

リクエスト

POST

https://app-auth.makeshop.jp/oauth2/token

ヘッダー

名前
Authorization
Basic クライアントID:クライアントシークレット

クライアントID:クライアントシークレットは(コロン含め)Base64エンコード
Content-Type
application/x-www-form-urlencoded

ボディ

パラメータ 必須 説明
grant_type 必須
refresh_token
固定
client_id 必須 redirect_uri 登録時に発行されたクライアントID
refresh_token 必須 リフレッシュトークン

レスポンス

リフレッシュトークンが有効であれば、JSONフォーマットでトークン情報を返します。

フィールド名 説明
token_type
bearer
固定
access_token リソースへのアクセスを認可するための一時トークンです。
makeshop apps APIを実行する際に使用します。
id_token ユーザが認証されたことを証明するためのトークンです。
nonceの検証はこのトークンをJWTデコードしたJSON の nonce と SSO ログイン URLのnonce と一致するか確認します。

※JWSの検証をする場合、以下のURLよりJWK Setを取得してください。
auth-facadeのurl/.well-known/jwks.json
refresh_token 一時トークンをリフレッシュする際に使用します
scope アプリケーションに設定されているAPIの利用権限を返します。
expires_in 一時トークンの有効期限を返します

エラー

HTTPステータス
400 Bad Request
401 Unauthorized
500 Internal Server Error
[レスポンス例]
{
    "error": "internal server error",
    "error_description": "The server encountered an error and could not complete your request" 
}

ユースケース

アプリを起動したショップが新規ショップか、既存ショップかを判別し、ユーザに合わせた画面を表示するユースケース

ユースケース

memberSSO(会員シングルサインオン)

memberSSOについて

makeshopをIdPとして、ショップ会員のユーザ認証(ログイン)を行うことで外部サイトのユーザー認証も行うための仕組みです。

  • ①外部サイトのログインボタンをクリック
  • ②makeshopのログイン画面でログイン(ログイン済みの場合はスキップ)
  • ③外部サイトに戻る(Makeshopも外部サイトもログイン状態)

事前準備

外部サイト名、リダイレクトURLなどの登録申請

「アプリ開発申請」及び「アプリ公開申請」にて登録申請をお願いします。

情報 必須 説明
外部サイト名 必須 ロゴURLが未入力の場合、ログイン画面のタイトルを表示
※半角・全角100字まで
外部サイトURL 必須 ログイン画面のタイトル、もしくは「ホームへ」をクリックした際の遷移先URL
※半角255字まで
外部サイトのロゴURL 任意 ロゴURLが未入力の場合、ログイン画面のタイトルを表示
※プロトコルはhttpsである必要があります。
※半角255字まで
パスワード紛失時リンクURL 任意 ログイン画面の「パスワードをお忘れの方はこちら」クリックした際の遷移先URL
未登録の場合は、リンクは表示されません
※半角255字まで
新規会員登録ボタンURL 任意 ログイン画面の「新規会員登録」ボタンをクリックした際の遷移先URL
未登録の場合は、リンクは表示されません
※半角255字まで
ログイン後のリダイレクト先URL 必須 ログイン後(認可コード発行後)の遷移先URL
※プロトコルはhttpsである必要があります。
※半角255字まで
※最大15件登録可能
※URLにフラグメントコンポーネント(#)は含められません
ログアウト後のリダイレクト先URL 任意 ログアウト後の遷移先URL
ログアウト連携APIを使用する場合には必須です
※プロトコルはhttpsである必要があります。
※半角255字まで
※最大15件登録可能
※URLにフラグメントコンポーネント(#)は含められません
※「ログイン後のリダイレクト先URL」に同一Origin(プロトコル、ホスト、ポート番号)が含まれる必要があります

シーケンス図

makeshopに未ログインのケース

makeshopに未ログインのケース

makeshopにログイン済みのケース

makeshopにログイン済みのケース

1. ユーザー認証API

ユーザーがログインID、クライアントが認可コードを取得するAPIです。

リクエスト

GET

https://member-auth.makeshop.jp/sso/login

クエリ

パラメータ 必須 説明
response_type 必須 code 固定
client_id 必須 インストールwebhookで通知されるクライアントID
redirect_uri 必須 ログイン後のリダイレクト先URL
※アプリ開発/公開申請にて、予め登録した「ログイン後のリダイレクト先URL」に含まれている必要があります。
state 必須 クロスサイトリクエストフォージェリ防止用の固有な英数字の文字列(8文字以上)。
ログインセッションごとにWebアプリでランダムに生成してください。
なお、URLエンコードされた文字列は使用できません。
nonce 必須 リプレイアタックを防止するための文字列。
この値はレスポンスで返されるIDトークンに含まれます。

レスポンス

redirect_uriへリダイレクトするレスポンス(HTTP ステータス 302)が返却されます。
redirect_uriには以下のクエリパラーメータが付与されます。

パラメータ 説明
code アクセストークン発行で使用する認可コードです。
scope アプリケーションに設定されているスコープを返します。
state リクエスト時に指定されたstateパラメータを返却します。

エラー

エラーが発生した場合、error及びerror_descriptionをパラメータに付与しエラー画面のURLへリダイレクトします。

2. トークン取得API

アクセストークンおよびIDトークンを取得するためのAPIです。

リクエスト

POST

https://member-auth.makeshop.jp/oauth2/token

ヘッダー

名前
Authorization Basic クライアントID:クライアントシークレット
※クライアントID:クライアントシークレットは(コロン含め)Base64エンコード
Content-Type application/x-www-form-urlencoded固定

ボディ

パラメータ 必須 説明
grant_type 必須 authorization_code固定
client_id 必須 インストールwebhookで通知されるクライアントID
code 必須 ユーザ認証APIで発行された認可コード
redirect_uri 必須 ログイン後のリダイレクト先URL
※アプリ開発/公開申請にて、予め登録した「ログイン後のリダイレクト先URL」に含まれている必要があります。"

レスポンス

リクエストが認可されるとJSONフォーマットでトークン情報を返します。

フィールド名 説明
token_type bearer固定
access_token リソースへのアクセスを認可するための一時トークンです。
会員ID取得APIを実行する際に使用します。
※一時トークンの有効期限は5分となります
id_token ユーザが認証されたことを証明するためのトークンです。
nonceの検証はこのトークンをJWTデコードしたJSON の nonce と SSO ログイン URLのnonce と一致するか確認します。

※JWSの検証をする場合、以下のURLよりJWK Setを取得してください。
https://member-auth.makeshop.jp/.well-known/jwks.json
scope アプリケーションに設定されているAPIの利用権限を返します。
expires_in 一時トークンの有効期限を返します。

エラー

HTTPステータス
400 Bad Request
401 Unauthorized
500 Internal Server Error
  [レスポンス例]
  {
    "error": "invalid_grant",
    "error_description": "The provided authorization grant (e.g., authorization code, resource owner credentials) or refresh token is invalid, expired, revoked, does not match the redirection URI used in the authorization request, or was issued to another client."
  }
  

3. 会員ID取得API

ユーザの会員IDを取得するためのAPIです。
※メールアドレスでログインした場合でも、makeshopに登録された会員IDを返却します。

リクエスト

GET

https://member-auth.makeshop.jp/userinfo

ヘッダー

名前
Authorization Bearer 一時トークン
※トークン取得APIで取得したアクセストークン

レスポンス

リクエストが認可されるとJSONフォーマットでトークン情報を返します。

フィールド名 説明
auth_time ユーザ認証時間
iat トークン発行時間
iss トークン発行者
sub ユーザーID

エラー

HTTPステータス
400 Bad Request
401 Unauthorized
500 Internal Server Error
[レスポンス例]
{
  "error": "request_unauthorized",
  "error_description": "The request could not be authorized. Check that you provided valid credentials in the right format."
}

ログアウト連携API

外部サイトとmakeshop間でログアウト連携するためのAPIです。

外部サイトログアウトのケース

外部サイトログアウトのケース

makeshopログアウトのケース

makeshopログアウトのケース

リクエスト

GET

  https://member-auth.makeshop.jp/sso/logout

クエリ

パラメータ 必須 説明
id_token_hint 必須 トークン取得APIで発行したIDトークン
post_logout_redirect_uri 必須 ログアウト後のリダイレクト先URL
※アプリ開発/公開申請にて、予め登録した「ログアウト後のリダイレクト先URL」に含まれている必要があります。
state 必須 クロスサイトリクエストフォージェリ防止用の固有な英数字の文字列(8文字以上)。
ログインセッションごとにWebアプリでランダムに生成してください。
なお、URLエンコードされた文字列は使用できません。

レスポンス

post_logout_redirect_uriへリダイレクトするレスポンス(HTTP ステータス 302)が返却されます。
post_logout_redirect_uriには以下のクエリパラーメータが付与されます。

パラメータ 説明
state リクエスト時に指定されたstateパラメータを返却します。

エラー

エラーが発生した場合、error及びerror_descriptionをパラメータに付与しエラー画面のURLへリダイレクトします。