show @ SystemPicturesController

システム画像詳細

url

リクエスト

認証素材読者*
権限
methodget
urlパラメータid
POSTデータjson形式*
html
json
jsonp×
png
gif
jpeg

*オープンモードのとき、誰でも可 →RunMode

解説

システム画像の情報を得るために使う機能。拡張子が画像フォーマットであれば、画像を返す。それ以外なら行データを返す。

  • セッションまたは認証トークンからユーザアカウントを特定する。
  • ユーザアカウントから作家を取得する。
  • システム画像モデルに単体取得を問い合わせ、その結果を対象システム画像として取得する。
    • 要求されたidとロールリスト(ユーザと管理者と借手アカウント)を渡す。
  • 取得したデータを返す。

urlパラメータ

id

  • システム画像のid

POSTデータ

auth_token

  • 外部からjsonで要求する場合、認証処置として認証トークンが必要。

戻り値

正常系

  • htmlのとき、ステータスコード200 OKとともに、テンプレートから起こしたページを返す。
  • 画像のとき、ステータスコード200 OKとともに、対象システム画像モデルに画像のバイナリデータをもらって、それを返す。
    • システム画像モデルにMimeTypeを問い合わせ、inlineで送信する。
  • jsonのとき、ステータスコード200 OKとともに、json構造のデータを返す。
    • 出力フォーマットはシステム画像モデルのjson単体出力オプションに従う

参考:SystemPicturesShowView

例外系

  • ユーザまたは管理者または借手アカウントでサインインしてなかった。(Devise)
    • htmlなら、ステータスコード302 Foundを返すとともに、サインインを促すページ(/users/sign_in)へ遷移する。
    • jsonなら、ステータスコード401 Unauthorizedを返すとともに、応答メッセージにUnauthorizedを返す。
  • 対象システム画像が存在しなかった。(SystemPictureModel)
    • htmlなら、例外404 not_foundを返す
    • jsonなら、例外404 not_foundを返す
  • 対象システム画像に対する閲覧権限がなかった。(SystemPictureModel)
    • htmlなら、例外403 forbiddenを返す
    • jsonなら、例外403 forbiddenを返す