binnacle 0.4.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +3 -0
- data/.ruby-gemset +1 -0
- data/.ruby-version +1 -0
- data/Gemfile +8 -0
- data/Gemfile.lock +138 -0
- data/LICENSE.txt +22 -0
- data/README.asc +264 -0
- data/Rakefile +48 -0
- data/bin/binnacle +5 -0
- data/binnacle.gemspec +49 -0
- data/lib/binnacle.rb +112 -0
- data/lib/binnacle/client.rb +115 -0
- data/lib/binnacle/commands/commands.rb +20 -0
- data/lib/binnacle/commands/help.rb +21 -0
- data/lib/binnacle/commands/tail.rb +187 -0
- data/lib/binnacle/configuration.rb +278 -0
- data/lib/binnacle/connection.rb +66 -0
- data/lib/binnacle/errors.rb +4 -0
- data/lib/binnacle/http_logging/adapters/ethon.rb +44 -0
- data/lib/binnacle/http_logging/adapters/excon.rb +62 -0
- data/lib/binnacle/http_logging/adapters/http.rb +63 -0
- data/lib/binnacle/http_logging/adapters/httpclient.rb +93 -0
- data/lib/binnacle/http_logging/adapters/net_http.rb +54 -0
- data/lib/binnacle/http_logging/adapters/patron.rb +24 -0
- data/lib/binnacle/http_logging/adapters/typhoeus.rb +20 -0
- data/lib/binnacle/http_logging/http_logger.rb +83 -0
- data/lib/binnacle/logging/formatter.rb +62 -0
- data/lib/binnacle/logging/logging.rb +36 -0
- data/lib/binnacle/logging/request_log_subscriber.rb +120 -0
- data/lib/binnacle/resource.rb +54 -0
- data/lib/binnacle/resources/event.rb +100 -0
- data/lib/binnacle/trap/backtrace.rb +130 -0
- data/lib/binnacle/trap/exception_event.rb +176 -0
- data/lib/binnacle/trap/middleware.rb +45 -0
- data/lib/binnacle/trap/railtie.rb +28 -0
- data/lib/binnacle/version.rb +3 -0
- data/lib/generators/binnacle/binnacle_generator.rb +78 -0
- data/lib/generators/binnacle/templates/firebase-messaging-sw.js.erb +35 -0
- data/spec/adapters/ethon_adapter.rb +19 -0
- data/spec/adapters/excon_adapter.rb +10 -0
- data/spec/adapters/faraday_adapter.rb +46 -0
- data/spec/adapters/http_adapter.rb +14 -0
- data/spec/adapters/http_base_adapter.rb +37 -0
- data/spec/adapters/httparty_adapter.rb +10 -0
- data/spec/adapters/httpclient_adapter.rb +21 -0
- data/spec/adapters/net_http_adapter.rb +14 -0
- data/spec/adapters/open_uri_adapter.rb +17 -0
- data/spec/adapters/patron_adapter.rb +29 -0
- data/spec/adapters/typhoeus_adapter.rb +25 -0
- data/spec/backtrace_spec.rb +197 -0
- data/spec/binnacle_spec.rb +33 -0
- data/spec/client_spec.rb +128 -0
- data/spec/commands_spec.rb +91 -0
- data/spec/configuration_spec.rb +139 -0
- data/spec/connection_spec.rb +34 -0
- data/spec/exception_event_spec.rb +72 -0
- data/spec/http_logger_spec.rb +77 -0
- data/spec/logger_spec.rb +60 -0
- data/spec/spec_helper.rb +117 -0
- data/spec/support/index.html +8 -0
- data/spec/support/index.html.gz +0 -0
- data/spec/support/test.bin +0 -0
- data/spec/support/test_server.rb +31 -0
- data/spec/support/utf8-invalid.html +0 -0
- data/spec/support/utf8.html +8 -0
- data/spec/vcr/binnacle/configure_can_be_configured_via_a_hash_of_options.yml +42 -0
- data/spec/vcr/binnacle/configure_creates_a_module_level_instance_of_a_binnacle_client.yml +42 -0
- data/spec/vcr/binnacle_client/events_invokes_the_events_api.yml +124 -0
- data/spec/vcr/binnacle_client/events_returns_a_collection_of_event_objects.yml +124 -0
- data/spec/vcr/binnacle_client/recents_invokes_the_events_api_recents.yml +83 -0
- data/spec/vcr/binnacle_client/recents_returns_a_collection_of_event_objects.yml +83 -0
- data/spec/vcr/binnacle_client/report_exception_invokes_the_events_api_signal.yml +121 -0
- data/spec/vcr/binnacle_client/signal_asynch_invokes_the_events_api_signal.yml +74 -0
- data/spec/vcr/binnacle_client/signal_invokes_the_events_api_signal.yml +74 -0
- data/spec/vcr/binnacle_client_ready_/returns_true_if_a_connection_has_been_successfully_established.yml +42 -0
- data/spec/vcr/binnacle_command/tail_command_with_n_flag_returns_recent_events.yml +81 -0
- data/spec/vcr/binnacle_connection/initialize_fails_with_incorrect_credentials.yml +40 -0
- data/spec/vcr/binnacle_connection/initialize_retrieves_available_endpoints_upon_successful_connection.yml +42 -0
- data/spec/vcr/binnacle_http_logger/_htt_party_adapter_should_log__ge_t_requests.yml +122 -0
- data/spec/vcr/binnacle_http_logger/_http_adapter_should_log__ge_t_requests.yml +165 -0
- data/spec/vcr/binnacle_http_logger/_http_client_adapter_should_log__ge_t_requests.yml +274 -0
- data/spec/vcr/binnacle_http_logger/ethon_adapter_should_log__ge_t_requests.yml +87 -0
- data/spec/vcr/binnacle_http_logger/excon_adapter_should_log__ge_t_requests.yml +204 -0
- data/spec/vcr/binnacle_http_logger/faraday_adapter_should_log__ge_t_requests.yml +200 -0
- data/spec/vcr/binnacle_http_logger/net_http_adapter_should_log__ge_t_requests.yml +827 -0
- data/spec/vcr/binnacle_http_logger/open_uri_adapter_should_log__ge_t_requests.yml +751 -0
- data/spec/vcr/binnacle_http_logger/patron_adapter_should_log__ge_t_requests.yml +124 -0
- data/spec/vcr/binnacle_http_logger/typhoeus_adapter_should_log__ge_t_requests.yml +124 -0
- data/spec/vcr/binnacle_logging/logging_allows_passing_other_parameters_using_a_hash.yml +119 -0
- data/spec/vcr/binnacle_logging/logging_invokes_the_events_api_signal.yml +75 -0
- data/spec/vcr/binnacle_logging/logging_respects_the_logger_severity.yml +81 -0
- data/vendor/assets/javascripts/atmosphere/atmosphere.js +3487 -0
- data/vendor/assets/javascripts/base64/base64.js +61 -0
- data/vendor/assets/javascripts/binnacle.js +5 -0
- data/vendor/assets/javascripts/binnacle/binnacle.js +9090 -0
- data/vendor/assets/javascripts/firebase/firebase-app-externs.js +261 -0
- data/vendor/assets/javascripts/firebase/firebase-app.js +35 -0
- data/vendor/assets/javascripts/firebase/firebase-auth-externs.js +1300 -0
- data/vendor/assets/javascripts/firebase/firebase-auth.js +241 -0
- data/vendor/assets/javascripts/firebase/firebase-database-externs.js +1700 -0
- data/vendor/assets/javascripts/firebase/firebase-database.js +260 -0
- data/vendor/assets/javascripts/firebase/firebase-messaging-externs.js +164 -0
- data/vendor/assets/javascripts/firebase/firebase-messaging.js +35 -0
- data/vendor/assets/javascripts/firebase/firebase-storage-externs.js +663 -0
- data/vendor/assets/javascripts/firebase/firebase-storage.js +52 -0
- data/vendor/assets/javascripts/firebase/firebase.js +611 -0
- data/vendor/assets/javascripts/moment/locale/af.js +73 -0
- data/vendor/assets/javascripts/moment/locale/ar-dz.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ar-kw.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ar-ly.js +126 -0
- data/vendor/assets/javascripts/moment/locale/ar-ma.js +60 -0
- data/vendor/assets/javascripts/moment/locale/ar-sa.js +105 -0
- data/vendor/assets/javascripts/moment/locale/ar-tn.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ar.js +142 -0
- data/vendor/assets/javascripts/moment/locale/az.js +105 -0
- data/vendor/assets/javascripts/moment/locale/be.js +134 -0
- data/vendor/assets/javascripts/moment/locale/bg.js +90 -0
- data/vendor/assets/javascripts/moment/locale/bn.js +119 -0
- data/vendor/assets/javascripts/moment/locale/bo.js +119 -0
- data/vendor/assets/javascripts/moment/locale/br.js +108 -0
- data/vendor/assets/javascripts/moment/locale/bs.js +143 -0
- data/vendor/assets/javascripts/moment/locale/ca.js +88 -0
- data/vendor/assets/javascripts/moment/locale/cs.js +172 -0
- data/vendor/assets/javascripts/moment/locale/cv.js +63 -0
- data/vendor/assets/javascripts/moment/locale/cy.js +81 -0
- data/vendor/assets/javascripts/moment/locale/da.js +60 -0
- data/vendor/assets/javascripts/moment/locale/de-at.js +79 -0
- data/vendor/assets/javascripts/moment/locale/de-ch.js +78 -0
- data/vendor/assets/javascripts/moment/locale/de.js +78 -0
- data/vendor/assets/javascripts/moment/locale/dv.js +100 -0
- data/vendor/assets/javascripts/moment/locale/el.js +100 -0
- data/vendor/assets/javascripts/moment/locale/en-au.js +67 -0
- data/vendor/assets/javascripts/moment/locale/en-ca.js +63 -0
- data/vendor/assets/javascripts/moment/locale/en-gb.js +67 -0
- data/vendor/assets/javascripts/moment/locale/en-ie.js +67 -0
- data/vendor/assets/javascripts/moment/locale/en-nz.js +67 -0
- data/vendor/assets/javascripts/moment/locale/eo.js +73 -0
- data/vendor/assets/javascripts/moment/locale/es-do.js +82 -0
- data/vendor/assets/javascripts/moment/locale/es.js +83 -0
- data/vendor/assets/javascripts/moment/locale/et.js +80 -0
- data/vendor/assets/javascripts/moment/locale/eu.js +66 -0
- data/vendor/assets/javascripts/moment/locale/fa.js +107 -0
- data/vendor/assets/javascripts/moment/locale/fi.js +107 -0
- data/vendor/assets/javascripts/moment/locale/fo.js +60 -0
- data/vendor/assets/javascripts/moment/locale/fr-ca.js +74 -0
- data/vendor/assets/javascripts/moment/locale/fr-ch.js +78 -0
- data/vendor/assets/javascripts/moment/locale/fr.js +83 -0
- data/vendor/assets/javascripts/moment/locale/fy.js +75 -0
- data/vendor/assets/javascripts/moment/locale/gd.js +76 -0
- data/vendor/assets/javascripts/moment/locale/gl.js +77 -0
- data/vendor/assets/javascripts/moment/locale/gom-latn.js +122 -0
- data/vendor/assets/javascripts/moment/locale/he.js +99 -0
- data/vendor/assets/javascripts/moment/locale/hi.js +124 -0
- data/vendor/assets/javascripts/moment/locale/hr.js +145 -0
- data/vendor/assets/javascripts/moment/locale/hu.js +109 -0
- data/vendor/assets/javascripts/moment/locale/hy-am.js +95 -0
- data/vendor/assets/javascripts/moment/locale/id.js +83 -0
- data/vendor/assets/javascripts/moment/locale/is.js +127 -0
- data/vendor/assets/javascripts/moment/locale/it.js +70 -0
- data/vendor/assets/javascripts/moment/locale/ja.js +80 -0
- data/vendor/assets/javascripts/moment/locale/jv.js +83 -0
- data/vendor/assets/javascripts/moment/locale/ka.js +89 -0
- data/vendor/assets/javascripts/moment/locale/kk.js +87 -0
- data/vendor/assets/javascripts/moment/locale/km.js +58 -0
- data/vendor/assets/javascripts/moment/locale/kn.js +126 -0
- data/vendor/assets/javascripts/moment/locale/ko.js +69 -0
- data/vendor/assets/javascripts/moment/locale/ky.js +88 -0
- data/vendor/assets/javascripts/moment/locale/lb.js +137 -0
- data/vendor/assets/javascripts/moment/locale/lo.js +70 -0
- data/vendor/assets/javascripts/moment/locale/lt.js +117 -0
- data/vendor/assets/javascripts/moment/locale/lv.js +97 -0
- data/vendor/assets/javascripts/moment/locale/me.js +111 -0
- data/vendor/assets/javascripts/moment/locale/mi.js +64 -0
- data/vendor/assets/javascripts/moment/locale/mk.js +90 -0
- data/vendor/assets/javascripts/moment/locale/ml.js +81 -0
- data/vendor/assets/javascripts/moment/locale/mr.js +159 -0
- data/vendor/assets/javascripts/moment/locale/ms-my.js +83 -0
- data/vendor/assets/javascripts/moment/locale/ms.js +82 -0
- data/vendor/assets/javascripts/moment/locale/my.js +96 -0
- data/vendor/assets/javascripts/moment/locale/nb.js +63 -0
- data/vendor/assets/javascripts/moment/locale/ne.js +123 -0
- data/vendor/assets/javascripts/moment/locale/nl-be.js +88 -0
- data/vendor/assets/javascripts/moment/locale/nl.js +88 -0
- data/vendor/assets/javascripts/moment/locale/nn.js +60 -0
- data/vendor/assets/javascripts/moment/locale/pa-in.js +124 -0
- data/vendor/assets/javascripts/moment/locale/pl.js +107 -0
- data/vendor/assets/javascripts/moment/locale/pt-br.js +61 -0
- data/vendor/assets/javascripts/moment/locale/pt.js +65 -0
- data/vendor/assets/javascripts/moment/locale/ro.js +75 -0
- data/vendor/assets/javascripts/moment/locale/ru.js +183 -0
- data/vendor/assets/javascripts/moment/locale/sd.js +98 -0
- data/vendor/assets/javascripts/moment/locale/se.js +61 -0
- data/vendor/assets/javascripts/moment/locale/si.js +71 -0
- data/vendor/assets/javascripts/moment/locale/sk.js +150 -0
- data/vendor/assets/javascripts/moment/locale/sl.js +162 -0
- data/vendor/assets/javascripts/moment/locale/sq.js +70 -0
- data/vendor/assets/javascripts/moment/locale/sr-cyrl.js +110 -0
- data/vendor/assets/javascripts/moment/locale/sr.js +110 -0
- data/vendor/assets/javascripts/moment/locale/ss.js +89 -0
- data/vendor/assets/javascripts/moment/locale/sv.js +69 -0
- data/vendor/assets/javascripts/moment/locale/sw.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ta.js +130 -0
- data/vendor/assets/javascripts/moment/locale/te.js +89 -0
- data/vendor/assets/javascripts/moment/locale/tet.js +68 -0
- data/vendor/assets/javascripts/moment/locale/th.js +67 -0
- data/vendor/assets/javascripts/moment/locale/tl-ph.js +62 -0
- data/vendor/assets/javascripts/moment/locale/tlh.js +120 -0
- data/vendor/assets/javascripts/moment/locale/tr.js +90 -0
- data/vendor/assets/javascripts/moment/locale/tzl.js +91 -0
- data/vendor/assets/javascripts/moment/locale/tzm-latn.js +58 -0
- data/vendor/assets/javascripts/moment/locale/tzm.js +58 -0
- data/vendor/assets/javascripts/moment/locale/uk.js +151 -0
- data/vendor/assets/javascripts/moment/locale/ur.js +99 -0
- data/vendor/assets/javascripts/moment/locale/uz-latn.js +58 -0
- data/vendor/assets/javascripts/moment/locale/uz.js +58 -0
- data/vendor/assets/javascripts/moment/locale/vi.js +79 -0
- data/vendor/assets/javascripts/moment/locale/x-pseudo.js +68 -0
- data/vendor/assets/javascripts/moment/locale/yo.js +60 -0
- data/vendor/assets/javascripts/moment/locale/zh-cn.js +111 -0
- data/vendor/assets/javascripts/moment/locale/zh-hk.js +105 -0
- data/vendor/assets/javascripts/moment/locale/zh-tw.js +104 -0
- data/vendor/assets/javascripts/moment/min/locales.js +9252 -0
- data/vendor/assets/javascripts/moment/min/moment-with-locales.js +13700 -0
- data/vendor/assets/javascripts/moment/min/moment.min.js +7 -0
- data/vendor/assets/javascripts/moment/min/tests.js +78265 -0
- data/vendor/assets/javascripts/moment/moment.js +4463 -0
- data/vendor/assets/javascripts/moment/src/lib/create/check-overflow.js +34 -0
- data/vendor/assets/javascripts/moment/src/lib/create/date-from-array.js +21 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-anything.js +110 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-array.js +140 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-object.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-string-and-array.js +50 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-string-and-format.js +113 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-string.js +202 -0
- data/vendor/assets/javascripts/moment/src/lib/create/local.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/create/parsing-flags.js +26 -0
- data/vendor/assets/javascripts/moment/src/lib/create/utc.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/create/valid.js +49 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/abs.js +18 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/add-subtract.js +21 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/as.js +61 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/bubble.js +61 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/constructor.js +44 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/create.js +122 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/duration.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/get.js +25 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/humanize.js +85 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/iso-string.js +56 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/prototype.js +50 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/valid.js +35 -0
- data/vendor/assets/javascripts/moment/src/lib/format/format.js +92 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/base-config.js +44 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/calendar.js +15 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/constructor.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/en.js +15 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/formats.js +23 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/invalid.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/lists.js +93 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/locale.js +39 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/locales.js +186 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/ordinal.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/pre-post-format.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/prototype.js +69 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/relative.js +30 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/set.js +49 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/add-subtract.js +55 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/calendar.js +26 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/clone.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/compare.js +59 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/constructor.js +77 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/creation-data.js +9 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/diff.js +62 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/format.js +57 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/from.js +17 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/get-set.js +55 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/locale.js +34 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/min-max.js +63 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/moment.js +28 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/now.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/prototype.js +150 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/start-end-of.js +59 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/to-type.js +34 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/to.js +17 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/valid.js +15 -0
- data/vendor/assets/javascripts/moment/src/lib/parse/regex.js +54 -0
- data/vendor/assets/javascripts/moment/src/lib/parse/token.js +33 -0
- data/vendor/assets/javascripts/moment/src/lib/units/aliases.js +30 -0
- data/vendor/assets/javascripts/moment/src/lib/units/constants.js +9 -0
- data/vendor/assets/javascripts/moment/src/lib/units/day-of-month.js +39 -0
- data/vendor/assets/javascripts/moment/src/lib/units/day-of-week.js +364 -0
- data/vendor/assets/javascripts/moment/src/lib/units/day-of-year.js +36 -0
- data/vendor/assets/javascripts/moment/src/lib/units/hour.js +144 -0
- data/vendor/assets/javascripts/moment/src/lib/units/millisecond.js +69 -0
- data/vendor/assets/javascripts/moment/src/lib/units/minute.js +29 -0
- data/vendor/assets/javascripts/moment/src/lib/units/month.js +283 -0
- data/vendor/assets/javascripts/moment/src/lib/units/offset.js +235 -0
- data/vendor/assets/javascripts/moment/src/lib/units/priorities.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/units/quarter.js +32 -0
- data/vendor/assets/javascripts/moment/src/lib/units/second.js +29 -0
- data/vendor/assets/javascripts/moment/src/lib/units/timestamp.js +20 -0
- data/vendor/assets/javascripts/moment/src/lib/units/timezone.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/units/units.js +20 -0
- data/vendor/assets/javascripts/moment/src/lib/units/week-calendar-utils.js +65 -0
- data/vendor/assets/javascripts/moment/src/lib/units/week-year.js +107 -0
- data/vendor/assets/javascripts/moment/src/lib/units/week.js +67 -0
- data/vendor/assets/javascripts/moment/src/lib/units/year.js +75 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/abs-ceil.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/abs-floor.js +8 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/abs-round.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/compare-arrays.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/defaults.js +10 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/deprecate.js +55 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/extend.js +19 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/has-own-prop.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/hooks.js +13 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/index-of.js +18 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-array.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-date.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-function.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-number.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-object-empty.js +8 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-object.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-undefined.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/keys.js +19 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/map.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/some.js +19 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/to-int.js +12 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/zero-fill.js +7 -0
- data/vendor/assets/javascripts/moment/src/locale/af.js +63 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-dz.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-kw.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-ly.js +112 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-ma.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-sa.js +95 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-tn.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/ar.js +128 -0
- data/vendor/assets/javascripts/moment/src/locale/az.js +96 -0
- data/vendor/assets/javascripts/moment/src/locale/be.js +125 -0
- data/vendor/assets/javascripts/moment/src/locale/bg.js +81 -0
- data/vendor/assets/javascripts/moment/src/locale/bn.js +109 -0
- data/vendor/assets/javascripts/moment/src/locale/bo.js +110 -0
- data/vendor/assets/javascripts/moment/src/locale/br.js +99 -0
- data/vendor/assets/javascripts/moment/src/locale/bs.js +133 -0
- data/vendor/assets/javascripts/moment/src/locale/ca.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/cs.js +163 -0
- data/vendor/assets/javascripts/moment/src/locale/cv.js +53 -0
- data/vendor/assets/javascripts/moment/src/locale/cy.js +72 -0
- data/vendor/assets/javascripts/moment/src/locale/da.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/de-at.js +69 -0
- data/vendor/assets/javascripts/moment/src/locale/de-ch.js +68 -0
- data/vendor/assets/javascripts/moment/src/locale/de.js +68 -0
- data/vendor/assets/javascripts/moment/src/locale/dv.js +89 -0
- data/vendor/assets/javascripts/moment/src/locale/el.js +88 -0
- data/vendor/assets/javascripts/moment/src/locale/en-au.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/en-ca.js +53 -0
- data/vendor/assets/javascripts/moment/src/locale/en-gb.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/en-ie.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/en-nz.js +57 -0
- data/vendor/assets/javascripts/moment/src/locale/eo.js +64 -0
- data/vendor/assets/javascripts/moment/src/locale/es-do.js +73 -0
- data/vendor/assets/javascripts/moment/src/locale/es.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/et.js +71 -0
- data/vendor/assets/javascripts/moment/src/locale/eu.js +57 -0
- data/vendor/assets/javascripts/moment/src/locale/fa.js +97 -0
- data/vendor/assets/javascripts/moment/src/locale/fi.js +98 -0
- data/vendor/assets/javascripts/moment/src/locale/fo.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/fr-ca.js +65 -0
- data/vendor/assets/javascripts/moment/src/locale/fr-ch.js +69 -0
- data/vendor/assets/javascripts/moment/src/locale/fr.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/fy.js +66 -0
- data/vendor/assets/javascripts/moment/src/locale/gd.js +67 -0
- data/vendor/assets/javascripts/moment/src/locale/gl.js +68 -0
- data/vendor/assets/javascripts/moment/src/locale/gom-latn.js +112 -0
- data/vendor/assets/javascripts/moment/src/locale/he.js +90 -0
- data/vendor/assets/javascripts/moment/src/locale/hi.js +115 -0
- data/vendor/assets/javascripts/moment/src/locale/hr.js +135 -0
- data/vendor/assets/javascripts/moment/src/locale/hu.js +100 -0
- data/vendor/assets/javascripts/moment/src/locale/hy-am.js +86 -0
- data/vendor/assets/javascripts/moment/src/locale/id.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/is.js +118 -0
- data/vendor/assets/javascripts/moment/src/locale/it.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/ja.js +71 -0
- data/vendor/assets/javascripts/moment/src/locale/jv.js +73 -0
- data/vendor/assets/javascripts/moment/src/locale/ka.js +80 -0
- data/vendor/assets/javascripts/moment/src/locale/kk.js +77 -0
- data/vendor/assets/javascripts/moment/src/locale/km.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/kn.js +116 -0
- data/vendor/assets/javascripts/moment/src/locale/ko.js +60 -0
- data/vendor/assets/javascripts/moment/src/locale/ky.js +78 -0
- data/vendor/assets/javascripts/moment/src/locale/lb.js +128 -0
- data/vendor/assets/javascripts/moment/src/locale/lo.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/lt.js +108 -0
- data/vendor/assets/javascripts/moment/src/locale/lv.js +88 -0
- data/vendor/assets/javascripts/moment/src/locale/me.js +101 -0
- data/vendor/assets/javascripts/moment/src/locale/mi.js +54 -0
- data/vendor/assets/javascripts/moment/src/locale/mk.js +81 -0
- data/vendor/assets/javascripts/moment/src/locale/ml.js +72 -0
- data/vendor/assets/javascripts/moment/src/locale/mr.js +150 -0
- data/vendor/assets/javascripts/moment/src/locale/ms-my.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/ms.js +73 -0
- data/vendor/assets/javascripts/moment/src/locale/my.js +86 -0
- data/vendor/assets/javascripts/moment/src/locale/nb.js +54 -0
- data/vendor/assets/javascripts/moment/src/locale/ne.js +114 -0
- data/vendor/assets/javascripts/moment/src/locale/nl-be.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/nl.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/nn.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/pa-in.js +115 -0
- data/vendor/assets/javascripts/moment/src/locale/pl.js +97 -0
- data/vendor/assets/javascripts/moment/src/locale/pt-br.js +52 -0
- data/vendor/assets/javascripts/moment/src/locale/pt.js +56 -0
- data/vendor/assets/javascripts/moment/src/locale/ro.js +66 -0
- data/vendor/assets/javascripts/moment/src/locale/ru.js +173 -0
- data/vendor/assets/javascripts/moment/src/locale/sd.js +88 -0
- data/vendor/assets/javascripts/moment/src/locale/se.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/si.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/sk.js +141 -0
- data/vendor/assets/javascripts/moment/src/locale/sl.js +152 -0
- data/vendor/assets/javascripts/moment/src/locale/sq.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/sr-cyrl.js +100 -0
- data/vendor/assets/javascripts/moment/src/locale/sr.js +100 -0
- data/vendor/assets/javascripts/moment/src/locale/ss.js +80 -0
- data/vendor/assets/javascripts/moment/src/locale/sv.js +60 -0
- data/vendor/assets/javascripts/moment/src/locale/sw.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/ta.js +120 -0
- data/vendor/assets/javascripts/moment/src/locale/te.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/tet.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/th.js +57 -0
- data/vendor/assets/javascripts/moment/src/locale/tl-ph.js +53 -0
- data/vendor/assets/javascripts/moment/src/locale/tlh.js +110 -0
- data/vendor/assets/javascripts/moment/src/locale/tr.js +81 -0
- data/vendor/assets/javascripts/moment/src/locale/tzl.js +82 -0
- data/vendor/assets/javascripts/moment/src/locale/tzm-latn.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/tzm.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/uk.js +142 -0
- data/vendor/assets/javascripts/moment/src/locale/ur.js +89 -0
- data/vendor/assets/javascripts/moment/src/locale/uz-latn.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/uz.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/vi.js +70 -0
- data/vendor/assets/javascripts/moment/src/locale/x-pseudo.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/yo.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/zh-cn.js +102 -0
- data/vendor/assets/javascripts/moment/src/locale/zh-hk.js +95 -0
- data/vendor/assets/javascripts/moment/src/locale/zh-tw.js +94 -0
- data/vendor/assets/javascripts/moment/src/moment.js +82 -0
- data/vendor/assets/javascripts/moment/templates/default.js +5 -0
- data/vendor/assets/javascripts/moment/templates/locale-header.js +6 -0
- data/vendor/assets/javascripts/moment/templates/test-header.js +6 -0
- metadata +943 -0
@@ -0,0 +1,278 @@
|
|
1
|
+
module Binnacle
|
2
|
+
class Configuration
|
3
|
+
|
4
|
+
DEFAULT_IGNORED_EXCEPTIONS = [
|
5
|
+
'ActiveRecord::RecordNotFound',
|
6
|
+
'ActionController::RoutingError',
|
7
|
+
'ActionController::InvalidAuthenticityToken',
|
8
|
+
'CGI::Session::CookieStore::TamperedWithCookie',
|
9
|
+
'ActionController::UnknownHttpMethod',
|
10
|
+
'ActionController::UnknownAction',
|
11
|
+
'AbstractController::ActionNotFound',
|
12
|
+
'Mongoid::Errors::DocumentNotFound',
|
13
|
+
'ActionController::UnknownFormat',
|
14
|
+
'Sinatra::NotFound'
|
15
|
+
].map(&:freeze).freeze
|
16
|
+
|
17
|
+
DEFAULT_PORT = '8080'
|
18
|
+
|
19
|
+
DEFAULT_BACKTRACE_FILTERS = [
|
20
|
+
lambda { |line| line.gsub(/^\.\//, "") },
|
21
|
+
lambda { |line|
|
22
|
+
Gem.path.each{ |path| line.sub!(/#{path}/, "[GEM_ROOT]") unless path.to_s.strip.empty? } if defined?(Gem)
|
23
|
+
line
|
24
|
+
},
|
25
|
+
lambda { |line| line if line !~ %r{lib/binnacle} }
|
26
|
+
].freeze
|
27
|
+
|
28
|
+
# The Binnacle Endpoint (BINNACLE_ENDPOINT) single IP or Array of IPs
|
29
|
+
attr_accessor :endpoint
|
30
|
+
|
31
|
+
# The Binnacle Endpoint PORT (BINNACLE_PORT), defaults to 8080 if not encrypted
|
32
|
+
attr_accessor :port
|
33
|
+
|
34
|
+
# The application logger Binnacle Channel (BINNACLE_APP_LOG_CHANNEL)
|
35
|
+
attr_accessor :logging_channel
|
36
|
+
|
37
|
+
# The application error Binnacle Channel (BINNACLE_APP_ERR_CHANNEL)
|
38
|
+
attr_accessor :error_channel
|
39
|
+
|
40
|
+
# An approved publisher API key for the App (BINNACLE_API_KEY)
|
41
|
+
attr_accessor :api_key
|
42
|
+
|
43
|
+
# The API secret for the given API key (BINNACLE_API_SECRET)
|
44
|
+
attr_accessor :api_secret
|
45
|
+
|
46
|
+
# Whether to redirect rails logging to Binnacle (BINNACLE_RAILS_LOG)
|
47
|
+
attr_accessor :intercept_rails_logging
|
48
|
+
|
49
|
+
# Whether to pipe Rails logs as they are (verbose as shit) or just grab action_controller events and single line them (BINNACLE_RAILS_LOG_VERBOSE)
|
50
|
+
attr_accessor :rails_verbose_logging
|
51
|
+
|
52
|
+
# Whether to report exceptions to Binnacle (BINNACLE_REPORT_EXCEPTIONS)
|
53
|
+
attr_accessor :report_exceptions
|
54
|
+
|
55
|
+
# Exceptions that do not get reported to Binnacle (BINNACLE_IGNORED_EXCEPTIONS)
|
56
|
+
attr_accessor :ignored_exceptions
|
57
|
+
|
58
|
+
# Whether to skip reporting exceptions where the headers['X-Cascade'] is set
|
59
|
+
# to 'pass'. In Rails typically it means route was not found (404 error).
|
60
|
+
attr_accessor :ignore_cascade_pass
|
61
|
+
|
62
|
+
# Whether to make the requests over HTTPS, default is HTTPS
|
63
|
+
attr_reader :encrypted
|
64
|
+
|
65
|
+
# Whether to log asynchronoushly via the Ruby logger
|
66
|
+
attr_accessor :asynch_logging
|
67
|
+
|
68
|
+
# Array of Events to skip, e.g. ['home#index', 'webhooks#test']
|
69
|
+
attr_writer :ignore_actions
|
70
|
+
|
71
|
+
# HTTP outgoing logging options
|
72
|
+
attr_accessor :url_whitelist_patterns
|
73
|
+
attr_accessor :url_blacklist_patterns
|
74
|
+
attr_reader :url_whitelist_pattern
|
75
|
+
attr_reader :url_blacklist_pattern
|
76
|
+
|
77
|
+
attr_accessor :log_binnacle_signals
|
78
|
+
|
79
|
+
|
80
|
+
def initialize
|
81
|
+
if ENV['BINNACLE_ENDPOINT']
|
82
|
+
self.endpoint ||= ENV['BINNACLE_ENDPOINT'].include?(',') ? ENV['BINNACLE_ENDPOINT'].split(',') : ENV['BINNACLE_ENDPOINT']
|
83
|
+
else
|
84
|
+
if self.endpoint !~ /[^[:space:]]/
|
85
|
+
self.endpoint = (1..6).to_a.sample(3).map { |n| "api#{n}.binnacle-api.io" }
|
86
|
+
end
|
87
|
+
end
|
88
|
+
|
89
|
+
self.logging_channel ||= ENV['BINNACLE_APP_LOG_CHANNEL']
|
90
|
+
self.error_channel ||= ENV['BINNACLE_APP_ERR_CHANNEL']
|
91
|
+
self.api_key ||= ENV['BINNACLE_API_KEY']
|
92
|
+
self.api_secret ||= ENV['BINNACLE_API_SECRET']
|
93
|
+
self.intercept_rails_logging = Configuration.set_boolean_flag_for(ENV['BINNACLE_RAILS_LOG'])
|
94
|
+
self.rails_verbose_logging = Configuration.set_boolean_flag_for(ENV['BINNACLE_RAILS_LOG_VERBOSE'])
|
95
|
+
self.report_exceptions = Configuration.set_boolean_flag_for(ENV['BINNACLE_REPORT_EXCEPTIONS'])
|
96
|
+
self.ignored_exceptions ||= ENV['BINNACLE_IGNORED_EXCEPTIONS'] ? DEFAULT_IGNORED_EXCEPTIONS + ENV['BINNACLE_IGNORED_EXCEPTIONS'].split(',') : DEFAULT_IGNORED_EXCEPTIONS
|
97
|
+
self.ignore_cascade_pass ||= true
|
98
|
+
self.asynch_logging = Configuration.set_boolean_flag_for(ENV['BINNACLE_RAILS_LOG_ASYNCH'], true)
|
99
|
+
@encrypted = Configuration.set_boolean_flag_for(ENV['BINNACLE_ENCRYPTED'], true)
|
100
|
+
|
101
|
+
self.url_whitelist_patterns ||= ENV['BINNACLE_HTTP_LOGGING_WHITELIST'] ? ENV['BINNACLE_HTTP_LOGGING_WHITELIST'].split(',') : []
|
102
|
+
self.url_blacklist_patterns ||= ENV['BINNACLE_HTTP_LOGGING_BLACKLIST'] ? ENV['BINNACLE_HTTP_LOGGING_BLACKLIST'].split(',') : []
|
103
|
+
@url_whitelist_pattern = /.*/
|
104
|
+
@url_blacklist_pattern = nil
|
105
|
+
|
106
|
+
self.log_binnacle_signals = Configuration.set_boolean_flag_for(ENV['BINNACLE_LOG_SIGNALS'])
|
107
|
+
|
108
|
+
prepare!
|
109
|
+
end
|
110
|
+
|
111
|
+
def prepare!
|
112
|
+
set_default_port
|
113
|
+
set_urls
|
114
|
+
set_blacklist_patterns
|
115
|
+
set_whitelist_patterns
|
116
|
+
end
|
117
|
+
|
118
|
+
def url
|
119
|
+
if @urls
|
120
|
+
@urls.is_a?(Array) ? @urls.sample : @urls
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
124
|
+
def urls
|
125
|
+
@urls
|
126
|
+
end
|
127
|
+
|
128
|
+
def ready?
|
129
|
+
urls? && self.api_key && self.api_secret
|
130
|
+
end
|
131
|
+
|
132
|
+
def urls?
|
133
|
+
(!@urls.nil? && !@urls.is_a?(Array)) || (@urls.is_a?(Array) && !@urls.empty?)
|
134
|
+
end
|
135
|
+
|
136
|
+
def can_setup_logger?
|
137
|
+
!self.logging_channel.nil?
|
138
|
+
end
|
139
|
+
|
140
|
+
def intercept_rails_logging?
|
141
|
+
self.intercept_rails_logging && !self.logging_channel.nil?
|
142
|
+
end
|
143
|
+
|
144
|
+
def rails_verbose_logging?
|
145
|
+
self.rails_verbose_logging
|
146
|
+
end
|
147
|
+
|
148
|
+
def trap?
|
149
|
+
!self.report_exceptions.nil? && !self.error_channel.nil?
|
150
|
+
end
|
151
|
+
|
152
|
+
def ignore_cascade_pass?
|
153
|
+
self.ignore_cascade_pass
|
154
|
+
end
|
155
|
+
|
156
|
+
def encrypted?
|
157
|
+
self.encrypted
|
158
|
+
end
|
159
|
+
|
160
|
+
def build_url(ip_or_host)
|
161
|
+
["#{protocol}://#{ip_or_host}", port].compact.join(":")
|
162
|
+
end
|
163
|
+
|
164
|
+
def protocol
|
165
|
+
self.encrypted? ? 'https' : 'http'
|
166
|
+
end
|
167
|
+
|
168
|
+
def set_urls
|
169
|
+
if self.endpoint && (self.endpoint.is_a?(Array) ? !self.endpoint.empty? : (!self.endpoint !~ /[^[:space:]]/))
|
170
|
+
@urls = self.endpoint.is_a?(Array) ? self.endpoint.map { |ep| build_url(ep) } : build_url(endpoint)
|
171
|
+
end
|
172
|
+
end
|
173
|
+
|
174
|
+
def set_blacklist_patterns
|
175
|
+
blacklist_patterns = []
|
176
|
+
|
177
|
+
# don't log binnacle's posts
|
178
|
+
unless self.log_binnacle_signals
|
179
|
+
if @urls.is_a?(Array)
|
180
|
+
@urls.each do |url|
|
181
|
+
blacklist_patterns << /#{url}/ if url
|
182
|
+
end
|
183
|
+
elsif @urls
|
184
|
+
blacklist_patterns << /#{@urls}/
|
185
|
+
end
|
186
|
+
end
|
187
|
+
|
188
|
+
self.url_blacklist_patterns.each do |pattern|
|
189
|
+
blacklist_patterns << pattern
|
190
|
+
end
|
191
|
+
|
192
|
+
unless blacklist_patterns.empty?
|
193
|
+
@url_blacklist_pattern = Regexp.union(blacklist_patterns)
|
194
|
+
end
|
195
|
+
end
|
196
|
+
|
197
|
+
def set_whitelist_patterns
|
198
|
+
whitelist_patterns = []
|
199
|
+
|
200
|
+
self.url_whitelist_patterns.each do |pattern|
|
201
|
+
whitelist_patterns << pattern
|
202
|
+
end
|
203
|
+
|
204
|
+
unless whitelist_patterns.empty?
|
205
|
+
@whitelist_pattern = Regexp.union(whitelist_patterns)
|
206
|
+
end
|
207
|
+
end
|
208
|
+
|
209
|
+
def endpoint=(value)
|
210
|
+
@endpoint = value
|
211
|
+
set_urls
|
212
|
+
end
|
213
|
+
|
214
|
+
def encrypted=(value)
|
215
|
+
@encrypted = value
|
216
|
+
set_default_port
|
217
|
+
set_urls
|
218
|
+
end
|
219
|
+
|
220
|
+
def to_s
|
221
|
+
[ :endpoint,
|
222
|
+
:logging_channel,
|
223
|
+
:error_channel,
|
224
|
+
:api_key,
|
225
|
+
:api_secret,
|
226
|
+
:intercept_rails_logging,
|
227
|
+
:report_exceptions,
|
228
|
+
:ignore_cascade_pass,
|
229
|
+
:encrypted,
|
230
|
+
:asynch_logging
|
231
|
+
].map { |m| "#{m}: #{self.send(m)}" }.join(', ')
|
232
|
+
end
|
233
|
+
|
234
|
+
def self.set_boolean_flag_for(value, default = false)
|
235
|
+
!value.nil? ? value.downcase == 'true' : default
|
236
|
+
end
|
237
|
+
|
238
|
+
def set_default_port
|
239
|
+
self.port ||= ENV['BINNACLE_PORT'] || (self.encrypted? ? nil : DEFAULT_PORT)
|
240
|
+
end
|
241
|
+
|
242
|
+
# Set conditions for events that should be ignored
|
243
|
+
#
|
244
|
+
# Currently supported formats are:
|
245
|
+
# - A single string representing a controller action, e.g. 'users#sign_in'
|
246
|
+
# - An array of strings representing controller actions
|
247
|
+
# - An object that responds to call with an event argument and returns
|
248
|
+
# true if the event should be ignored.
|
249
|
+
#
|
250
|
+
# The action ignores are given to 'ignore_actions'. The callable ignores
|
251
|
+
# are given to 'ignore'. Both methods can be called multiple times, which
|
252
|
+
# just adds more ignore conditions to a list that is checked before logging.
|
253
|
+
|
254
|
+
def ignore_actions(actions)
|
255
|
+
ignore(lamba do |event|
|
256
|
+
params = event.payload[:params]
|
257
|
+
Array(actions).include?("#{params['controller']}##{params['action']}")
|
258
|
+
end)
|
259
|
+
end
|
260
|
+
|
261
|
+
def ignore_tests
|
262
|
+
@ignore_tests ||= []
|
263
|
+
end
|
264
|
+
|
265
|
+
def ignore(test)
|
266
|
+
ignore_tests.push(test) if test
|
267
|
+
end
|
268
|
+
|
269
|
+
def ignore_nothing
|
270
|
+
@ignore_tests = []
|
271
|
+
end
|
272
|
+
|
273
|
+
def ignore?(event)
|
274
|
+
ignore_tests.any? { |ignore_test| ignore_test.call(event) }
|
275
|
+
end
|
276
|
+
|
277
|
+
end
|
278
|
+
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
require 'forwardable'
|
2
|
+
require 'faraday'
|
3
|
+
require 'uri'
|
4
|
+
|
5
|
+
module Binnacle
|
6
|
+
class Connection
|
7
|
+
extend Forwardable
|
8
|
+
|
9
|
+
attr_reader :connection
|
10
|
+
attr_reader :active_url
|
11
|
+
attr_reader :contact_url
|
12
|
+
|
13
|
+
def_delegators :@connection, :get, :post, :put, :delete, :head, :patch, :options
|
14
|
+
|
15
|
+
def initialize(api_key = nil, api_secret = nil, url = nil)
|
16
|
+
@contact_url = url || Binnacle.configuration.url
|
17
|
+
@active_url = @contact_url
|
18
|
+
@api_key = api_key || Binnacle.configuration.api_key
|
19
|
+
@api_secret = api_secret || Binnacle.configuration.api_secret
|
20
|
+
|
21
|
+
raise Binnacle::ConfigurationError.new("Binnacle URL not provided, set BINNACLE_URL or provide in the constructor") unless @contact_url
|
22
|
+
|
23
|
+
build_connection
|
24
|
+
randomize_endpoint
|
25
|
+
end
|
26
|
+
|
27
|
+
def endpoints
|
28
|
+
begin
|
29
|
+
response = @connection.get do |req|
|
30
|
+
req.url "/api/endpoints"
|
31
|
+
req.headers['Content-Type'] = 'application/json'
|
32
|
+
end
|
33
|
+
|
34
|
+
if response.status == 401
|
35
|
+
Binnacle.binnacle_logger.error("Error communicating with Binnacle (/api/endpoints): #{response.body}")
|
36
|
+
[]
|
37
|
+
else
|
38
|
+
JSON.parse(response.body)
|
39
|
+
end
|
40
|
+
rescue Faraday::Error::ConnectionFailed => cf
|
41
|
+
Binnacle.binnacle_logger.error("Error communicating with Binnacle (/api/endpoints): #{cf.message}")
|
42
|
+
[]
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
def randomize_endpoint
|
47
|
+
fresh_endpoints = endpoints
|
48
|
+
if fresh_endpoints.size > 1
|
49
|
+
Binnacle.configuration.endpoint = fresh_endpoints
|
50
|
+
@active_url = Binnacle.configuration.url
|
51
|
+
build_connection()
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
def build_connection
|
56
|
+
@connection ||= Faraday.new(:url => @active_url) do |faraday|
|
57
|
+
faraday.request :basic_auth, @api_key, @api_secret
|
58
|
+
faraday.request :url_encoded # form-encode POST params
|
59
|
+
#faraday.response :logger # log requests to STDOUT TODO set a client log file
|
60
|
+
faraday.adapter :httpclient
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
end
|
65
|
+
|
66
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
if defined?(Ethon)
|
2
|
+
require 'uri'
|
3
|
+
|
4
|
+
module Ethon
|
5
|
+
class Easy
|
6
|
+
module Http
|
7
|
+
alias_method :orig_http_request, :http_request
|
8
|
+
def http_request(url, action_name, options = {})
|
9
|
+
@binnacle_request_headers = options[:headers]
|
10
|
+
@binnacle_backup_url = url
|
11
|
+
|
12
|
+
@binnacle_action_name = action_name # remember this for compact logging
|
13
|
+
@binnacle_request_headers = options[:headers]
|
14
|
+
@binnacle_request_data = options[:body]
|
15
|
+
|
16
|
+
orig_http_request(url, action_name, options)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
module Operations
|
21
|
+
alias_method :orig_perform, :perform
|
22
|
+
def perform
|
23
|
+
_url = _url || @url || @binnacle_backup_url
|
24
|
+
return orig_perform unless Binnacle::HttpLogger.allow?(_url)
|
25
|
+
|
26
|
+
_response_code = nil
|
27
|
+
bm = Benchmark.realtime do
|
28
|
+
_response_code = orig_perform
|
29
|
+
end
|
30
|
+
|
31
|
+
uri = URI(_url)
|
32
|
+
status = response_headers.scan(/HTTP\/... (\d{3})/).flatten.first
|
33
|
+
encoding = response_headers.scan(/Content-Encoding: (\S+)/).flatten.first
|
34
|
+
content_type = response_headers.scan(/Content-Type: (\S+(; charset=\S+)?)/).flatten.first
|
35
|
+
url_without_query = "#{uri.scheme}://#{uri.host}:#{uri.port}#{uri.path}"
|
36
|
+
|
37
|
+
Binnacle::HttpLogger.signal(url_without_query, @binnacle_action_name, uri.host, uri.port, uri.path, uri.query, response_code, bm, @binnacle_request_headers, response_body, encoding, content_type, @binnacle_request_data)
|
38
|
+
|
39
|
+
return_code
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
if defined?(Excon)
|
2
|
+
module Excon
|
3
|
+
|
4
|
+
class Connection
|
5
|
+
|
6
|
+
def _httplog_url(datum)
|
7
|
+
"#{datum[:scheme]}://#{datum[:host]}:#{datum[:port]}#{datum[:path]}#{datum[:query]}"
|
8
|
+
end
|
9
|
+
|
10
|
+
alias_method :orig_request, :request
|
11
|
+
def request(params, &block)
|
12
|
+
datum = @data.merge(params)
|
13
|
+
url = _httplog_url(datum)
|
14
|
+
|
15
|
+
return orig_request(params, &block) unless Binnacle::HttpLogger.allow?(url)
|
16
|
+
|
17
|
+
result = nil
|
18
|
+
@binnacle_bm = Benchmark.realtime do
|
19
|
+
result = orig_request(params, &block)
|
20
|
+
end
|
21
|
+
|
22
|
+
datum[:headers] = @data[:headers].merge(datum[:headers] || {})
|
23
|
+
|
24
|
+
if Binnacle::HttpLogger.allow?(url)
|
25
|
+
@binnacle_method = datum[:method]
|
26
|
+
end
|
27
|
+
result
|
28
|
+
end
|
29
|
+
|
30
|
+
alias_method :orig_request_call, :request_call
|
31
|
+
def request_call(datum)
|
32
|
+
url = _httplog_url(datum)
|
33
|
+
|
34
|
+
if Binnacle::HttpLogger.allow?(url)
|
35
|
+
@binnacle_headers = datum[:headers]
|
36
|
+
@binnacle_data = datum[:body] # if datum[:method] == :post
|
37
|
+
@binnacle_method = datum[:method]
|
38
|
+
end
|
39
|
+
orig_request_call(datum)
|
40
|
+
end
|
41
|
+
|
42
|
+
alias_method :orig_response, :response
|
43
|
+
def response(datum={})
|
44
|
+
url = _httplog_url(datum)
|
45
|
+
return orig_response(datum) unless Binnacle::HttpLogger.allow?(url)
|
46
|
+
|
47
|
+
uri = URI(url)
|
48
|
+
url_without_query = "#{uri.scheme}://#{uri.host}:#{uri.port}#{uri.path}"
|
49
|
+
|
50
|
+
bm = Benchmark.realtime do
|
51
|
+
datum = orig_response(datum)
|
52
|
+
end
|
53
|
+
response = datum[:response]
|
54
|
+
headers = response[:headers] || {}
|
55
|
+
|
56
|
+
Binnacle::HttpLogger.signal(url_without_query, @binnacle_method, datum[:host], datum[:port], uri.path, uri.query, response[:status], @binnacle_bm, @binnacle_headers, response[:body], headers['Content-Encoding'], headers['Content-Type'], @binnacle_data)
|
57
|
+
|
58
|
+
datum
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|