Skip to content

Commit

Permalink
Merge pull request huginn#1017 from cantino/allow_url_from_event_to_b…
Browse files Browse the repository at this point in the history
…e_array

Allow url_from_event in the WebsiteAgent to be an Array
  • Loading branch information
cantino committed Sep 9, 2015
2 parents 2824161 + 48d5990 commit 065a35c
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 4 deletions.
8 changes: 4 additions & 4 deletions app/models/agents/website_agent.rb
Original file line number Diff line number Diff line change
Expand Up @@ -251,11 +251,11 @@ def check
check_urls(interpolated['url'])
end

def check_urls(in_url)
def check_urls(in_url, payload = {})
return unless in_url.present?

Array(in_url).each do |url|
check_url(url)
check_url(url, payload)
end
end

Expand Down Expand Up @@ -322,11 +322,11 @@ def receive(incoming_events)
interpolate_with(event) do
url_to_scrape =
if url_template = options['url_from_event'].presence
interpolate_string(url_template)
interpolate_options(url_template)
else
event.payload['url']
end
check_url(url_to_scrape,
check_urls(url_to_scrape,
interpolated['mode'].to_s == "merge" ? event.payload : {})
end
end
Expand Down
13 changes: 13 additions & 0 deletions spec/models/agents/website_agent_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -673,6 +673,19 @@
expect(stub).to have_been_requested
end

it "should allow url_from_event to be an array of urls" do
stub1 = stub_request(:any, 'http://example.org/?url=http%3A%2F%2Fxkcd.com')
stub2 = stub_request(:any, 'http://google.org/?url=http%3A%2F%2Fxkcd.com')

@checker.options = @valid_options.merge(
'url_from_event' => ['http://example.org/?url={{url | uri_escape}}', 'http://google.org/?url={{url | uri_escape}}']
)
@checker.receive([@event])

expect(stub1).to have_been_requested
expect(stub2).to have_been_requested
end

it "should interpolate values from incoming event payload" do
expect {
@valid_options['extract'] = {
Expand Down

0 comments on commit 065a35c

Please sign in to comment.