From 80c733143bceac76dec7c0adadb220547354195e Mon Sep 17 00:00:00 2001 From: Chris Blanchard Date: Mon, 17 Aug 2015 18:55:03 +0100 Subject: [PATCH 1/5] Added id to users API index method --- app/services/api/v1/users_collection.rb | 4 +++- spec/controllers/api/v1/users_controller_spec.rb | 2 +- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/app/services/api/v1/users_collection.rb b/app/services/api/v1/users_collection.rb index 8065d41..2630913 100644 --- a/app/services/api/v1/users_collection.rb +++ b/app/services/api/v1/users_collection.rb @@ -29,7 +29,8 @@ class Api::V1::UsersCollection < Api::V1::Collection users_table[:steamid], teams_table[:name], teams_table[:tag], - teams_table[:logo] + teams_table[:logo], + users_table[:id] ] end @@ -45,6 +46,7 @@ class Api::V1::UsersCollection < Api::V1::Collection def map_query execute_query.map do |row| { + id: row[5], username: row[0], steamid: row[1], team: { diff --git a/spec/controllers/api/v1/users_controller_spec.rb b/spec/controllers/api/v1/users_controller_spec.rb index 72b42ab..3a8d07e 100644 --- a/spec/controllers/api/v1/users_controller_spec.rb +++ b/spec/controllers/api/v1/users_controller_spec.rb @@ -81,11 +81,11 @@ describe Api::V1::UsersController do it 'returns the excpected JSON keys' do get :index - user_json = json["users"].first nested_team_json = user_json["team"] expect(user_json).to have_key("username") + expect(user_json).to have_key("id") expect(user_json).to have_key("steamid") expect(user_json).to have_key("team") expect(nested_team_json).to have_key("name") From c7a81d8e75ec709df573413866dfbb97e296a5de Mon Sep 17 00:00:00 2001 From: Chris Blanchard Date: Mon, 17 Aug 2015 19:06:47 +0100 Subject: [PATCH 2/5] Invalid steam ids on the users API now returns null for steam attributes --- app/controllers/api/v1/users_controller.rb | 14 +++++++++++--- spec/controllers/api/v1/users_controller_spec.rb | 11 +++++++++++ spec/services/api/v1/users_collection_spec.rb | 4 ++-- 3 files changed, 24 insertions(+), 5 deletions(-) diff --git a/app/controllers/api/v1/users_controller.rb b/app/controllers/api/v1/users_controller.rb index ea0f56b..bae11dc 100644 --- a/app/controllers/api/v1/users_controller.rb +++ b/app/controllers/api/v1/users_controller.rb @@ -5,7 +5,7 @@ class Api::V1::UsersController < Api::V1::BaseController def show @user = User.find(params[:id]) - @steam = SteamCondenser::Community::SteamId.from_steam_id("STEAM_#{@user.steamid}") + @steam = steam_profile @user render json: { id: @user.id, @@ -15,8 +15,8 @@ class Api::V1::UsersController < Api::V1::BaseController avatar: @user.profile.avatar.url, admin: @user.admin?, steam: { - url: @steam.base_url, - nickname: @steam.nickname + url: @steam.nil? ? nil : @steam.base_url, + nickname: @steam.nil? ? nil : @steam.nickname }, bans: { gather: @user.banned?(Ban::TYPE_GATHER).present?, @@ -28,4 +28,12 @@ class Api::V1::UsersController < Api::V1::BaseController rescue ActiveRecord::RecordNotFound raise ActionController::RoutingError.new('User Not Found') end + + private + + def steam_profile user + SteamCondenser::Community::SteamId.from_steam_id("STEAM_#{user.steamid}") + rescue SteamCondenser::Error => e + return nil + end end diff --git a/spec/controllers/api/v1/users_controller_spec.rb b/spec/controllers/api/v1/users_controller_spec.rb index 3a8d07e..4ea3f54 100644 --- a/spec/controllers/api/v1/users_controller_spec.rb +++ b/spec/controllers/api/v1/users_controller_spec.rb @@ -28,6 +28,17 @@ describe Api::V1::UsersController do expect(json['team']).to be_nil end + it 'returns data for users with invalid steam ids' do + @user.steamid = '0:0:000' + @user.save! + + get :show, id: @user.id + + expect(response).to be_success + expect(json['steam']['url']).to be_nil + expect(json['steam']['nickname']).to be_nil + end + it 'returns 404 if user does not exist' do expect { get :show, id: -1 diff --git a/spec/services/api/v1/users_collection_spec.rb b/spec/services/api/v1/users_collection_spec.rb index 9d29c02..62dfbd9 100644 --- a/spec/services/api/v1/users_collection_spec.rb +++ b/spec/services/api/v1/users_collection_spec.rb @@ -23,8 +23,8 @@ describe Api::V1::UsersCollection do expect(collection.execute_query.size).to eq(3) end - it 'returns 5 columns' do - expect(collection.execute_query.first.size).to eq(5) + it 'returns 6 columns' do + expect(collection.execute_query.first.size).to eq(6) end end end From 25479aa4a4d37e6e9b977869a2429d6c2a49c607 Mon Sep 17 00:00:00 2001 From: Chris Blanchard Date: Mon, 17 Aug 2015 19:16:32 +0100 Subject: [PATCH 3/5] Fix style --- app/controllers/api/v1/users_controller.rb | 8 +-- .../api/v1/users_controller_spec.rb | 64 +++++++++---------- spec/services/api/v1/users_collection_spec.rb | 14 ++-- 3 files changed, 43 insertions(+), 43 deletions(-) diff --git a/app/controllers/api/v1/users_controller.rb b/app/controllers/api/v1/users_controller.rb index bae11dc..69af4ba 100644 --- a/app/controllers/api/v1/users_controller.rb +++ b/app/controllers/api/v1/users_controller.rb @@ -15,7 +15,7 @@ class Api::V1::UsersController < Api::V1::BaseController avatar: @user.profile.avatar.url, admin: @user.admin?, steam: { - url: @steam.nil? ? nil : @steam.base_url, + url: @steam.nil? ? nil : @steam.base_url, nickname: @steam.nil? ? nil : @steam.nickname }, bans: { @@ -31,9 +31,9 @@ class Api::V1::UsersController < Api::V1::BaseController private - def steam_profile user + def steam_profile(user) SteamCondenser::Community::SteamId.from_steam_id("STEAM_#{user.steamid}") - rescue SteamCondenser::Error => e - return nil + rescue SteamCondenser::Error + nil end end diff --git a/spec/controllers/api/v1/users_controller_spec.rb b/spec/controllers/api/v1/users_controller_spec.rb index 4ea3f54..2701f7a 100644 --- a/spec/controllers/api/v1/users_controller_spec.rb +++ b/spec/controllers/api/v1/users_controller_spec.rb @@ -1,87 +1,87 @@ -require 'spec_helper' +require "spec_helper" describe Api::V1::UsersController do before do - request.accept = 'application/json' + request.accept = "application/json" end - describe '#show' do + describe "#show" do before(:each) do @user = create :user, :chris end - it 'returns user data' do + it "returns user data" do get :show, id: @user.id expect(response).to be_success - expect(json['id']).to eq(@user.id) - expect(json['username']).to eq(@user.username) - expect(json['country']).to eq(@user.country) - expect(json['time_zone']).to eq(@user.time_zone) - expect(json['admin']).to eq(@user.admin?) + expect(json["id"]).to eq(@user.id) + expect(json["username"]).to eq(@user.username) + expect(json["country"]).to eq(@user.country) + expect(json["time_zone"]).to eq(@user.time_zone) + expect(json["admin"]).to eq(@user.admin?) expect(json).to have_key("steam") - expect(json['steam']).to have_key("url") - expect(json['steam']).to have_key("nickname") - expect(json['bans']['mute']).to eq(false) - expect(json['bans']['gather']).to eq(false) - expect(json['bans']['site']).to eq(false) - expect(json['team']).to be_nil + expect(json["steam"]).to have_key("url") + expect(json["steam"]).to have_key("nickname") + expect(json["bans"]["mute"]).to eq(false) + expect(json["bans"]["gather"]).to eq(false) + expect(json["bans"]["site"]).to eq(false) + expect(json["team"]).to be_nil end - it 'returns data for users with invalid steam ids' do - @user.steamid = '0:0:000' + it "returns data for users with invalid steam ids" do + @user.steamid = "0:0:000" @user.save! get :show, id: @user.id expect(response).to be_success - expect(json['steam']['url']).to be_nil - expect(json['steam']['nickname']).to be_nil + expect(json["steam"]["url"]).to be_nil + expect(json["steam"]["nickname"]).to be_nil end - it 'returns 404 if user does not exist' do + it "returns 404 if user does not exist" do expect { get :show, id: -1 }.to raise_error(ActionController::RoutingError) end - it 'returns correct ban if user muted' do + it "returns correct ban if user muted" do create :ban, :mute, user: @user get :show, id: @user.id expect(response).to be_success - expect(json['bans']['mute']).to eq(true) + expect(json["bans"]["mute"]).to eq(true) end - it 'returns correct ban if user gather banned' do + it "returns correct ban if user gather banned" do create :ban, :gather, user: @user get :show, id: @user.id expect(response).to be_success - expect(json['bans']['gather']).to eq(true) + expect(json["bans"]["gather"]).to eq(true) end - it 'returns correct ban if user site banned' do + it "returns correct ban if user site banned" do create :ban, :site, user: @user get :show, id: @user.id expect(response).to be_success - expect(json['bans']['site']).to eq(true) + expect(json["bans"]["site"]).to eq(true) end - it 'returns team information' do + it "returns team information" do @user.destroy @user_with_team = create :user_with_team, :chris get :show, id: @user_with_team.id expect(response).to be_success - expect(json['team']['id']).to eq(@user_with_team.team.id) - expect(json['team']['name']).to eq(@user_with_team.team.name) + expect(json["team"]["id"]).to eq(@user_with_team.team.id) + expect(json["team"]["name"]).to eq(@user_with_team.team.name) end end - describe '#index' do + describe "#index" do before do 5.times { create(:user_with_team) } end - it 'returns all users and associated teams' do + it "returns all users and associated teams" do users = User.all get :index @@ -90,7 +90,7 @@ describe Api::V1::UsersController do expect(json["users"].size).to eq(users.size) end - it 'returns the excpected JSON keys' do + it "returns the excpected JSON keys" do get :index user_json = json["users"].first nested_team_json = user_json["team"] diff --git a/spec/services/api/v1/users_collection_spec.rb b/spec/services/api/v1/users_collection_spec.rb index 62dfbd9..66437e9 100644 --- a/spec/services/api/v1/users_collection_spec.rb +++ b/spec/services/api/v1/users_collection_spec.rb @@ -1,29 +1,29 @@ -require 'spec_helper' +require "spec_helper" describe Api::V1::UsersCollection do let(:collection) { Api::V1::UsersCollection.new } - describe '#execute_query' do - describe 'when there are users with no teams' do + describe "#execute_query" do + describe "when there are users with no teams" do before do 3.times { create(:user) } end - it 'returns 0 results' do + it "returns 0 results" do expect(collection.execute_query.size).to eq(0) end end - describe 'when there are some users with teams' do + describe "when there are some users with teams" do before do 3.times { create(:user_with_team) } end - it 'returns 3 results' do + it "returns 3 results" do expect(collection.execute_query.size).to eq(3) end - it 'returns 6 columns' do + it "returns 6 columns" do expect(collection.execute_query.first.size).to eq(6) end end From 007c74a6fbfd799048c396cb660ccb34fe3fcef5 Mon Sep 17 00:00:00 2001 From: Chris Blanchard Date: Tue, 18 Aug 2015 11:05:52 +0100 Subject: [PATCH 4/5] Share production ensl session store with subdomains --- config/environments/production.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/environments/production.rb b/config/environments/production.rb index c646579..6cdc6d3 100644 --- a/config/environments/production.rb +++ b/config/environments/production.rb @@ -63,5 +63,5 @@ Ensl::Application.configure do config.active_support.deprecation = :notify # Custom Session Store config to allow gathers.staging.ensl.org - # config.session_store :cookie_store, key: '_ENSL_session_key', expire_after: 30.days.to_i, domain: "gathers.ensl.org" + config.session_store :cookie_store, key: "_ENSL_session_key", expire_after: 30.days.to_i, domain: ".ensl.org" end \ No newline at end of file From 676efdd3f089196abfaf99487075373ebec5d2fe Mon Sep 17 00:00:00 2001 From: Chris Blanchard Date: Thu, 20 Aug 2015 13:56:07 +0100 Subject: [PATCH 5/5] Prevent crawls of large data files --- public/robots.txt | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/public/robots.txt b/public/robots.txt index 085187f..8958fb4 100644 --- a/public/robots.txt +++ b/public/robots.txt @@ -1,5 +1,7 @@ # See http://www.robotstxt.org/wc/norobots.html for documentation on how to use the robots.txt file # # To ban all spiders from the entire site uncomment the next two lines: -# User-Agent: * -# Disallow: / +User-Agent: * +Disallow: /data_files +Disallow: /directories +Disallow: /movies \ No newline at end of file