Merge pull request #36 from cblanc/expand_api

Expand api
This commit is contained in:
simplefl 2015-08-01 19:02:48 +02:00
commit cf2fcd6e89
11 changed files with 213 additions and 77 deletions

View file

@ -0,0 +1,17 @@
class Api::V1::MapsController < Api::V1::BaseController
def index
render json: { maps: gather_maps }
end
private
def gather_maps
Map.classic.basic.map do |m|
{
id: m.id,
name: m.name,
category_id: m.category_id
}
end
end
end

View file

@ -0,0 +1,21 @@
class Api::V1::ServersController < Api::V1::BaseController
def index
render json: { servers: active_servers }
end
private
def active_servers
Server.active.map do |s|
{
id: s.id,
description: s.description,
dns: s.dns,
ip: s.ip,
port: s.port,
password: s.password,
category_id: s.category_id
}
end
end
end

View file

@ -17,7 +17,13 @@ class Api::V1::UsersController < Api::V1::BaseController
steam: { steam: {
url: @steam.base_url, url: @steam.base_url,
nickname: @steam.nickname nickname: @steam.nickname
} },
bans: {
gather: @user.banned?(Ban::TYPE_GATHER).present?,
mute: @user.banned?(Ban::TYPE_MUTE).present?,
site: @user.banned?(Ban::TYPE_SITE).present?
},
team: @user.team.present? ? { id: @user.team.id, name: @user.team.name } : nil
} }
rescue ActiveRecord::RecordNotFound rescue ActiveRecord::RecordNotFound
raise ActionController::RoutingError.new('User Not Found') raise ActionController::RoutingError.new('User Not Found')

View file

@ -15,7 +15,6 @@ class ShoutmsgsController < ApplicationController
def create def create
@shoutmsg = Shoutmsg.new params[:shoutmsg] @shoutmsg = Shoutmsg.new params[:shoutmsg]
puts @shoutmsg
@shoutmsg.user = cuser @shoutmsg.user = cuser
raise AccessError unless @shoutmsg.can_create? cuser raise AccessError unless @shoutmsg.can_create? cuser

View file

@ -6,76 +6,78 @@ Ensl::Application.routes.draw do
namespace :api do namespace :api do
namespace :v1 do namespace :v1 do
resources :users, only: [:show, :index] resources :users, only: [:show, :index]
resources :servers, only: [:index]
resources :maps, only: [:index]
end end
end end
root to: "articles#news_index" root to: "articles#news_index"
resources :articles do resources :articles do
resources :versions resources :versions
end end
match 'contests/del_map' match 'contests/del_map'
match 'contests/scores' match 'contests/scores'
match 'contests/historical', to: "contests#historical" match 'contests/historical', to: "contests#historical"
resources :contests do resources :contests do
get 'current', on: :collection get 'current', on: :collection
end end
resources :log_events resources :log_events
resources :categories resources :categories
resources :options resources :options
resources :polls resources :polls
match 'comments/quote' match 'comments/quote'
resources :comments resources :comments
resources :shoutmsgs resources :shoutmsgs
resources :teamers resources :teamers
resources :teams resources :teams
resources :gathers resources :gathers
resources :gatherers resources :gatherers
resources :groups resources :groups
resources :groupers resources :groupers
resources :forumers resources :forumers
resources :topics resources :topics
match 'forums/up' match 'forums/up'
match 'forums/down' match 'forums/down'
resources :forums resources :forums
resources :users resources :users
resources :locks resources :locks
resources :contesters resources :contesters
resources :contests resources :contests
resources :challenges resources :challenges
resources :servers resources :servers
resources :predictions resources :predictions
resources :rounds resources :rounds
resources :matches do |m| resources :matches do |m|
get :admin, to: "matches#admin", on: :collection get :admin, to: "matches#admin", on: :collection
get :ref, to: "matches#ref" get :ref, to: "matches#ref"
end end
resources :maps resources :maps
resources :logs resources :logs
resources :log_files resources :log_files
resources :directories resources :directories
resources :data_files resources :data_files
resources :predictions resources :predictions
resources :weeks resources :weeks
resources :movies resources :movies
resources :messages resources :messages
resources :sites resources :sites
resources :bans resources :bans
resources :tweets resources :tweets
resources :issues resources :issues
match 'posts/quote' match 'posts/quote'
resources :posts resources :posts
resources :brackets resources :brackets
match 'about/action' match 'about/action'
match 'about/staff' match 'about/staff'
@ -127,10 +129,10 @@ Ensl::Application.routes.draw do
match 'votes/create' match 'votes/create'
match ':controller/:action', requirements: { action: /A-Za-z/ } match ':controller/:action', requirements: { action: /A-Za-z/ }
match ':controller/:action/:id' match ':controller/:action/:id'
match ':controller/:action/:id.:format' match ':controller/:action/:id.:format'
match ':controller/:action/:id/:id2' match ':controller/:action/:id/:id2'
match 'teamers/replace', to: 'teamers#replace', as: 'teamers_replace' match 'teamers/replace', to: 'teamers#replace', as: 'teamers_replace'
end end

View file

@ -0,0 +1,19 @@
require 'spec_helper'
describe Api::V1::MapsController do
before do
request.accept = 'application/json'
end
describe '#index' do
let!(:map) { create :map }
it 'returns a list of maps' do
get :index
expect(response).to be_success
expect(json['maps'].length).to eq(1)
json_map = json['maps'][0]
expect(json_map['id']).to eq(map.id)
end
end
end

View file

@ -0,0 +1,20 @@
require 'spec_helper'
describe Api::V1::ServersController do
before do
request.accept = 'application/json'
end
describe '#index' do
let!(:server) { create :server, :active }
let!(:inactive_server) { create :server, :inactive }
it 'returns a list of servers' do
get :index
expect(response).to be_success
expect(json['servers'].length).to eq(1)
json_server = json['servers'][0]
expect(json_server['id']).to eq(server.id)
end
end
end

View file

@ -6,8 +6,8 @@ describe Api::V1::UsersController do
end end
describe '#show' do describe '#show' do
before do before(:each) do
@user = create :user_with_team, :chris @user = create :user, :chris
end end
it 'returns user data' do it 'returns user data' do
@ -22,6 +22,10 @@ describe Api::V1::UsersController do
expect(json).to have_key("steam") expect(json).to have_key("steam")
expect(json['steam']).to have_key("url") expect(json['steam']).to have_key("url")
expect(json['steam']).to have_key("nickname") 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 end
it 'returns 404 if user does not exist' do it 'returns 404 if user does not exist' do
@ -29,6 +33,33 @@ describe Api::V1::UsersController do
get :show, id: -1 get :show, id: -1
}.to raise_error(ActionController::RoutingError) }.to raise_error(ActionController::RoutingError)
end end
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)
end
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)
end
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)
end
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)
end
end end
describe '#index' do describe '#index' do

View file

@ -1,23 +1,31 @@
FactoryGirl.define do FactoryGirl.define do
factory :ban do factory :ban do
ban_type Ban::TYPE_SITE ban_type Ban::TYPE_SITE
expiry Date.today + 1 expiry Date.today + 1
# Hack because of the awkward way bans are created (requires user_name) # Hack because of the awkward way bans are created (requires user_name)
before(:create) do |ban| before(:create) do |ban|
if ban.user.nil? if ban.user.nil?
user = create :user user = create :user
ban.user_name = user.username ban.user_name = user.username
else else
ban.user_name = ban.user.username ban.user_name = ban.user.username
end end
end end
end end
trait :mute do trait :mute do
ban_type Ban::TYPE_MUTE ban_type Ban::TYPE_MUTE
end end
trait :expired do trait :site do
expiry Date.yesterday - 1 ban_type Ban::TYPE_SITE
end end
trait :gather do
ban_type Ban::TYPE_GATHER
end
trait :expired do
expiry Date.yesterday - 1
end
end end

5
spec/factories/map.rb Normal file
View file

@ -0,0 +1,5 @@
FactoryGirl.define do
factory :map do
sequence(:name) { |n| "ns_MapName#{n}" }
end
end

View file

@ -1,8 +1,16 @@
FactoryGirl.define do FactoryGirl.define do
factory :server do factory :server do
sequence(:name) { |n| "ServerName#{n}" } sequence(:name) { |n| "ServerName#{n}" }
sequence(:dns) { |n| "DNS#{n}" } sequence(:dns) { |n| "DNS#{n}" }
sequence(:ip) { |n| "192.168.#{n % 255}.#{n}" } sequence(:ip) { |n| "192.168.#{n % 255}.#{n}" }
sequence(:port) { |n| "#{1000 + n}" } sequence(:port) { |n| "#{1000 + n}" }
end
trait :active do
active true
end
trait :inactive do
active false
end
end
end end