opensips-mi 0.0.2 → 0.0.3
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 +8 -8
- data/README.md +3 -0
- data/lib/opensips/mi/command.rb +16 -5
- data/lib/opensips/mi/transport/datagram.rb +1 -8
- data/lib/opensips/mi/transport/xmlrpc.rb +3 -10
- data/lib/opensips/mi/version.rb +1 -1
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,15 +1,15 @@
|
|
1
1
|
---
|
2
2
|
!binary "U0hBMQ==":
|
3
3
|
metadata.gz: !binary |-
|
4
|
-
|
4
|
+
ZThhYmE0OGQxNWQ4ZTg2MGI0OWU3YTA2NmE1MjllZDJmYjU0YjIyYQ==
|
5
5
|
data.tar.gz: !binary |-
|
6
|
-
|
6
|
+
MTQ4ZTAyYzViMWE2OGI3YmYzMTRhN2Y4Y2RhYWE3YWFmOTczMTc5Yw==
|
7
7
|
!binary "U0hBNTEy":
|
8
8
|
metadata.gz: !binary |-
|
9
|
-
|
10
|
-
|
11
|
-
|
9
|
+
YWJmODcxMzQyNWM4MmEwNmYzOTkwYzg0MGI3NTJjY2JkZmE5MzZlYjA3OTNi
|
10
|
+
NmU1YWI0Yjg0NmNlZDI1MmM4NDRjODFhNTRjNTExZDRmYTA0NmEwYjc3YzRi
|
11
|
+
MjljMDJkOWJiZTJlZWI3MzMzYjY1ZTc3NDNlNTk5MjUzYmE2YjM=
|
12
12
|
data.tar.gz: !binary |-
|
13
|
-
|
14
|
-
|
15
|
-
|
13
|
+
ZjUwNzE0ZTU2ODJjMTgwMTQ3NzgwZjgyODM5NjA3MWU4MjZjMjUyZGU4MjBk
|
14
|
+
ZmFlYjZkYmRkMjFkYTdhYmE4YWJmYzYzMzMyNGZhOTE1ZmMzYTllNDgzNzBl
|
15
|
+
YTc5MGY4MmIyZTlhNGVmNGU1NzhlZWE0M2VkYjI5ZDY2ZTkyNDg=
|
data/README.md
CHANGED
@@ -1,4 +1,7 @@
|
|
1
1
|
# Opensips::Mi
|
2
|
+
[](https://travis-ci.org/staskobzar/opensips-mi)
|
3
|
+
[](https://codeclimate.com/github/staskobzar/opensips-mi)
|
4
|
+
[](http://badge.fury.io/rb/opensips-mi)
|
2
5
|
|
3
6
|
OpenSIPs management interface library.
|
4
7
|
This library supports following management interfaces OpenSIPs modules:
|
data/lib/opensips/mi/command.rb
CHANGED
@@ -87,10 +87,8 @@ module Opensips
|
|
87
87
|
headers = hf.map{|name,val| name.eql?("nl") ? "" : "#{name}: #{val}"}.join "\r\n"
|
88
88
|
headers << "\r\n"
|
89
89
|
|
90
|
-
# hack for xmlrpc which fails if headers are quoted
|
91
|
-
|
92
|
-
#params = [method, ruri, next_hop, socket, "\"#{headers}\""]
|
93
|
-
params = [method, ruri, next_hop, socket, headers]
|
90
|
+
# set_header is a hack for xmlrpc which fails if headers are quoted
|
91
|
+
params = [method, ruri, next_hop, socket, set_header(headers)]
|
94
92
|
params << body unless body.nil?
|
95
93
|
# send it and return Response
|
96
94
|
command 't_uac_dlg', params
|
@@ -160,7 +158,20 @@ module Opensips
|
|
160
158
|
uac_dlg "NOTIFY", uri, hf.merge(mbody)
|
161
159
|
end
|
162
160
|
|
163
|
-
|
161
|
+
private
|
162
|
+
def set_header(header);"\"#{header}\"";end
|
163
|
+
|
164
|
+
def host_valid? params
|
165
|
+
raise ArgumentError,
|
166
|
+
'Missing socket host' if params[:host].nil?
|
167
|
+
raise ArgumentError,
|
168
|
+
'Missing socket port' if params[:port].nil?
|
169
|
+
Socket.getaddrinfo(params[:host], nil) rescue
|
170
|
+
raise SocketError, "Invalid host #{params[:host]}"
|
171
|
+
raise SocketError,
|
172
|
+
"Invalid port #{params[:port]}" unless (1..(2**16-1)).include?(params[:port])
|
173
|
+
true
|
174
|
+
end
|
164
175
|
|
165
176
|
end
|
166
177
|
end
|
@@ -11,14 +11,7 @@ module Opensips
|
|
11
11
|
end
|
12
12
|
|
13
13
|
def initialize(params)
|
14
|
-
|
15
|
-
'Missing socket host' if params[:host].nil?
|
16
|
-
raise ArgumentError,
|
17
|
-
'Missing socket port' if params[:port].nil?
|
18
|
-
Socket.getaddrinfo(params[:host], nil) rescue
|
19
|
-
raise SocketError, "Invalid host #{params[:host]}"
|
20
|
-
raise SocketError,
|
21
|
-
"Invalid port #{params[:port]}" unless (1..(2**16-1)).include?(params[:port])
|
14
|
+
host_valid? params
|
22
15
|
@sock = UDPSocket.new
|
23
16
|
@sock.connect params[:host], params[:port]
|
24
17
|
end
|
@@ -10,14 +10,7 @@ module Opensips
|
|
10
10
|
end
|
11
11
|
|
12
12
|
def initialize(params)
|
13
|
-
|
14
|
-
'Missing socket host' if params[:host].nil?
|
15
|
-
raise ArgumentError,
|
16
|
-
'Missing socket port' if params[:port].nil?
|
17
|
-
Socket.getaddrinfo(params[:host], nil) rescue
|
18
|
-
raise SocketError, "Invalid host #{params[:host]}"
|
19
|
-
raise SocketError,
|
20
|
-
"Invalid port #{params[:port]}" unless (1..(2**16-1)).include?(params[:port])
|
13
|
+
host_valid? params
|
21
14
|
uri = "http://#{params[:host]}:#{params[:port]}/#{RPCSEG}"
|
22
15
|
@client = XMLRPC::Client.new_from_uri(uri, nil, 3)
|
23
16
|
rescue => e
|
@@ -29,10 +22,10 @@ module Opensips
|
|
29
22
|
response = ["200 OK"]
|
30
23
|
response += @client.call(cmd, *params).split(?\n)
|
31
24
|
response << ""
|
32
|
-
Opensips::MI::Response.new response
|
33
25
|
rescue => e
|
34
26
|
response = ["600 " << e.message]
|
35
|
-
|
27
|
+
ensure
|
28
|
+
return Opensips::MI::Response.new response
|
36
29
|
end
|
37
30
|
|
38
31
|
def set_header(header);header;end
|
data/lib/opensips/mi/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: opensips-mi
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Stas Kobzar
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2013-04-
|
11
|
+
date: 2013-04-17 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -114,7 +114,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
114
114
|
version: '0'
|
115
115
|
requirements: []
|
116
116
|
rubyforge_project:
|
117
|
-
rubygems_version: 2.0.
|
117
|
+
rubygems_version: 2.0.2
|
118
118
|
signing_key:
|
119
119
|
specification_version: 4
|
120
120
|
summary: OpenSIPs management interface
|