mirror of
https://github.com/discourse/discourse.git
synced 2025-05-24 03:36:18 +08:00
Require permitted scopes when registering a client (#29718)
This commit is contained in:
@ -21,41 +21,69 @@ RSpec.describe UserApiKeyClientsController do
|
||||
}
|
||||
end
|
||||
|
||||
describe "#register" do
|
||||
context "without a user" do
|
||||
it "returns a 403" do
|
||||
post "/user-api-key-client/register.json", params: args
|
||||
expect(response.status).to eq(403)
|
||||
describe "#show" do
|
||||
context "with a registered client" do
|
||||
before { Fabricate(:user_api_key_client, **args) }
|
||||
|
||||
it "succeeds" do
|
||||
head "/user-api-key-client.json", params: { client_id: args[:client_id] }
|
||||
expect(response.status).to eq(200)
|
||||
end
|
||||
end
|
||||
|
||||
context "with a user" do
|
||||
before { sign_in(Fabricate(:user)) }
|
||||
context "without a registered client" do
|
||||
it "returns a 400" do
|
||||
head "/user-api-key-client.json", params: { client_id: args[:client_id] }
|
||||
expect(response.status).to eq(400)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
it "registers a client" do
|
||||
post "/user-api-key-client/register.json", params: args
|
||||
expect(response.status).to eq(200)
|
||||
expect(
|
||||
UserApiKeyClient.exists?(
|
||||
client_id: args[:client_id],
|
||||
application_name: args[:application_name],
|
||||
auth_redirect: args[:auth_redirect],
|
||||
public_key: args[:public_key],
|
||||
),
|
||||
).to eq(true)
|
||||
describe "#create" do
|
||||
context "without scopes" do
|
||||
it "returns a 400" do
|
||||
post "/user-api-key-client.json", params: args
|
||||
expect(response.status).to eq(400)
|
||||
end
|
||||
end
|
||||
|
||||
context "with scopes" do
|
||||
let!(:args_with_scopes) { args.merge(scopes: "user_status") }
|
||||
|
||||
context "when scopes are not allowed" do
|
||||
before { SiteSetting.allow_user_api_key_client_scopes = "" }
|
||||
|
||||
it "returns a 403" do
|
||||
post "/user-api-key-client.json", params: args_with_scopes
|
||||
expect(response.status).to eq(403)
|
||||
end
|
||||
end
|
||||
|
||||
it "updates a registered client" do
|
||||
Fabricate(:user_api_key_client, **args)
|
||||
args[:application_name] = "bar"
|
||||
post "/user-api-key-client/register.json", params: args
|
||||
expect(response.status).to eq(200)
|
||||
expect(
|
||||
UserApiKeyClient.exists?(
|
||||
client_id: args[:client_id],
|
||||
application_name: args[:application_name],
|
||||
),
|
||||
).to eq(true)
|
||||
context "when scopes are allowed" do
|
||||
before { SiteSetting.allow_user_api_key_client_scopes = "user_status" }
|
||||
|
||||
it "registers a client" do
|
||||
post "/user-api-key-client.json", params: args_with_scopes
|
||||
expect(response.status).to eq(200)
|
||||
client =
|
||||
UserApiKeyClient.find_by(
|
||||
client_id: args_with_scopes[:client_id],
|
||||
application_name: args_with_scopes[:application_name],
|
||||
auth_redirect: args_with_scopes[:auth_redirect],
|
||||
public_key: args_with_scopes[:public_key],
|
||||
)
|
||||
expect(client.present?).to eq(true)
|
||||
expect(client.scopes.map(&:name)).to match_array(["user_status"])
|
||||
end
|
||||
|
||||
context "if the client is already registered" do
|
||||
before { Fabricate(:user_api_key_client, **args) }
|
||||
|
||||
it "returns a 403" do
|
||||
post "/user-api-key-client.json", params: args_with_scopes
|
||||
expect(response.status).to eq(403)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
Reference in New Issue
Block a user