mirror of
https://github.com/discourse/discourse.git
synced 2025-01-26 12:18:46 +08:00
116 lines
3.5 KiB
Ruby
116 lines
3.5 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
describe "Discord OAuth2" do
|
||
|
let(:access_token) { "discord_access_token_448" }
|
||
|
let(:client_id) { "abcdef11223344" }
|
||
|
let(:client_secret) { "adddcccdddd99922" }
|
||
|
let(:temp_code) { "discord_temp_code_544254" }
|
||
|
|
||
|
fab!(:user1) { Fabricate(:user) }
|
||
|
|
||
|
def setup_discord_email_stub(email, verified:)
|
||
|
stub_request(:get, "https://discord.com/api/users/@me").with(
|
||
|
headers: {
|
||
|
"Authorization" => "Bearer #{access_token}",
|
||
|
},
|
||
|
).to_return(
|
||
|
status: 200,
|
||
|
body:
|
||
|
JSON.dump(
|
||
|
id: "80351110224678912",
|
||
|
username: "Nelly",
|
||
|
discriminator: "1337",
|
||
|
avatar: "8342729096ea3675442027381ff50dfe",
|
||
|
verified: verified,
|
||
|
email: email,
|
||
|
flags: 64,
|
||
|
banner: "06c16474723fe537c283b8efa61a30c8",
|
||
|
accent_color: 16_711_680,
|
||
|
premium_type: 1,
|
||
|
public_flags: 64,
|
||
|
),
|
||
|
headers: {
|
||
|
"Content-Type" => "application/json",
|
||
|
},
|
||
|
)
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
SiteSetting.enable_discord_logins = true
|
||
|
SiteSetting.discord_client_id = client_id
|
||
|
SiteSetting.discord_secret = client_secret
|
||
|
|
||
|
stub_request(:post, "https://discord.com/api/oauth2/token").with(
|
||
|
body:
|
||
|
hash_including(
|
||
|
"client_id" => client_id,
|
||
|
"client_secret" => client_secret,
|
||
|
"code" => temp_code,
|
||
|
"grant_type" => "authorization_code",
|
||
|
"redirect_uri" => "http://test.localhost/auth/discord/callback",
|
||
|
),
|
||
|
).to_return(
|
||
|
status: 200,
|
||
|
body:
|
||
|
Rack::Utils.build_query(
|
||
|
access_token: access_token,
|
||
|
scope: "identify emails guilds",
|
||
|
token_type: "Bearer",
|
||
|
expires_in: 604_800,
|
||
|
refresh_token: "D43f5y0ahjqew82jZ4NViEr2YafMKhue",
|
||
|
),
|
||
|
headers: {
|
||
|
"Content-Type" => "application/x-www-form-urlencoded",
|
||
|
},
|
||
|
)
|
||
|
|
||
|
stub_request(:get, "https://discord.com/api/users/@me/guilds").with(
|
||
|
headers: {
|
||
|
"Authorization" => "Bearer #{access_token}",
|
||
|
},
|
||
|
).to_return(
|
||
|
status: 200,
|
||
|
body:
|
||
|
JSON.dump(
|
||
|
id: "80351110224678912",
|
||
|
name: "1337 Krew",
|
||
|
icon: "8342729096ea3675442027381ff50dfe",
|
||
|
owner: true,
|
||
|
permissions: "36953089",
|
||
|
features: %w[COMMUNITY NEWS],
|
||
|
),
|
||
|
headers: {
|
||
|
"Content-Type" => "application/json",
|
||
|
},
|
||
|
)
|
||
|
end
|
||
|
|
||
|
it "doesn't sign in anyone if the email from discord is not verified" do
|
||
|
post "/auth/discord"
|
||
|
expect(response.status).to eq(302)
|
||
|
expect(response.location).to start_with("https://discord.com/api/oauth2/authorize")
|
||
|
|
||
|
setup_discord_email_stub(user1.email, verified: false)
|
||
|
|
||
|
post "/auth/discord/callback", params: { state: session["omniauth.state"], code: temp_code }
|
||
|
|
||
|
expect(response.status).to eq(302)
|
||
|
expect(response.location).to eq("http://test.localhost/")
|
||
|
expect(session[:current_user_id]).to be_blank
|
||
|
end
|
||
|
|
||
|
it "signs in the user if the email from discord is verified and matches the user's email" do
|
||
|
post "/auth/discord"
|
||
|
expect(response.status).to eq(302)
|
||
|
expect(response.location).to start_with("https://discord.com/api/oauth2/authorize")
|
||
|
|
||
|
setup_discord_email_stub(user1.email, verified: true)
|
||
|
|
||
|
post "/auth/discord/callback", params: { state: session["omniauth.state"], code: temp_code }
|
||
|
|
||
|
expect(response.status).to eq(302)
|
||
|
expect(response.location).to eq("http://test.localhost/")
|
||
|
expect(session[:current_user_id]).to eq(user1.id)
|
||
|
end
|
||
|
end
|