airbrake 4.2.0 → 4.2.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG +29 -1
- data/lib/airbrake.rb +1 -0
- data/lib/airbrake/cli/client.rb +11 -5
- data/lib/airbrake/cli/options.rb +14 -11
- data/lib/airbrake/cli/printer.rb +7 -4
- data/lib/airbrake/rails.rb +6 -4
- data/lib/airbrake/rails/controller_methods.rb +1 -1
- data/lib/airbrake/version.rb +1 -1
- data/resources/notice.xml +2 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: bdcc32fee19d4bee22a412fd87357392fbda943c
|
4
|
+
data.tar.gz: 41a7ff747ff14ebd2e65bb35aef18d4f486876af
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 20944213193e778553dc05ff6290d4590bdf73ed56341d442b6dc9e25dd26a01547d7168fa03a8e2a31c50ab0f66d9b791f9c79f633d4d0393e6bcab433775ec
|
7
|
+
data.tar.gz: 2225e193cb0e76876d36732b264d5c115647e8ebe90b817a1a35c6f3e9c873dafeeb5a75ce9037a7fb2da440d500c1ee8819f3d1e9eccbb4d4d155fdba9498b6
|
data/CHANGELOG
CHANGED
@@ -1,3 +1,30 @@
|
|
1
|
+
Version 4.2.1 - 2015-06-01 22:12:49 -0500
|
2
|
+
===============================================================================
|
3
|
+
|
4
|
+
Marko Šiftar (3):
|
5
|
+
Merge pull request #384 from biske/improve-notify-documentation
|
6
|
+
Merge pull request #385 from arrtchiu/patch-2
|
7
|
+
Merge pull request #386 from airbrake/fix/check-if-failsafe-middleware-is-defined
|
8
|
+
|
9
|
+
Phuong Nguyen (1):
|
10
|
+
Insert UserInformer middleware before Rack::Runtime since Rack::Lock may not be available for app with websocket-rails
|
11
|
+
|
12
|
+
arrtchiu (1):
|
13
|
+
Support Rails 4 without ActiveRecord
|
14
|
+
|
15
|
+
shifi (7):
|
16
|
+
typo in changelog
|
17
|
+
add more args in deploy CLI - fixes #296
|
18
|
+
update CLI help info
|
19
|
+
do not require pry - fix typo
|
20
|
+
check if failsafe middleware is defined - fixes #379
|
21
|
+
fix conflicts
|
22
|
+
Merge branch 'phuongnd08-master'
|
23
|
+
|
24
|
+
Иван Бишевац (1):
|
25
|
+
Improves documentation for notify method
|
26
|
+
|
27
|
+
|
1
28
|
Version 4.2.0 - 2015-05-27 19:05:32 -0500
|
2
29
|
===============================================================================
|
3
30
|
|
@@ -50,7 +77,7 @@ grosser (3):
|
|
50
77
|
halida (1):
|
51
78
|
fix rails request.fullpath behavior change in 4.1.6 -- no longer has leading /
|
52
79
|
|
53
|
-
shifi (
|
80
|
+
shifi (16):
|
54
81
|
add test for filtering frozen objects
|
55
82
|
Merge branch 'Promptus-issue_369_frozen_array_issue'
|
56
83
|
update Appraisals file
|
@@ -1515,5 +1542,6 @@ Nick Quaranto (3):
|
|
1515
1542
|
|
1516
1543
|
|
1517
1544
|
|
1545
|
+
|
1518
1546
|
|
1519
1547
|
|
data/lib/airbrake.rb
CHANGED
@@ -127,6 +127,7 @@ module Airbrake
|
|
127
127
|
# @option opts [String] :rack_env The Rack environment.
|
128
128
|
# @option opts [String] :session The contents of the user's session.
|
129
129
|
# @option opts [String] :environment_name The application environment name.
|
130
|
+
# @option opts [String] :parameters Additional parameters.
|
130
131
|
def notify(exception, opts = {})
|
131
132
|
send_notice(build_notice_for(exception, opts))
|
132
133
|
end
|
data/lib/airbrake/cli/client.rb
CHANGED
@@ -29,15 +29,21 @@ module Client
|
|
29
29
|
end
|
30
30
|
|
31
31
|
def create_deploy
|
32
|
-
uri = URI.parse "http://airbrake.io"
|
33
|
-
"/deploys.txt"
|
32
|
+
uri = URI.parse "http://airbrake.io/deploys.txt"
|
34
33
|
http = Net::HTTP.new(uri.host,uri.port)
|
35
34
|
request = Net::HTTP::Post.new(uri.request_uri)
|
36
|
-
opts = {'
|
37
|
-
opts.merge!('deploy[scm_revision]' => options.scm_revision) if options.scm_revision
|
35
|
+
opts = { 'api_key' => options.api_key }.merge!(deploy_opts)
|
38
36
|
request.set_form_data(opts)
|
39
37
|
response = http.request(request)
|
40
|
-
puts response.
|
38
|
+
puts response.message if response.respond_to?(:message)
|
39
|
+
end
|
40
|
+
|
41
|
+
def deploy_opts
|
42
|
+
opts = {}
|
43
|
+
['rails_env', 'scm_revision', 'scm_repository', 'local_username'].each do |attr|
|
44
|
+
opts.merge!("deploy[#{attr}]" => options.send(attr))
|
45
|
+
end
|
46
|
+
opts
|
41
47
|
end
|
42
48
|
|
43
49
|
def print_projects
|
data/lib/airbrake/cli/options.rb
CHANGED
@@ -1,6 +1,7 @@
|
|
1
1
|
class Options
|
2
2
|
|
3
|
-
ATTRIBUTES = [:error, :message, :api_key, :host, :port, :auth_token, :name,
|
3
|
+
ATTRIBUTES = [:error, :message, :api_key, :host, :port, :auth_token, :name,
|
4
|
+
:account, :rails_env, :scm_revision, :scm_repository, :local_username]
|
4
5
|
|
5
6
|
ATTRIBUTES.each do |attribute|
|
6
7
|
attr_reader attribute
|
@@ -18,16 +19,18 @@ class Options
|
|
18
19
|
# Parses all the options passed and stores them in attributes
|
19
20
|
def initialize(array = [])
|
20
21
|
opts = Hash[*array]
|
21
|
-
self.error
|
22
|
-
self.message
|
23
|
-
self.api_key
|
24
|
-
self.host
|
25
|
-
self.port
|
26
|
-
self.auth_token
|
27
|
-
self.name
|
28
|
-
self.account
|
29
|
-
self.rails_env
|
30
|
-
self.scm_revision
|
22
|
+
self.error = opts.delete("-e") || opts.delete("--error") { RuntimeError }
|
23
|
+
self.message = opts.delete("-m") || opts.delete("--message") { "I've made a huge mistake" }
|
24
|
+
self.api_key = opts.delete("-k") || opts.delete("--api-key") || config_from_file.api_key || ENV["AIRBRAKE_API_KEY"]
|
25
|
+
self.host = opts.delete("-h") || opts.delete("--host") || config_from_file.host
|
26
|
+
self.port = opts.delete("-p") || opts.delete("--port") || config_from_file.port
|
27
|
+
self.auth_token = opts.delete("-t") || opts.delete("--auth-token") || ENV["AIRBRAKE_AUTH_TOKEN"]
|
28
|
+
self.name = opts.delete("-n") || opts.delete("--name")
|
29
|
+
self.account = opts.delete("-a") || opts.delete("--account") || ENV["AIRBRAKE_ACCOUNT"]
|
30
|
+
self.rails_env = opts.delete("-E") || opts.delete("--rails-env") || ENV["RAILS_ENV"] || "production"
|
31
|
+
self.scm_revision = opts.delete("-r") || opts.delete("--scm-revision") || ENV["REVISION"]
|
32
|
+
self.scm_repository = opts.delete("-R") || opts.delete("--scm-repository") || ENV["REPO"]
|
33
|
+
self.local_username = opts.delete("-u") || opts.delete("--local-username") || ENV["USER"]
|
31
34
|
opts
|
32
35
|
end
|
33
36
|
|
data/lib/airbrake/cli/printer.rb
CHANGED
@@ -17,13 +17,16 @@ Commands:
|
|
17
17
|
Options:
|
18
18
|
-e, [--error=ERROR] # Error class to raise. Default: RuntimeError
|
19
19
|
-m, [--message=MESSAGE] # Error message. Default: "I've made a huge mistake"
|
20
|
-
-k, [--api-key=API_KEY] # Api key of your Airbrake application
|
20
|
+
-k, [--api-key=API_KEY] # Api key of your Airbrake application
|
21
21
|
-h, [--host=HOST] # URL of the Airbrake API server. Default: api.airbrake.io
|
22
22
|
-p, [--port=PORT] # Port of the Airbrake API server. Default: 80
|
23
|
-
-t, [--auth-token=AUTH_TOKEN] # The auth token used for API requests
|
24
|
-
-a, [--account=ACCOUNT] # The account used for API requests
|
25
|
-
-n, [--name=NAME] # The name of the project you're trying to create
|
23
|
+
-t, [--auth-token=AUTH_TOKEN] # The auth token used for API requests
|
24
|
+
-a, [--account=ACCOUNT] # The account used for API requests
|
25
|
+
-n, [--name=NAME] # The name of the project you're trying to create
|
26
26
|
-E, [--rails-env=NAME] # The name of the environment you're deploying to. Default: production
|
27
|
+
-r, [--scm-revision=REVISION] # SCM revision for deployment info
|
28
|
+
-R, [--scm-repository=REPO] # SCM repository for deployment info
|
29
|
+
-u, [--local-username=USER] # The name of the user who is deploying
|
27
30
|
-h, [--help] # Show this usage
|
28
31
|
USAGE
|
29
32
|
end
|
data/lib/airbrake/rails.rb
CHANGED
@@ -19,10 +19,12 @@ module Airbrake
|
|
19
19
|
end
|
20
20
|
|
21
21
|
if defined?(::Rails.configuration) && ::Rails.configuration.respond_to?(:middleware)
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
22
|
+
if defined?(ActionController::Failsafe)
|
23
|
+
::Rails.configuration.middleware
|
24
|
+
.insert_after 'ActionController::Failsafe', Airbrake::Rack
|
25
|
+
end
|
26
|
+
::Rails.configuration.middleware
|
27
|
+
.insert_before 'Rack::Runtime', Airbrake::UserInformer
|
26
28
|
end
|
27
29
|
|
28
30
|
Airbrake.configure(true) do |config|
|
@@ -115,7 +115,7 @@ module Airbrake
|
|
115
115
|
ensure
|
116
116
|
# The Airbrake middleware is first in the chain, before ActiveRecord::ConnectionAdapters::ConnectionManagement
|
117
117
|
# kicks in to do its thing. This can cause the connection pool to run out of connections.
|
118
|
-
if defined?(ActiveRecord) && ActiveRecord::Base.respond_to?(:connection_pool)
|
118
|
+
if defined?(ActiveRecord::Base) && ActiveRecord::Base.respond_to?(:connection_pool)
|
119
119
|
ActiveRecord::Base.connection_pool.release_connection
|
120
120
|
end
|
121
121
|
end
|
data/lib/airbrake/version.rb
CHANGED
data/resources/notice.xml
CHANGED
@@ -1 +1,2 @@
|
|
1
|
-
<?xml version="1.0" encoding="UTF-8"?><notice version="2.4"><api-key>myapikey</api-key><notifier><name>Airbrake Notifier</name><version>4.
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?><notice version="2.4"><api-key>myapikey</api-key><notifier><name>Airbrake Notifier</name><version>4.2.0</version><url>https://github.com/airbrake/airbrake</url></notifier><error><class>AirbrakeTestingException</class><message>AirbrakeTestingException:
|
2
|
+
Testing airbrake via "rake airbrake:test". If you can see this, it works.</message><backtrace><line number="432" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/callbacks.rb" method="_run__3460589810992859441__process_action__1355900617236565786__callbacks"/><line number="410" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/callbacks.rb" method="_run_process_action_callbacks"/><line number="94" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/callbacks.rb" method="run_callbacks"/><line number="17" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/abstract_controller/callbacks.rb" method="process_action"/><line number="17" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_controller/metal/rescue.rb" method="process_action"/><line number="30" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_controller/metal/instrumentation.rb" method="block in process_action"/><line number="52" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/notifications.rb" method="block in instrument"/><line number="21" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/notifications/instrumenter.rb" method="instrument"/><line number="52" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/notifications.rb" method="instrument"/><line number="29" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_controller/metal/instrumentation.rb" method="process_action"/><line number="119" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/abstract_controller/base.rb" method="process"/><line number="41" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/abstract_controller/rendering.rb" method="process"/><line number="138" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_controller/metal.rb" method="dispatch"/><line number="14" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_controller/metal/rack_delegation.rb" method="dispatch"/><line number="178" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_controller/metal.rb" method="block in action"/><line number="68" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/routing/route_set.rb" method="call"/><line number="68" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/routing/route_set.rb" method="dispatch"/><line number="33" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/routing/route_set.rb" method="call"/><line number="148" file="[GEM_ROOT]/gems/rack-mount-0.6.14/lib/rack/mount/route_set.rb" method="block in call"/><line number="93" file="[GEM_ROOT]/gems/rack-mount-0.6.14/lib/rack/mount/code_generation.rb" method="block in recognize"/><line number="68" file="[GEM_ROOT]/gems/rack-mount-0.6.14/lib/rack/mount/code_generation.rb" method="optimized_each"/><line number="92" file="[GEM_ROOT]/gems/rack-mount-0.6.14/lib/rack/mount/code_generation.rb" method="recognize"/><line number="139" file="[GEM_ROOT]/gems/rack-mount-0.6.14/lib/rack/mount/route_set.rb" method="call"/><line number="499" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/routing/route_set.rb" method="call"/><line number="17" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/best_standards_support.rb" method="call"/><line number="14" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/head.rb" method="call"/><line number="24" file="[GEM_ROOT]/gems/rack-1.2.8/lib/rack/methodoverride.rb" method="call"/><line number="21" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/params_parser.rb" method="call"/><line number="182" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/flash.rb" method="call"/><line number="149" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/session/abstract_store.rb" method="call"/><line number="302" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/cookies.rb" method="call"/><line number="46" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/callbacks.rb" method="block in call"/><line number="416" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/callbacks.rb" method="_run_call_callbacks"/><line number="44" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/callbacks.rb" method="call"/><line number="106" file="[GEM_ROOT]/gems/rack-1.2.8/lib/rack/sendfile.rb" method="call"/><line number="48" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/remote_ip.rb" method="call"/><line number="13" file="[GEM_ROOT]/gems/railties-3.0.20/lib/rails/rack/logger.rb" method="call"/><line number="17" file="[GEM_ROOT]/gems/rack-1.2.8/lib/rack/runtime.rb" method="call"/><line number="72" file="[GEM_ROOT]/gems/activesupport-3.0.20/lib/active_support/cache/strategy/local_cache.rb" method="call"/><line number="13" file="[GEM_ROOT]/gems/rack-1.2.8/lib/rack/lock.rb" method="block in call"/><line number="13" file="[GEM_ROOT]/gems/rack-1.2.8/lib/rack/lock.rb" method="synchronize"/><line number="13" file="[GEM_ROOT]/gems/rack-1.2.8/lib/rack/lock.rb" method="call"/><line number="30" file="[GEM_ROOT]/gems/actionpack-3.0.20/lib/action_dispatch/middleware/static.rb" method="call"/><line number="168" file="[GEM_ROOT]/gems/railties-3.0.20/lib/rails/application.rb" method="call"/><line number="240" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/task.rb" method="call"/><line number="240" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/task.rb" method="block in execute"/><line number="235" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/task.rb" method="each"/><line number="235" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/task.rb" method="execute"/><line number="179" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/task.rb" method="block in invoke_with_call_chain"/><line number="211" file="/Users/shifi/.rvm/rubies/ruby-2.1.3/lib/ruby/2.1.0/monitor.rb" method="mon_synchronize"/><line number="172" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/task.rb" method="invoke_with_call_chain"/><line number="165" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/task.rb" method="invoke"/><line number="150" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="invoke_task"/><line number="106" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="block (2 levels) in top_level"/><line number="106" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="each"/><line number="106" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="block in top_level"/><line number="115" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="run_with_threads"/><line number="100" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="top_level"/><line number="78" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="block in run"/><line number="176" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="standard_exception_handling"/><line number="75" file="[GEM_ROOT]/gems/rake-10.4.2/lib/rake/application.rb" method="run"/><line number="33" file="[GEM_ROOT]/gems/rake-10.4.2/bin/rake" method="<top (required)>"/><line number="23" file="[GEM_ROOT]/bin/rake" method="load"/><line number="23" file="[GEM_ROOT]/bin/rake" method="<main>"/></backtrace></error><request><url>http://www.example.com/verify</url><component>application</component><action>verify</action><params><var key="action">verify</var><var key="controller">application</var></params><cgi-data><var key="rack.version">["1", "1"]</var><var key="rack.multithread">false</var><var key="rack.multiprocess">true</var><var key="rack.run_once">false</var><var key="REQUEST_METHOD">GET</var><var key="SERVER_NAME">www.example.com</var><var key="SERVER_PORT">80</var><var key="QUERY_STRING"></var><var key="PATH_INFO">/verify</var><var key="rack.url_scheme">http</var><var key="HTTPS">off</var><var key="SCRIPT_NAME"></var><var key="CONTENT_LENGTH">0</var><var key="REMOTE_ADDR">127.0.0.1</var><var key="action_dispatch.parameter_filter">["password"]</var><var key="action_dispatch.show_exceptions">false</var><var key="action_dispatch.remote_ip">127.0.0.1</var><var key="action_dispatch.request.path_parameters"><var key="action">verify</var><var key="controller">application</var></var><var key="action_dispatch.request.content_type"></var><var key="action_dispatch.request.request_parameters"></var><var key="rack.request.query_string"></var><var key="rack.request.query_hash"></var><var key="action_dispatch.request.query_parameters"></var><var key="action_dispatch.request.parameters"><var key="action">verify</var><var key="controller">application</var></var><var key="action_dispatch.request.formats">["text/html"]</var></cgi-data></request><server-environment><project-root>/Users/shifi/work/rackspace/code/airbrake/tmp/rails_root</project-root><environment-name>test</environment-name><hostname>shifi-mac.local</hostname></server-environment><framework>Rails: 3.0.20</framework></notice>
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: airbrake
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 4.2.
|
4
|
+
version: 4.2.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Airbrake
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-
|
11
|
+
date: 2015-06-02 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: builder
|