mirror of
https://github.com/Fishwaldo/huginn.git
synced 2025-03-15 19:31:26 +00:00
Integrate UserLocationUpdatesController into WebRequestsController.
This commit is contained in:
parent
f720291b49
commit
89754a1cb3
5 changed files with 57 additions and 60 deletions
|
@ -1,16 +0,0 @@
|
|||
class UserLocationUpdatesController < ApplicationController
|
||||
skip_before_filter :authenticate_user!
|
||||
|
||||
def create
|
||||
user = User.find_by_id(params[:user_id])
|
||||
if user
|
||||
secret = params[:secret]
|
||||
user.agents.of_type(Agents::UserLocationAgent).find_all {|agent| agent.options[:secret] == secret }.each do |agent|
|
||||
agent.trigger_web_request(params.except(:action, :controller, :user_id, :format), request.method_symbol.to_s, request.format.to_s)
|
||||
end
|
||||
render :text => "ok"
|
||||
else
|
||||
render :text => "user not found", :status => :not_found
|
||||
end
|
||||
end
|
||||
end
|
|
@ -38,4 +38,19 @@ class WebRequestsController < ApplicationController
|
|||
render :text => "user not found", :status => 404
|
||||
end
|
||||
end
|
||||
|
||||
# legacy
|
||||
def update_location
|
||||
if user = User.find_by_id(params[:user_id])
|
||||
secret = params[:secret]
|
||||
user.agents.of_type(Agents::UserLocationAgent).each { |agent|
|
||||
if agent.options[:secret] == secret
|
||||
agent.trigger_web_request(params.except(:action, :controller, :user_id, :format), request.method_symbol.to_s, request.format.to_s)
|
||||
end
|
||||
}
|
||||
render :text => "ok"
|
||||
else
|
||||
render :text => "user not found", :status => :not_found
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -62,10 +62,9 @@ Huginn::Application.routes.draw do
|
|||
|
||||
get "/worker_status" => "worker_status#show"
|
||||
|
||||
post "/users/:user_id/update_location/:secret" => "user_location_updates#create" # legacy
|
||||
|
||||
match "/users/:user_id/web_requests/:agent_id/:secret" => "web_requests#handle_request", :as => :web_requests, :via => [:get, :post, :put, :delete]
|
||||
post "/users/:user_id/webhooks/:agent_id/:secret" => "web_requests#handle_request" # legacy
|
||||
match "/users/:user_id/web_requests/:agent_id/:secret" => "web_requests#handle_request", :as => :web_requests, :via => [:get, :post, :put, :delete]
|
||||
post "/users/:user_id/webhooks/:agent_id/:secret" => "web_requests#handle_request" # legacy
|
||||
post "/users/:user_id/update_location/:secret" => "web_requests#update_location" # legacy
|
||||
|
||||
devise_for :users, :sign_out_via => [ :post, :delete ]
|
||||
get '/auth/:provider/callback', to: 'services#callback'
|
||||
|
|
|
@ -1,39 +0,0 @@
|
|||
require 'spec_helper'
|
||||
|
||||
describe UserLocationUpdatesController do
|
||||
before do
|
||||
@agent = Agent.build_for_type("Agents::UserLocationAgent", users(:bob), :name => "something", :options => { :secret => "my_secret" })
|
||||
@agent.save!
|
||||
end
|
||||
|
||||
it "should create events without requiring login" do
|
||||
post :create, :user_id => users(:bob).to_param, :secret => "my_secret", :longitude => 123, :latitude => 45, :something => "else"
|
||||
@agent.events.last.payload.should == { 'longitude' => "123", 'latitude' => "45", 'something' => "else" }
|
||||
@agent.events.last.lat.should == 45
|
||||
@agent.events.last.lng.should == 123
|
||||
end
|
||||
|
||||
it "should only consider Agents::UserLocationAgents for the given user" do
|
||||
@jane_agent = Agent.build_for_type("Agents::UserLocationAgent", users(:jane), :name => "something", :options => { :secret => "my_secret" })
|
||||
@jane_agent.save!
|
||||
|
||||
post :create, :user_id => users(:bob).to_param, :secret => "my_secret", :longitude => 123, :latitude => 45, :something => "else"
|
||||
@agent.events.last.payload.should == { 'longitude' => "123", 'latitude' => "45", 'something' => "else" }
|
||||
@jane_agent.events.should be_empty
|
||||
end
|
||||
|
||||
it "should raise a 404 error when given an invalid user id" do
|
||||
post :create, :user_id => "123", :secret => "not_my_secret", :longitude => 123, :latitude => 45, :something => "else"
|
||||
response.should be_missing
|
||||
end
|
||||
|
||||
it "should only look at agents with the given secret" do
|
||||
@agent2 = Agent.build_for_type("Agents::UserLocationAgent", users(:bob), :name => "something", :options => { :secret => "my_secret2" })
|
||||
@agent2.save!
|
||||
|
||||
lambda {
|
||||
post :create, :user_id => users(:bob).to_param, :secret => "my_secret2", :longitude => 123, :latitude => 45, :something => "else"
|
||||
@agent2.events.last.payload.should == { 'longitude' => "123", 'latitude' => "45", 'something' => "else" }
|
||||
}.should_not change { @agent.events.count }
|
||||
end
|
||||
end
|
|
@ -94,4 +94,42 @@ describe WebRequestsController do
|
|||
post :handle_request, :user_id => users(:bob).to_param, :agent_id => 454545, :secret => "my_secret", :no => "go"
|
||||
response.should be_missing
|
||||
end
|
||||
end
|
||||
|
||||
describe "legacy update_location endpoint" do
|
||||
before do
|
||||
@agent = Agent.build_for_type("Agents::UserLocationAgent", users(:bob), name: "something", options: { secret: "my_secret" })
|
||||
@agent.save!
|
||||
end
|
||||
|
||||
it "should create events without requiring login" do
|
||||
post :update_location, user_id: users(:bob).to_param, secret: "my_secret", longitude: 123, latitude: 45, something: "else"
|
||||
@agent.events.last.payload.should == { 'longitude' => "123", 'latitude' => "45", 'something' => "else" }
|
||||
@agent.events.last.lat.should == 45
|
||||
@agent.events.last.lng.should == 123
|
||||
end
|
||||
|
||||
it "should only consider Agents::UserLocationAgents for the given user" do
|
||||
@jane_agent = Agent.build_for_type("Agents::UserLocationAgent", users(:jane), name: "something", options: { secret: "my_secret" })
|
||||
@jane_agent.save!
|
||||
|
||||
post :update_location, user_id: users(:bob).to_param, secret: "my_secret", longitude: 123, latitude: 45, something: "else"
|
||||
@agent.events.last.payload.should == { 'longitude' => "123", 'latitude' => "45", 'something' => "else" }
|
||||
@jane_agent.events.should be_empty
|
||||
end
|
||||
|
||||
it "should raise a 404 error when given an invalid user id" do
|
||||
post :update_location, user_id: "123", secret: "not_my_secret", longitude: 123, latitude: 45, something: "else"
|
||||
response.should be_missing
|
||||
end
|
||||
|
||||
it "should only look at agents with the given secret" do
|
||||
@agent2 = Agent.build_for_type("Agents::UserLocationAgent", users(:bob), name: "something", options: { secret: "my_secret2" })
|
||||
@agent2.save!
|
||||
|
||||
lambda {
|
||||
post :update_location, user_id: users(:bob).to_param, secret: "my_secret2", longitude: 123, latitude: 45, something: "else"
|
||||
@agent2.events.last.payload.should == { 'longitude' => "123", 'latitude' => "45", 'something' => "else" }
|
||||
}.should_not change { @agent.events.count }
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue