faraday-diario_de_bordo 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: f0fc0b4a7ba8ef982faaedacdf981e1c81ed658f
4
+ data.tar.gz: a30d034cd3514791352460cfec7afd88052808e5
5
+ SHA512:
6
+ metadata.gz: 7da65dfe1b6103b91cb1fe6dca068d292991f7f95f2813286b8bfda8a95d3304dbe306ef7483742eee97918c694bbd73a19cd41e440daf183e62a17b79951cce
7
+ data.tar.gz: 5caad7cc2b2fdccbe883227cb857dba22d34c0b0a1ba1431817b006adb227ea9f0510587e2c203d0cd2e1f936f278e3b7756a03314973c93900163713b1741f9
data/.gitignore ADDED
@@ -0,0 +1,9 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
data/Gemfile ADDED
@@ -0,0 +1,5 @@
1
+ source 'https://rubygems.org'
2
+
3
+ gemspec
4
+
5
+ gem 'diario_de_bordo', git: 'git@github.com:Bidu/diario_de_bordo.git', tag: '0.1.3'
data/README.md ADDED
@@ -0,0 +1,53 @@
1
+ # Faraday::DiarioDeBordo
2
+
3
+ Middleware to save faraday request logs using the [diario_de_bordo](https://github.com/bidu/diario_de_bordo) gem.
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ ```ruby
10
+ gem 'faraday-diario_de_bordo'
11
+ ```
12
+
13
+ And then execute:
14
+
15
+ $ bundle
16
+
17
+ Or install it yourself as:
18
+
19
+ $ gem install faraday-diario_de_bordo
20
+
21
+ ## Usage
22
+
23
+ 1: Create a connection with diario_de_bordo. Instructions in diario_de_bordo's [README](https://github.com/bidu/diario_de_bordo/README.md).
24
+
25
+ 2: Add middleware to your Faraday connection:
26
+
27
+ ```ruby
28
+ Faraday.new do |faraday|
29
+ faraday.response :diario_de_bordo
30
+ end
31
+ ```
32
+
33
+ 3: Send informations through your request headers:
34
+
35
+ ```ruby
36
+ connection = Faraday.new do |faraday|
37
+ faraday.response :diario_de_bordo
38
+ end
39
+
40
+ connection.post(YOUR_ENDPOINT) do |request|
41
+ request.headers.merge(susep: 1234, template: 'path_to_your_template', external_id: 583723)
42
+ end
43
+ ```
44
+
45
+ ## Development
46
+
47
+ After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake false` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
48
+
49
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags.
50
+
51
+ ## Contributing
52
+
53
+ Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/faraday-diario_de_bordo.
data/Rakefile ADDED
@@ -0,0 +1 @@
1
+ require "bundler/gem_tasks"
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "faraday/diario_de_bordo"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
data/bin/setup ADDED
@@ -0,0 +1,7 @@
1
+ #!/bin/bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+
5
+ bundle install
6
+
7
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,25 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'faraday/diario_de_bordo/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = 'faraday-diario_de_bordo'
8
+ spec.version = Faraday::DiarioDeBordo::VERSION
9
+ spec.authors = ['Bidu Dev Team', 'Jaya Dev Team']
10
+ spec.email = ['dev@bidu.com.br', 'bidu@jaya-apps.com.br']
11
+
12
+ spec.summary = 'Middleware between faraday and diario de bordo'
13
+ spec.description = 'Middleware to save logs for faraday requests'
14
+ spec.homepage = 'https://github.com/Bidu/faraday-diario_de_bordo'
15
+
16
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
17
+ spec.bindir = "exe"
18
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
19
+ spec.require_paths = ['lib']
20
+
21
+ spec.add_development_dependency 'bundler'
22
+ spec.add_development_dependency 'rake', '~> 10.0'
23
+
24
+ spec.add_dependency 'faraday', '~> 0.9'
25
+ end
@@ -0,0 +1,6 @@
1
+ module Faraday
2
+ module DiarioDeBordo
3
+ require 'faraday/diario_de_bordo/version'
4
+ require 'faraday/diario_de_bordo/middleware'
5
+ end
6
+ end
@@ -0,0 +1,75 @@
1
+ require 'faraday'
2
+
3
+ module Faraday
4
+ class DiarioDeBordo::Middleware < Response::Middleware
5
+ DEFAULT_OPTIONS = { bodies: true }
6
+
7
+ attr_reader :logger, :options, :request_body, :response_body, :started_at, :ended_at
8
+
9
+ def initialize(app, logger = nil, options = {})
10
+ super(app)
11
+ @logger = logger || begin
12
+ require 'diario_de_bordo'
13
+ ::DiarioDeBordo::Loggers::Database
14
+ end
15
+ @options = DEFAULT_OPTIONS.merge(options)
16
+ end
17
+
18
+ def call(env)
19
+ @request_body = dump_body(env[:body]) if env[:body] && log_body?(:request)
20
+ @started_at = Time.now
21
+ super
22
+ end
23
+
24
+ def on_complete(env)
25
+ @ended_at = Time.now
26
+ @response_body = dump_body(env[:body]) if env[:body] && log_body?(:response)
27
+ logger.log(response_log(env))
28
+ end
29
+
30
+ private
31
+
32
+ def duration
33
+ (ended_at - started_at)
34
+ end
35
+
36
+ def response_log(env)
37
+ {
38
+ request: request_body,
39
+ response: response_body,
40
+ susep: env.request_headers.delete('susep'),
41
+ method: env.request_headers.delete('template'),
42
+ external_id: env.request_headers.delete('external_id'),
43
+ status_code: env.status,
44
+ duration: duration,
45
+ created_at: Time.now
46
+ }
47
+ end
48
+
49
+ def dump_headers(headers)
50
+ headers.map { |k, v| "#{k}: #{v.inspect}" }.join("\n")
51
+ end
52
+
53
+ def dump_body(body)
54
+ if body.respond_to?(:to_str)
55
+ body.to_str
56
+ else
57
+ pretty_inspect(body)
58
+ end
59
+ end
60
+
61
+ def pretty_inspect(body)
62
+ require 'pp' unless body.respond_to?(:pretty_inspect)
63
+ body.pretty_inspect
64
+ end
65
+
66
+ def log_body?(type)
67
+ case options[:bodies]
68
+ when Hash then options[:bodies][type]
69
+ else options[:bodies]
70
+ end
71
+ end
72
+ end
73
+ end
74
+
75
+ Faraday::Response.register_middleware(diario_de_bordo: Faraday::DiarioDeBordo::Middleware)
@@ -0,0 +1,5 @@
1
+ module Faraday
2
+ module DiarioDeBordo
3
+ VERSION = '0.1.0'.freeze
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,97 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: faraday-diario_de_bordo
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Bidu Dev Team
8
+ - Jaya Dev Team
9
+ autorequire:
10
+ bindir: exe
11
+ cert_chain: []
12
+ date: 2016-05-09 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: bundler
16
+ requirement: !ruby/object:Gem::Requirement
17
+ requirements:
18
+ - - ">="
19
+ - !ruby/object:Gem::Version
20
+ version: '0'
21
+ type: :development
22
+ prerelease: false
23
+ version_requirements: !ruby/object:Gem::Requirement
24
+ requirements:
25
+ - - ">="
26
+ - !ruby/object:Gem::Version
27
+ version: '0'
28
+ - !ruby/object:Gem::Dependency
29
+ name: rake
30
+ requirement: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - "~>"
33
+ - !ruby/object:Gem::Version
34
+ version: '10.0'
35
+ type: :development
36
+ prerelease: false
37
+ version_requirements: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - "~>"
40
+ - !ruby/object:Gem::Version
41
+ version: '10.0'
42
+ - !ruby/object:Gem::Dependency
43
+ name: faraday
44
+ requirement: !ruby/object:Gem::Requirement
45
+ requirements:
46
+ - - "~>"
47
+ - !ruby/object:Gem::Version
48
+ version: '0.9'
49
+ type: :runtime
50
+ prerelease: false
51
+ version_requirements: !ruby/object:Gem::Requirement
52
+ requirements:
53
+ - - "~>"
54
+ - !ruby/object:Gem::Version
55
+ version: '0.9'
56
+ description: Middleware to save logs for faraday requests
57
+ email:
58
+ - dev@bidu.com.br
59
+ - bidu@jaya-apps.com.br
60
+ executables: []
61
+ extensions: []
62
+ extra_rdoc_files: []
63
+ files:
64
+ - ".gitignore"
65
+ - Gemfile
66
+ - README.md
67
+ - Rakefile
68
+ - bin/console
69
+ - bin/setup
70
+ - faraday-diario_de_bordo.gemspec
71
+ - lib/faraday/diario_de_bordo.rb
72
+ - lib/faraday/diario_de_bordo/middleware.rb
73
+ - lib/faraday/diario_de_bordo/version.rb
74
+ homepage: https://github.com/Bidu/faraday-diario_de_bordo
75
+ licenses: []
76
+ metadata: {}
77
+ post_install_message:
78
+ rdoc_options: []
79
+ require_paths:
80
+ - lib
81
+ required_ruby_version: !ruby/object:Gem::Requirement
82
+ requirements:
83
+ - - ">="
84
+ - !ruby/object:Gem::Version
85
+ version: '0'
86
+ required_rubygems_version: !ruby/object:Gem::Requirement
87
+ requirements:
88
+ - - ">="
89
+ - !ruby/object:Gem::Version
90
+ version: '0'
91
+ requirements: []
92
+ rubyforge_project:
93
+ rubygems_version: 2.4.5.1
94
+ signing_key:
95
+ specification_version: 4
96
+ summary: Middleware between faraday and diario de bordo
97
+ test_files: []