FIX: Suspicious login detection (#6772)
This commit is contained in:
parent
77fe57f923
commit
1960236822
|
@ -36,7 +36,7 @@ class UserAuthToken < ActiveRecord::Base
|
||||||
def self.login_location(ip)
|
def self.login_location(ip)
|
||||||
ipinfo = DiscourseIpInfo.get(ip)
|
ipinfo = DiscourseIpInfo.get(ip)
|
||||||
|
|
||||||
ipinfo['latitude'] && ipinfo['longitude'] ? [ipinfo['latitude'], ipinfo['longitude']] : nil
|
ipinfo[:latitude] && ipinfo[:longitude] ? [ipinfo[:latitude], ipinfo[:longitude]] : nil
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.distance(loc1, loc2)
|
def self.distance(loc1, loc2)
|
||||||
|
|
|
@ -4,20 +4,20 @@ describe Jobs::SuspiciousLogin do
|
||||||
|
|
||||||
let(:user) { Fabricate(:moderator) }
|
let(:user) { Fabricate(:moderator) }
|
||||||
|
|
||||||
let(:zurich) { [47.3686498, 8.5391825] } # Zurich, Switzerland
|
let(:zurich) { { latitude: 47.3686498, longitude: 8.5391825 } } # Zurich, Switzerland
|
||||||
let(:bern) { [46.947922, 7.444608] } # Bern, Switzerland
|
let(:bern) { { latitude: 46.947922, longitude: 7.444608 } } # Bern, Switzerland
|
||||||
let(:london) { [51.5073509, -0.1277583] } # London, United Kingdom
|
let(:london) { { latitude: 51.5073509, longitude: -0.1277583 } } # London, United Kingdom
|
||||||
|
|
||||||
before do
|
before do
|
||||||
UserAuthToken.stubs(:login_location).with("1.1.1.1").returns(zurich)
|
DiscourseIpInfo.stubs(:get).with("1.1.1.1").returns(zurich)
|
||||||
UserAuthToken.stubs(:login_location).with("1.1.1.2").returns(bern)
|
DiscourseIpInfo.stubs(:get).with("1.1.1.2").returns(bern)
|
||||||
UserAuthToken.stubs(:login_location).with("1.1.2.1").returns(london)
|
DiscourseIpInfo.stubs(:get).with("1.1.2.1").returns(london)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "will correctly compute distance" do
|
it "will correctly compute distance" do
|
||||||
def expect_distance(from, to, distance)
|
def expect_distance(from, to, distance)
|
||||||
expect(UserAuthToken.distance(from, to).to_i).to eq(distance)
|
expect(UserAuthToken.distance(from.values, to.values).to_i).to eq(distance)
|
||||||
expect(UserAuthToken.distance(to, from).to_i).to eq(distance)
|
expect(UserAuthToken.distance(to.values, from.values).to_i).to eq(distance)
|
||||||
end
|
end
|
||||||
|
|
||||||
expect_distance(zurich, bern, 95)
|
expect_distance(zurich, bern, 95)
|
||||||
|
|
Loading…
Reference in New Issue