destroy @ ScrollsController

スクロール削除

url

リクエスト

認証ユーザ
権限オーナー作家
methoddelete
urlパラメータid
POSTデータjson形式*
html
json
jsonp×

解説

指定されたidのスクロールを削除する。スクロールだけでなく、関連するスクコマも同時に削除される。

  • セッションまたは認証トークンからユーザアカウントを特定する。
  • ユーザアカウントから作家を取得する。
  • スクロールモデルに編集取得を問い合わせ、その結果を対象スクロールとして取得する。
    • 要求されたidと作家を渡す。
  • スクロールモデルに削除を依頼する。
  • 作業結果をクライアントに戻す。

urlパラメータ

id

  • 削除の対象となるスクロールのid

POSTデータ

auth_token

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

戻り値

正常系

  • htmlのとき、ステータスコード302 Foundとともに、マイスクロールの一覧(home/scroll)ページに遷移する。
  • jsonのとき、ステータスコード200 OKだけを返す。

例外系

  • ユーザアカウントでサインインしてなかった。(Devise)
    • htmlなら、ステータスコード302 Foundを返すとともに、サインインを促すページ(/users/sign_in)へ遷移する。
    • jsonなら、ステータスコード401 Unauthorizedを返すとともに、応答メッセージにUnauthorizedを返す。
  • 作家登録してなかった。
    • htmlなら、ステータスコード302 Foundを返すとともに、作家登録を促すページ(/authors/new)へ遷移する。
    • jsonなら、ステータスコード401 Unauthorizedを返すとともに、応答メッセージにUnauthorizedを返す。
  • 対象スクロールが存在しなかった。(ScrollModel)
    • htmlなら、例外404 not_foundを返す
    • jsonなら、例外404 not_foundを返す
  • 対象スクロールに対する編集権限がなかった。(ScrollModel)
    • htmlなら、例外403 forbiddenを返す
    • jsonなら、例外403 forbiddenを返す
  • 削除に失敗した
    • htmlなら、ステータスコード302 Foundを返すとともに、そのスクロールの詳細ページへ遷移する。
    • jsonなら、ステータスコード422 unprocessable_entityを返す。