epp 1.3.2 → 1.4.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +1 -0
- data/VERSION +1 -1
- data/epp.gemspec +4 -1
- data/lib/epp.rb +1 -1
- data/lib/epp/server.rb +27 -27
- data/test/test_epp.rb +1 -1
- data/test/xml/new_request.xml +2 -1
- metadata +18 -4
data/Rakefile
CHANGED
@@ -16,6 +16,7 @@ begin
|
|
16
16
|
gem.add_development_dependency "shoulda"
|
17
17
|
gem.add_development_dependency "mocha"
|
18
18
|
gem.add_dependency "hpricot"
|
19
|
+
gem.add_dependency "libxml-ruby"
|
19
20
|
end
|
20
21
|
rescue LoadError
|
21
22
|
puts "Jeweler (or a dependency) not available. Install it with: sudo gem install jeweler"
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
1.
|
1
|
+
1.4.0
|
data/epp.gemspec
CHANGED
@@ -5,7 +5,7 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = %q{epp}
|
8
|
-
s.version = "1.
|
8
|
+
s.version = "1.4.0"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["Josh Delsman"]
|
@@ -57,15 +57,18 @@ Gem::Specification.new do |s|
|
|
57
57
|
s.add_development_dependency(%q<shoulda>, [">= 0"])
|
58
58
|
s.add_development_dependency(%q<mocha>, [">= 0"])
|
59
59
|
s.add_runtime_dependency(%q<hpricot>, [">= 0"])
|
60
|
+
s.add_runtime_dependency(%q<libxml-ruby>, [">= 0"])
|
60
61
|
else
|
61
62
|
s.add_dependency(%q<shoulda>, [">= 0"])
|
62
63
|
s.add_dependency(%q<mocha>, [">= 0"])
|
63
64
|
s.add_dependency(%q<hpricot>, [">= 0"])
|
65
|
+
s.add_dependency(%q<libxml-ruby>, [">= 0"])
|
64
66
|
end
|
65
67
|
else
|
66
68
|
s.add_dependency(%q<shoulda>, [">= 0"])
|
67
69
|
s.add_dependency(%q<mocha>, [">= 0"])
|
68
70
|
s.add_dependency(%q<hpricot>, [">= 0"])
|
71
|
+
s.add_dependency(%q<libxml-ruby>, [">= 0"])
|
69
72
|
end
|
70
73
|
end
|
71
74
|
|
data/lib/epp.rb
CHANGED
data/lib/epp/server.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
module Epp #:nodoc:
|
2
2
|
class Server
|
3
|
-
include
|
3
|
+
include LibXML::XML
|
4
4
|
include RequiresParameters
|
5
5
|
|
6
6
|
attr_accessor :tag, :password, :server, :port, :lang, :services, :extensions, :version
|
@@ -34,14 +34,12 @@ module Epp #:nodoc:
|
|
34
34
|
end
|
35
35
|
|
36
36
|
def new_epp_request
|
37
|
-
xml
|
38
|
-
xml
|
37
|
+
xml = Document.new
|
38
|
+
xml.root = Node.new("epp")
|
39
39
|
|
40
|
-
xml.
|
41
|
-
|
42
|
-
|
43
|
-
"xsi:schemaLocation" => "urn:ietf:params:xml:ns:epp-1.0 epp-1.0.xsd"
|
44
|
-
})
|
40
|
+
xml.root["xmlns"] = "urn:ietf:params:xml:ns:epp-1.0"
|
41
|
+
xml.root["xmlns:xsi"] = "http://www.w3.org/2001/XMLSchema-instance"
|
42
|
+
xml.root["xsi:schemaLocation"] = "urn:ietf:params:xml:ns:epp-1.0 epp-1.0.xsd"
|
45
43
|
|
46
44
|
return xml
|
47
45
|
end
|
@@ -140,30 +138,32 @@ module Epp #:nodoc:
|
|
140
138
|
|
141
139
|
xml = new_epp_request
|
142
140
|
|
143
|
-
command =
|
144
|
-
login =
|
141
|
+
xml.root << command = Node.new("command")
|
142
|
+
command << login = Node.new("login")
|
145
143
|
|
146
|
-
login.
|
147
|
-
login.
|
144
|
+
login << Node.new("clID", tag)
|
145
|
+
login << Node.new("pw", password)
|
148
146
|
|
149
|
-
options =
|
150
|
-
options.add_element("version").text = version
|
151
|
-
options.add_element("lang").text = lang
|
147
|
+
login << options = Node.new("options")
|
152
148
|
|
153
|
-
|
154
|
-
|
155
|
-
services.add_element("objURI").text = "urn:ietf:params:xml:ns:contact-1.0"
|
156
|
-
services.add_element("objURI").text = "urn:ietf:params:xml:ns:host-1.0"
|
149
|
+
options << Node.new("version", version)
|
150
|
+
options << Node.new("lang", lang)
|
157
151
|
|
158
|
-
|
152
|
+
login << services = Node.new("svcs")
|
153
|
+
|
154
|
+
services << Node.new("objURI", "urn:ietf:params:xml:ns:domain-1.0")
|
155
|
+
services << Node.new("objURI", "urn:ietf:params:xml:ns:contact-1.0")
|
156
|
+
services << Node.new("objURI", "urn:ietf:params:xml:ns:host-1.0")
|
157
|
+
|
158
|
+
services << extensions_container = Node.new("svcExtension") unless extensions.empty?
|
159
159
|
|
160
160
|
for uri in extensions
|
161
|
-
extensions_container.
|
161
|
+
extensions_container << Node.new("extURI", uri)
|
162
162
|
end
|
163
163
|
|
164
|
-
command.
|
164
|
+
command << Node.new("clTRID", UUIDTools::UUID.timestamp_create.to_s)
|
165
165
|
|
166
|
-
response = Hpricot
|
166
|
+
response = Hpricot::XML(send_request(xml.to_s))
|
167
167
|
|
168
168
|
handle_response(response)
|
169
169
|
end
|
@@ -174,12 +174,12 @@ module Epp #:nodoc:
|
|
174
174
|
|
175
175
|
xml = new_epp_request
|
176
176
|
|
177
|
-
command =
|
177
|
+
xml.root << command = Node.new("command")
|
178
178
|
|
179
|
-
command.
|
180
|
-
command.
|
179
|
+
command << login = Node.new("logout")
|
180
|
+
command << Node.new("clTRID", UUIDTools::UUID.timestamp_create.to_s)
|
181
181
|
|
182
|
-
response = Hpricot
|
182
|
+
response = Hpricot::XML(send_request(xml.to_s))
|
183
183
|
|
184
184
|
handle_response(response, 1500)
|
185
185
|
end
|
data/test/test_epp.rb
CHANGED
@@ -61,7 +61,7 @@ class EppTest < Test::Unit::TestCase
|
|
61
61
|
should "build a new XML request" do
|
62
62
|
xml = xml_file("new_request.xml")
|
63
63
|
|
64
|
-
assert @epp.new_epp_request.is_a?(
|
64
|
+
assert @epp.new_epp_request.is_a?(LibXML::XML::Document)
|
65
65
|
assert_equal xml, @epp.new_epp_request.to_s
|
66
66
|
end
|
67
67
|
|
data/test/xml/new_request.xml
CHANGED
@@ -1 +1,2 @@
|
|
1
|
-
<?xml version=
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
2
|
+
<epp xmlns="urn:ietf:params:xml:ns:epp-1.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:ietf:params:xml:ns:epp-1.0 epp-1.0.xsd"/>
|
metadata
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: epp
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
hash:
|
4
|
+
hash: 7
|
5
5
|
prerelease: false
|
6
6
|
segments:
|
7
7
|
- 1
|
8
|
-
-
|
9
|
-
-
|
10
|
-
version: 1.
|
8
|
+
- 4
|
9
|
+
- 0
|
10
|
+
version: 1.4.0
|
11
11
|
platform: ruby
|
12
12
|
authors:
|
13
13
|
- Josh Delsman
|
@@ -60,6 +60,20 @@ dependencies:
|
|
60
60
|
version: "0"
|
61
61
|
type: :runtime
|
62
62
|
version_requirements: *id003
|
63
|
+
- !ruby/object:Gem::Dependency
|
64
|
+
name: libxml-ruby
|
65
|
+
prerelease: false
|
66
|
+
requirement: &id004 !ruby/object:Gem::Requirement
|
67
|
+
none: false
|
68
|
+
requirements:
|
69
|
+
- - ">="
|
70
|
+
- !ruby/object:Gem::Version
|
71
|
+
hash: 3
|
72
|
+
segments:
|
73
|
+
- 0
|
74
|
+
version: "0"
|
75
|
+
type: :runtime
|
76
|
+
version_requirements: *id004
|
63
77
|
description: Basic functionality for connecting and making requests on EPP (Extensible Provisioning Protocol) servers
|
64
78
|
email: jdelsman@ultraspeed.com
|
65
79
|
executables: []
|