forked from AkkomaGang/akkoma
da4923f2e5
Enforcement of OAuth scopes check for authenticated API endpoints See merge request pleroma/pleroma!2349
49 lines
1.2 KiB
Elixir
49 lines
1.2 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Tests.OAuthTestControllerTest do
|
|
use Pleroma.Web.ConnCase
|
|
|
|
import Pleroma.Factory
|
|
|
|
setup %{conn: conn} do
|
|
user = insert(:user)
|
|
conn = assign(conn, :user, user)
|
|
%{conn: conn, user: user}
|
|
end
|
|
|
|
test "missed_oauth", %{conn: conn} do
|
|
res =
|
|
conn
|
|
|> get("/test/authenticated_api/missed_oauth")
|
|
|> json_response(403)
|
|
|
|
assert res ==
|
|
%{
|
|
"error" =>
|
|
"Security violation: OAuth scopes check was neither handled nor explicitly skipped."
|
|
}
|
|
end
|
|
|
|
test "skipped_oauth", %{conn: conn} do
|
|
conn
|
|
|> assign(:token, nil)
|
|
|> get("/test/authenticated_api/skipped_oauth")
|
|
|> json_response(200)
|
|
end
|
|
|
|
test "performed_oauth", %{user: user} do
|
|
%{conn: good_token_conn} = oauth_access(["read"], user: user)
|
|
|
|
good_token_conn
|
|
|> get("/test/authenticated_api/performed_oauth")
|
|
|> json_response(200)
|
|
|
|
%{conn: bad_token_conn} = oauth_access(["follow"], user: user)
|
|
|
|
bad_token_conn
|
|
|> get("/test/authenticated_api/performed_oauth")
|
|
|> json_response(403)
|
|
end
|
|
end
|