pagarme 1.10.0 → 2.0.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.
@@ -19,7 +19,6 @@ module PagarMe
19
19
  @@api_key = nil
20
20
  @@api_endpoint = 'https://api.pagar.me/1'
21
21
  @@live = true
22
- @@api_card_encryption_public_key = File.join(File.dirname(__FILE__), '..', 'certs/public_key.pem')
23
22
 
24
23
  def self.api_endpoint=(api_endpoint)
25
24
  @@api_endpoint = api_endpoint
@@ -37,10 +36,6 @@ module PagarMe
37
36
  @@api_key
38
37
  end
39
38
 
40
- def self.api_card_encryption_public_key
41
- @@api_card_encryption_public_key
42
- end
43
-
44
39
  def self.full_api_url(relative_path)
45
40
  "#{@@api_endpoint}#{relative_path}"
46
41
  end
@@ -13,12 +13,14 @@ module PagarMe
13
13
  self.errors = []
14
14
  end
15
15
 
16
- def self.initFromServerResponse(response = {})
16
+ def self.fromServerResponse(response = {})
17
17
  object = self.new
18
+
18
19
  response['errors'].map do |error|
19
20
  object.message += error['message'] + ', '
20
21
  object.errors << PagarMeError.new(error['message'], error['parameter_name'], error['type'], response['url'])
21
22
  end
23
+
22
24
  object
23
25
  end
24
26
 
@@ -36,3 +38,4 @@ module PagarMe
36
38
  class ResponseError < PagarMeError
37
39
  end
38
40
  end
41
+
@@ -2,134 +2,132 @@
2
2
  require 'set'
3
3
 
4
4
  module PagarMe
5
- class PagarMeObject
6
-
7
- def initialize(response = {})
8
- #init @attributes - which are the attributes in the object
9
- @attributes = {}
10
-
11
- # Values that were changed in the object but weren't saved
12
- @unsaved_values = Set.new
13
-
14
- # Methods that already existed
15
- @@existing_methods = Array.new
16
-
17
- #Update object
18
- update(response)
19
- end
20
-
21
- def self.build(attributes)
22
- object = self.new(attributes)
23
- return object
24
- end
25
-
26
- def update(attributes)
27
-
28
- removed = Set.new(@attributes.keys - attributes.keys)
29
- added = Set.new(attributes.keys - @attributes.keys)
30
-
31
- instance_eval do
32
- remove_attribute(removed)
33
- add_attribute(added)
34
- end
35
-
36
- removed.each do |key|
37
- @attributes.delete(key)
38
- @unsaved_values.delete(key)
39
- end
40
-
41
- attributes.each do |key, value|
42
- @attributes[key] = Util.convert_to_pagarme_object(value)
43
- @unsaved_values.delete(key)
44
- end
45
- end
46
-
47
- def each(&block)
48
- @attributes.each(&block)
49
- end
50
-
51
- def []=(key,value)
52
- @attributes[key] = value
53
- end
54
-
55
- def [](key)
56
- @attributes[key.to_sym]
57
- end
58
-
59
- def unsaved_values
60
- values = {}
61
- @unsaved_values.each do |k|
62
- if(@attributes[k].kind_of?(PagarMeObject))
63
- values[k] = @attributes[k].unsaved_values
64
- else
65
- values[k] = @attributes[k]
66
- end
67
- end
68
- values
69
- end
70
-
71
- def to_hash
72
- ret_attributes = {}
73
- @attributes.each do |k,v|
74
- if @attributes[k].kind_of?(PagarMeObject)
75
- ret_attributes[k] = @attributes[k].to_hash if @attributes[k].kind_of?(PagarMeObject)
76
- else
77
- ret_attributes[k] = @attributes[k]
78
- end
79
- end
80
- return ret_attributes
81
- end
82
-
83
- protected
84
-
85
- def metaclass
86
- class << self; self; end
87
- end
88
-
89
- def remove_attribute(keys)
90
- metaclass.instance_eval do
91
- keys.each do |key|
92
- key_sym = :"#{key}="
93
- if !@@existing_methods.include?(key)
94
- remove_method(key) if method_defined?(key)
95
- end
96
- remove_method(key_sym) if method_defined?(key_sym)
97
- end
98
- end
99
- end
100
-
101
- def add_attribute(keys)
102
- metaclass.instance_eval do
103
- keys.each do |key|
104
- key_set = "#{key}="
105
- if method_defined?(key)
106
- @@existing_methods.push(key)
107
- else
108
- define_method(key) { @attributes[key] }
109
- end
110
- define_method(key_set) do |value|
111
- @attributes[key] = value
112
- @unsaved_values.add(key)
113
- end
114
- end
115
- end
116
- end
117
-
118
- def method_missing(name, *args)
119
- if name.to_s.end_with?('=')
120
- attr = name.to_s[0...-1].to_sym
121
- add_attribute([attr])
122
- begin
123
- mth = method(name)
124
- rescue NameError
125
- raise NoMethodError.new("O atributo #{name} nao e permitido.")
126
- end
127
- return mth.call(args[0])
128
- else
129
- if @attributes.has_key?(name)
130
- return @attributes[name]
131
- end
132
- end
133
- end
134
- end
5
+ class PagarMeObject
6
+ def initialize(response = {})
7
+ #init @attributes - which are the attributes in the object
8
+ @attributes = {}
9
+
10
+ # Values that were changed in the object but weren't saved
11
+ @unsaved_values = Set.new
12
+
13
+ # Methods that already existed
14
+ @@existing_methods = Array.new
15
+
16
+ #Update object
17
+ update(response)
18
+ end
19
+
20
+ def self.build(attributes)
21
+ self.new(attributes)
22
+ end
23
+
24
+ def update(attributes)
25
+ removed = Set.new(@attributes.keys - attributes.keys)
26
+ added = Set.new(attributes.keys - @attributes.keys)
27
+
28
+ instance_eval do
29
+ remove_attribute(removed)
30
+ add_attribute(added)
31
+ end
32
+
33
+ removed.each do |key|
34
+ @attributes.delete(key)
35
+ @unsaved_values.delete(key)
36
+ end
37
+
38
+ attributes.each do |key, value|
39
+ @attributes[key] = Util.convert_to_pagarme_object(value)
40
+ @unsaved_values.delete(key)
41
+ end
42
+ end
43
+
44
+ def each(&block)
45
+ @attributes.each(&block)
46
+ end
47
+
48
+ def []=(key,value)
49
+ @attributes[key] = value
50
+ end
51
+
52
+ def [](key)
53
+ @attributes[key.to_sym]
54
+ end
55
+
56
+ def to_hash_value(value, type)
57
+ case value
58
+ when PagarMeObject
59
+ value.send type
60
+ when Array
61
+ value.map do |v|
62
+ to_hash_value v, type
63
+ end
64
+ else
65
+ value
66
+ end
67
+ end
68
+
69
+ def unsaved_values
70
+ Hash[@unsaved_values.map { |k| [k, to_hash_value(@attributes[k], 'unsaved_values')] }]
71
+ end
72
+
73
+ def to_hash
74
+ Hash[@attributes.map { |k, v| [k, to_hash_value(v, 'to_hash')] }]
75
+ end
76
+
77
+ protected
78
+
79
+ def metaclass
80
+ class << self; self; end
81
+ end
82
+
83
+ def remove_attribute(keys)
84
+ metaclass.instance_eval do
85
+ keys.each do |key|
86
+ key_sym = :"#{key}="
87
+
88
+ if !@@existing_methods.include?(key)
89
+ remove_method(key) if method_defined?(key)
90
+ end
91
+
92
+ remove_method(key_sym) if method_defined?(key_sym)
93
+ end
94
+ end
95
+ end
96
+
97
+ def add_attribute(keys)
98
+ metaclass.instance_eval do
99
+ keys.each do |key|
100
+ key_set = "#{key}="
101
+
102
+ if method_defined?(key)
103
+ @@existing_methods.push(key)
104
+ else
105
+ define_method(key) { @attributes[key] }
106
+ end
107
+
108
+ define_method(key_set) do |value|
109
+ @attributes[key] = value
110
+ @unsaved_values.add(key)
111
+ end
112
+ end
113
+ end
114
+ end
115
+
116
+ def method_missing(name, *args)
117
+ if name.to_s.end_with?('=')
118
+ attr = name.to_s[0...-1].to_sym
119
+ add_attribute([attr])
120
+
121
+ begin
122
+ m = method(name)
123
+ rescue NameError
124
+ raise NoMethodError.new("O atributo #{name} nao e permitido.")
125
+ end
126
+
127
+ m.call *args
128
+ else
129
+ @attributes[name] if @attributes.has_key?(name)
130
+ end
131
+ end
132
+ end
135
133
  end
@@ -5,75 +5,48 @@ require File.join(File.dirname(__FILE__), '.', 'util')
5
5
  require File.join(File.dirname(__FILE__), '.', 'errors')
6
6
 
7
7
  module PagarMe
8
- class Request
9
- attr_accessor :path, :method, :parameters, :headers
10
-
11
- def initialize(path, method)
12
- self.path = path
13
- self.method = method
14
- self.parameters = {}
15
- self.headers = {}
16
- end
17
-
18
- def self.encode(params)
19
- Util.normalize_params(params).to_params
20
- end
21
-
22
- def run
23
- unless PagarMe.api_key
24
- raise PagarMeError.new("You need to configure a API key before performing requests.")
25
- end
26
-
27
- self.headers = {}
28
-
29
- parameters = self.parameters.merge({
30
- :api_key => PagarMe.api_key
31
- })
32
- error = nil
33
- # puts parameters.inspect
34
-
35
- begin
36
- response = RestClient::Request.execute({
37
- :method => self.method,
38
- :url => PagarMe.full_api_url(self.path),
39
- :headers => self.headers,
40
- :open_timeout => 30,
41
- :payload => self.class.encode(parameters),
42
- :timeout => 90
43
- })
44
- rescue SocketError => e
45
- error = "Error connecting to server (#{e.message})."
46
- rescue NoMethodError => e
47
- if e.message =~ /\WRequestFailed\W/
48
- raise ResponseError.new("Unexpected response code (#{e.inspect}).")
49
- else
50
- raise
51
- end
52
- rescue RestClient::ExceptionWithResponse => e
53
- parsed_error = parse_json_response(e.http_body)
54
- if parsed_error['errors']
55
- error = parsed_error
56
- raise PagarMeError.initFromServerResponse(error)
57
- else
58
- raise PagarMeError.new(e.http_body)
59
- end
60
- rescue RestClient::Exception, Errno::ECONNREFUSED => e
61
- error = "Error connecting to server: connection refused"
62
- end
63
-
64
- raise ConnectionError.new(error) if error
65
-
66
- parse_json_response(response.body)
67
- end
68
-
69
- private
70
-
71
- def parse_json_response(response)
72
- begin
73
- MultiJson.load(response)
74
- rescue MultiJson::LoadError => e
75
- raise PagarMeError.new("Server response is not a valid JSON.")
76
- end
77
- end
78
- end
8
+ class Request
9
+ attr_accessor :path, :method, :parameters, :headers, :query
10
+
11
+ def initialize(path, method)
12
+ self.path = path
13
+ self.method = method
14
+ self.parameters = {}
15
+ self.query = {}
16
+ self.headers = {}
17
+ end
18
+
19
+ def run
20
+ raise PagarMeError, "You need to configure a API key before performing requests." unless PagarMe.api_key
21
+
22
+ begin
23
+ response = RestClient::Request.execute({
24
+ :method => self.method,
25
+ :user => PagarMe.api_key,
26
+ :password => 'x',
27
+ :url => PagarMe.full_api_url(self.path) + '?' + URI.encode_www_form(query),
28
+ :payload => MultiJson.encode(parameters),
29
+ :open_timeout => 30,
30
+ :timeout => 90,
31
+ :ssl_ca_file => File.join(File.dirname(__FILE__), '..', '..', 'certs', 'cabundle.pem'),
32
+ :headers => {
33
+ 'Content-Type' => 'application/json; charset=utf8',
34
+ 'Accept' => 'application/json',
35
+ 'User-Agent' => 'pagarme-ruby/1.0'
36
+ }
37
+ })
38
+ rescue RestClient::ExceptionWithResponse => e
39
+ parsed_error = MultiJson.decode(e.http_body)
40
+
41
+ if parsed_error['errors']
42
+ raise PagarMeError.fromServerResponse(parsed_error)
43
+ else
44
+ raise PagarMeError.new(e.http_body)
45
+ end
46
+ end
47
+
48
+ MultiJson.decode response.body
49
+ end
50
+ end
79
51
  end
52
+
@@ -4,30 +4,30 @@ require 'base64'
4
4
  require File.join(File.dirname(__FILE__), '..', 'pagarme')
5
5
 
6
6
  module PagarMe
7
- class Transaction < TransactionCommon
8
- def self.calculate_installments(params)
9
- request = PagarMe::Request.new('/transactions/calculate_installments_amount', 'GET')
10
- request.parameters.merge!(params)
11
- response = request.run
12
- response
13
- end
7
+ class Transaction < TransactionCommon
8
+ def self.calculate_installments(params)
9
+ request = PagarMe::Request.new('/transactions/calculate_installments_amount', 'GET')
10
+ request.query.merge!(params)
11
+ response = request.run
12
+ response
13
+ end
14
14
 
15
- def charge
16
- create
17
- end
15
+ def charge
16
+ create
17
+ end
18
18
 
19
- def capture(params={})
20
- request = PagarMe::Request.new(self.url + '/capture', 'POST')
21
- request.parameters.merge!(params)
22
- response = request.run
23
- update(response)
24
- end
19
+ def capture(params={})
20
+ request = PagarMe::Request.new(self.url + '/capture', 'POST')
21
+ request.parameters.merge!(params)
22
+ response = request.run
23
+ update(response)
24
+ end
25
25
 
26
- def refund(params={})
27
- request = PagarMe::Request.new(self.url + '/refund', 'POST')
28
- request.parameters.merge!(params)
29
- response = request.run
30
- update(response)
31
- end
32
- end
26
+ def refund(params={})
27
+ request = PagarMe::Request.new(self.url + '/refund', 'POST')
28
+ request.parameters.merge!(params)
29
+ response = request.run
30
+ update(response)
31
+ end
32
+ end
33
33
  end