-
Notifications
You must be signed in to change notification settings - Fork 154
/
call_response.rb
119 lines (115 loc) · 3.6 KB
/
call_response.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
# = Informations
#
# == License
#
# Ekylibre - Simple agricultural ERP
# Copyright (C) 2008-2009 Brice Texier, Thibaud Merigon
# Copyright (C) 2010-2012 Brice Texier
# Copyright (C) 2012-2017 Brice Texier, David Joulin
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see http://www.gnu.org/licenses.
#
# == Table: call_messages
#
# body :text
# call_id :integer
# created_at :datetime not null
# creator_id :integer
# format :string
# headers :text
# id :integer not null, primary key
# ip_address :string
# lock_version :integer default(0), not null
# nature :string not null
# request_id :integer
# ssl :string
# status :string
# type :string
# updated_at :datetime not null
# updater_id :integer
# url :string
# verb :string
#
# Represents a Response in DB.
class CallResponse < CallMessage
belongs_to :request, class_name: 'CallRequest'
delegate :verb, :ip_address, :url, to: :request
# Create a CallResponse from an ActionResponse
def self.create_from_response!(response, request)
r = new(
nature: :outgoing, # Because we come from a controller here.
status: response.status,
headers: response.headers,
body: response.body,
format: response.content_type,
request: request
)
r.save!
r
rescue ActiveRecord::RecordInvalid => e
raise e unless r.errors.messages[:body].present?
create!(
nature: :outgoing, # Because we come from a controller here.
status: response.status,
headers: response.headers,
body: 'Body too long to be saved.',
format: response.content_type,
request: request
)
end
def self.create_from_net_response!(response, request)
r = new(
nature: :incoming, # Because we are receiving an answer.
status: response.code,
headers: response.to_hash,
body: response.body,
format: response.content_type,
request: request
)
r.save!
r
rescue ActiveRecord::RecordInvalid => e
raise e unless r.errors.messages[:body].present?
create!(
nature: :incoming, # Because we are receiving an answer.
status: response.code,
headers: response.to_hash,
body: 'Body too long to be saved.',
format: response.content_type,
request: request
)
end
def self.create_from_savon_httpi_response!(response, request)
r = new(
nature: :incoming, # Receiving an answer in protocol.
status: response.code,
headers: response.headers,
body: response.raw_body,
format: response.headers['Content-Type'].split(';').first,
request: request
)
r.save!
r
rescue ActiveRecord::RecordInvalid => e
raise e unless r.errors.messages[:body].present?
create!(
nature: :incoming, # Receiving an answer in protocol.
status: response.code,
headers: response.headers,
body: 'Body too long to be saved.',
format: response.headers['content-type'].split(';').first,
request: request
)
end
end