nakanoasaservice / hasura-mssql-liff

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

hasura-mssql-liff

前提

1. 環境構築

以下をやることでhasura consoleが起動する。

cd to/this/repo

docker compose up
cd hasura

hasura metadata apply
hasura migrate apply --all-databases
hasura md reload

hasura console

2. トークン取得

以下のページでLINEにログインし、IDトークンを取得する。

LIFF Playground

3. IDトークンをヘッダーにセット

hasura console上でトークンを以下のようにセットする。

  • KEY: Authorization
  • VALUE: Bearer <2で取得したidトークン>

4. ユーザーIDを控える

2で取得したidトークンの中に含まれるトークン中に含まれるsubというキーの値がユーザーIDとなる。これを控えておく。

idトークンの中身を見るには以下のサイトを利用するとよい。

jwt.io

5. 管理者権限でユーザーを作成する

x-hasura-admin-secret ヘッダーにチェックを入れることで、管理者権限で任意のGraphQLクエリが発行可能になる。

その上で、以下のクエリを実行し、ユーザーを作成する。

mutation AdminAddUser {
  insert_user_one(
    object: { id: "{ユーザーID}", name: "テストユーザー" }
  ) {
    id
    name
  }
}

6. IDトークンの権限でユーザー情報を取得する

x-hasura-admin-secret ヘッダーのチェックを外し、Authorizationヘッダーにチェックを入れることで、IDトークン中のユーザーIDに関するデータ取得しかできないクエリを発行できる。

その上で、以下のクエリを発行し、自分のデータしかとれていないことを確認できる。

query GetMe {
  user {
    id
    name
    deleted_at
  }
}

About