benschwarz-smoke 0.5.7 → 0.5.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (194) hide show
  1. data/Rakefile +6 -0
  2. data/VERSION.yml +1 -1
  3. metadata +65 -196
  4. data/Gemfile +0 -10
  5. data/bin/edit_json.rb +0 -3
  6. data/bin/restclient +0 -3
  7. data/vendor/gems/cache/crack-0.1.1.gem +0 -0
  8. data/vendor/gems/cache/fakeweb-1.2.5.gem +0 -0
  9. data/vendor/gems/cache/json-1.1.3.gem +0 -0
  10. data/vendor/gems/cache/rest-client-1.0.1.gem +0 -0
  11. data/vendor/gems/cache/simple-rss-1.2.gem +0 -0
  12. data/vendor/gems/cache/wycats-moneta-0.6.0.gem +0 -0
  13. data/vendor/gems/environment.rb +0 -83
  14. data/vendor/gems/gems/crack-0.1.1/LICENSE +0 -20
  15. data/vendor/gems/gems/crack-0.1.1/README.rdoc +0 -22
  16. data/vendor/gems/gems/crack-0.1.1/VERSION.yml +0 -4
  17. data/vendor/gems/gems/crack-0.1.1/lib/crack.rb +0 -7
  18. data/vendor/gems/gems/crack-0.1.1/lib/crack/core_extensions.rb +0 -126
  19. data/vendor/gems/gems/crack-0.1.1/lib/crack/json.rb +0 -66
  20. data/vendor/gems/gems/crack-0.1.1/lib/crack/xml.rb +0 -211
  21. data/vendor/gems/gems/crack-0.1.1/test/crack_test.rb +0 -4
  22. data/vendor/gems/gems/crack-0.1.1/test/json_test.rb +0 -42
  23. data/vendor/gems/gems/crack-0.1.1/test/test_helper.rb +0 -12
  24. data/vendor/gems/gems/crack-0.1.1/test/xml_test.rb +0 -451
  25. data/vendor/gems/gems/fakeweb-1.2.5/CHANGELOG +0 -163
  26. data/vendor/gems/gems/fakeweb-1.2.5/LICENSE.txt +0 -281
  27. data/vendor/gems/gems/fakeweb-1.2.5/README.rdoc +0 -193
  28. data/vendor/gems/gems/fakeweb-1.2.5/Rakefile +0 -76
  29. data/vendor/gems/gems/fakeweb-1.2.5/lib/fake_web.rb +0 -172
  30. data/vendor/gems/gems/fakeweb-1.2.5/lib/fake_web/ext/net_http.rb +0 -71
  31. data/vendor/gems/gems/fakeweb-1.2.5/lib/fake_web/registry.rb +0 -103
  32. data/vendor/gems/gems/fakeweb-1.2.5/lib/fake_web/responder.rb +0 -113
  33. data/vendor/gems/gems/fakeweb-1.2.5/lib/fake_web/response.rb +0 -10
  34. data/vendor/gems/gems/fakeweb-1.2.5/lib/fake_web/stub_socket.rb +0 -15
  35. data/vendor/gems/gems/fakeweb-1.2.5/lib/fake_web/utility.rb +0 -22
  36. data/vendor/gems/gems/fakeweb-1.2.5/lib/fakeweb.rb +0 -2
  37. data/vendor/gems/gems/fakeweb-1.2.5/test/fixtures/google_response_from_curl +0 -12
  38. data/vendor/gems/gems/fakeweb-1.2.5/test/fixtures/google_response_with_transfer_encoding +0 -17
  39. data/vendor/gems/gems/fakeweb-1.2.5/test/fixtures/google_response_without_transfer_encoding +0 -11
  40. data/vendor/gems/gems/fakeweb-1.2.5/test/fixtures/test_example.txt +0 -1
  41. data/vendor/gems/gems/fakeweb-1.2.5/test/fixtures/test_txt_file +0 -3
  42. data/vendor/gems/gems/fakeweb-1.2.5/test/test_allow_net_connect.rb +0 -85
  43. data/vendor/gems/gems/fakeweb-1.2.5/test/test_deprecations.rb +0 -54
  44. data/vendor/gems/gems/fakeweb-1.2.5/test/test_fake_authentication.rb +0 -92
  45. data/vendor/gems/gems/fakeweb-1.2.5/test/test_fake_web.rb +0 -518
  46. data/vendor/gems/gems/fakeweb-1.2.5/test/test_fake_web_open_uri.rb +0 -58
  47. data/vendor/gems/gems/fakeweb-1.2.5/test/test_helper.rb +0 -74
  48. data/vendor/gems/gems/fakeweb-1.2.5/test/test_missing_open_uri.rb +0 -25
  49. data/vendor/gems/gems/fakeweb-1.2.5/test/test_precedence.rb +0 -51
  50. data/vendor/gems/gems/fakeweb-1.2.5/test/test_query_string.rb +0 -45
  51. data/vendor/gems/gems/fakeweb-1.2.5/test/test_regexes.rb +0 -103
  52. data/vendor/gems/gems/fakeweb-1.2.5/test/test_response_headers.rb +0 -67
  53. data/vendor/gems/gems/fakeweb-1.2.5/test/test_trailing_slashes.rb +0 -53
  54. data/vendor/gems/gems/fakeweb-1.2.5/test/test_utility.rb +0 -70
  55. data/vendor/gems/gems/json-1.1.3/CHANGES +0 -93
  56. data/vendor/gems/gems/json-1.1.3/GPL +0 -340
  57. data/vendor/gems/gems/json-1.1.3/README +0 -78
  58. data/vendor/gems/gems/json-1.1.3/RUBY +0 -58
  59. data/vendor/gems/gems/json-1.1.3/Rakefile +0 -309
  60. data/vendor/gems/gems/json-1.1.3/TODO +0 -1
  61. data/vendor/gems/gems/json-1.1.3/VERSION +0 -1
  62. data/vendor/gems/gems/json-1.1.3/benchmarks/benchmark.txt +0 -133
  63. data/vendor/gems/gems/json-1.1.3/benchmarks/benchmark_generator.rb +0 -48
  64. data/vendor/gems/gems/json-1.1.3/benchmarks/benchmark_parser.rb +0 -26
  65. data/vendor/gems/gems/json-1.1.3/benchmarks/benchmark_rails.rb +0 -26
  66. data/vendor/gems/gems/json-1.1.3/bin/edit_json.rb +0 -10
  67. data/vendor/gems/gems/json-1.1.3/bin/prettify_json.rb +0 -76
  68. data/vendor/gems/gems/json-1.1.3/data/example.json +0 -1
  69. data/vendor/gems/gems/json-1.1.3/data/index.html +0 -38
  70. data/vendor/gems/gems/json-1.1.3/data/prototype.js +0 -4184
  71. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator.bundle +0 -0
  72. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/Makefile +0 -150
  73. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/extconf.rb +0 -9
  74. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/generator.bundle +0 -0
  75. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/generator.c +0 -875
  76. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/generator.o +0 -0
  77. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/unicode.c +0 -182
  78. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/unicode.h +0 -53
  79. data/vendor/gems/gems/json-1.1.3/ext/json/ext/generator/unicode.o +0 -0
  80. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser.bundle +0 -0
  81. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/Makefile +0 -150
  82. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/extconf.rb +0 -9
  83. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/parser.bundle +0 -0
  84. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/parser.c +0 -1758
  85. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/parser.o +0 -0
  86. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/parser.rl +0 -638
  87. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/unicode.c +0 -154
  88. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/unicode.h +0 -58
  89. data/vendor/gems/gems/json-1.1.3/ext/json/ext/parser/unicode.o +0 -0
  90. data/vendor/gems/gems/json-1.1.3/install.rb +0 -26
  91. data/vendor/gems/gems/json-1.1.3/lib/json.rb +0 -235
  92. data/vendor/gems/gems/json-1.1.3/lib/json/Array.xpm +0 -21
  93. data/vendor/gems/gems/json-1.1.3/lib/json/FalseClass.xpm +0 -21
  94. data/vendor/gems/gems/json-1.1.3/lib/json/Hash.xpm +0 -21
  95. data/vendor/gems/gems/json-1.1.3/lib/json/Key.xpm +0 -73
  96. data/vendor/gems/gems/json-1.1.3/lib/json/NilClass.xpm +0 -21
  97. data/vendor/gems/gems/json-1.1.3/lib/json/Numeric.xpm +0 -28
  98. data/vendor/gems/gems/json-1.1.3/lib/json/String.xpm +0 -96
  99. data/vendor/gems/gems/json-1.1.3/lib/json/TrueClass.xpm +0 -21
  100. data/vendor/gems/gems/json-1.1.3/lib/json/add/core.rb +0 -135
  101. data/vendor/gems/gems/json-1.1.3/lib/json/add/rails.rb +0 -58
  102. data/vendor/gems/gems/json-1.1.3/lib/json/common.rb +0 -354
  103. data/vendor/gems/gems/json-1.1.3/lib/json/editor.rb +0 -1362
  104. data/vendor/gems/gems/json-1.1.3/lib/json/ext.rb +0 -13
  105. data/vendor/gems/gems/json-1.1.3/lib/json/json.xpm +0 -1499
  106. data/vendor/gems/gems/json-1.1.3/lib/json/pure.rb +0 -75
  107. data/vendor/gems/gems/json-1.1.3/lib/json/pure/generator.rb +0 -394
  108. data/vendor/gems/gems/json-1.1.3/lib/json/pure/parser.rb +0 -259
  109. data/vendor/gems/gems/json-1.1.3/lib/json/version.rb +0 -9
  110. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail1.json +0 -1
  111. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail10.json +0 -1
  112. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail11.json +0 -1
  113. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail12.json +0 -1
  114. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail13.json +0 -1
  115. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail14.json +0 -1
  116. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail18.json +0 -1
  117. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail19.json +0 -1
  118. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail2.json +0 -1
  119. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail20.json +0 -1
  120. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail21.json +0 -1
  121. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail22.json +0 -1
  122. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail23.json +0 -1
  123. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail24.json +0 -1
  124. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail25.json +0 -1
  125. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail27.json +0 -2
  126. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail28.json +0 -2
  127. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail3.json +0 -1
  128. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail4.json +0 -1
  129. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail5.json +0 -1
  130. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail6.json +0 -1
  131. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail7.json +0 -1
  132. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail8.json +0 -1
  133. data/vendor/gems/gems/json-1.1.3/tests/fixtures/fail9.json +0 -1
  134. data/vendor/gems/gems/json-1.1.3/tests/fixtures/pass1.json +0 -56
  135. data/vendor/gems/gems/json-1.1.3/tests/fixtures/pass15.json +0 -1
  136. data/vendor/gems/gems/json-1.1.3/tests/fixtures/pass16.json +0 -1
  137. data/vendor/gems/gems/json-1.1.3/tests/fixtures/pass17.json +0 -1
  138. data/vendor/gems/gems/json-1.1.3/tests/fixtures/pass2.json +0 -1
  139. data/vendor/gems/gems/json-1.1.3/tests/fixtures/pass26.json +0 -1
  140. data/vendor/gems/gems/json-1.1.3/tests/fixtures/pass3.json +0 -6
  141. data/vendor/gems/gems/json-1.1.3/tests/runner.rb +0 -25
  142. data/vendor/gems/gems/json-1.1.3/tests/test_json.rb +0 -293
  143. data/vendor/gems/gems/json-1.1.3/tests/test_json_addition.rb +0 -161
  144. data/vendor/gems/gems/json-1.1.3/tests/test_json_fixtures.rb +0 -30
  145. data/vendor/gems/gems/json-1.1.3/tests/test_json_generate.rb +0 -100
  146. data/vendor/gems/gems/json-1.1.3/tests/test_json_rails.rb +0 -118
  147. data/vendor/gems/gems/json-1.1.3/tests/test_json_unicode.rb +0 -61
  148. data/vendor/gems/gems/json-1.1.3/tools/fuzz.rb +0 -140
  149. data/vendor/gems/gems/json-1.1.3/tools/server.rb +0 -62
  150. data/vendor/gems/gems/rest-client-1.0.1/README.rdoc +0 -151
  151. data/vendor/gems/gems/rest-client-1.0.1/Rakefile +0 -85
  152. data/vendor/gems/gems/rest-client-1.0.1/bin/restclient +0 -87
  153. data/vendor/gems/gems/rest-client-1.0.1/lib/rest_client.rb +0 -2
  154. data/vendor/gems/gems/rest-client-1.0.1/lib/restclient.rb +0 -93
  155. data/vendor/gems/gems/rest-client-1.0.1/lib/restclient/exceptions.rb +0 -84
  156. data/vendor/gems/gems/rest-client-1.0.1/lib/restclient/mixin/response.rb +0 -43
  157. data/vendor/gems/gems/rest-client-1.0.1/lib/restclient/raw_response.rb +0 -30
  158. data/vendor/gems/gems/rest-client-1.0.1/lib/restclient/request.rb +0 -236
  159. data/vendor/gems/gems/rest-client-1.0.1/lib/restclient/resource.rb +0 -146
  160. data/vendor/gems/gems/rest-client-1.0.1/lib/restclient/response.rb +0 -20
  161. data/vendor/gems/gems/rest-client-1.0.1/spec/base.rb +0 -4
  162. data/vendor/gems/gems/rest-client-1.0.1/spec/exceptions_spec.rb +0 -54
  163. data/vendor/gems/gems/rest-client-1.0.1/spec/mixin/response_spec.rb +0 -46
  164. data/vendor/gems/gems/rest-client-1.0.1/spec/raw_response_spec.rb +0 -17
  165. data/vendor/gems/gems/rest-client-1.0.1/spec/request_spec.rb +0 -462
  166. data/vendor/gems/gems/rest-client-1.0.1/spec/resource_spec.rb +0 -75
  167. data/vendor/gems/gems/rest-client-1.0.1/spec/response_spec.rb +0 -16
  168. data/vendor/gems/gems/rest-client-1.0.1/spec/restclient_spec.rb +0 -53
  169. data/vendor/gems/gems/simple-rss-1.2/LICENSE +0 -429
  170. data/vendor/gems/gems/simple-rss-1.2/README +0 -43
  171. data/vendor/gems/gems/simple-rss-1.2/Rakefile +0 -212
  172. data/vendor/gems/gems/simple-rss-1.2/lib/simple-rss.rb +0 -149
  173. data/vendor/gems/gems/simple-rss-1.2/test/base/base_test.rb +0 -51
  174. data/vendor/gems/gems/simple-rss-1.2/test/data/atom.xml +0 -45
  175. data/vendor/gems/gems/simple-rss-1.2/test/data/not-rss.xml +0 -8
  176. data/vendor/gems/gems/simple-rss-1.2/test/data/rss09.rdf +0 -79
  177. data/vendor/gems/gems/simple-rss-1.2/test/data/rss20.xml +0 -818
  178. data/vendor/gems/gems/simple-rss-1.2/test/test_helper.rb +0 -4
  179. data/vendor/gems/gems/wycats-moneta-0.6.0/LICENSE +0 -20
  180. data/vendor/gems/gems/wycats-moneta-0.6.0/README +0 -50
  181. data/vendor/gems/gems/wycats-moneta-0.6.0/Rakefile +0 -60
  182. data/vendor/gems/gems/wycats-moneta-0.6.0/TODO +0 -4
  183. data/vendor/gems/gems/wycats-moneta-0.6.0/lib/moneta.rb +0 -76
  184. data/vendor/gems/gems/wycats-moneta-0.6.0/lib/moneta/datamapper.rb +0 -117
  185. data/vendor/gems/gems/wycats-moneta-0.6.0/lib/moneta/file.rb +0 -91
  186. data/vendor/gems/gems/wycats-moneta-0.6.0/lib/moneta/memcache.rb +0 -52
  187. data/vendor/gems/gems/wycats-moneta-0.6.0/lib/moneta/memory.rb +0 -11
  188. data/vendor/gems/gems/wycats-moneta-0.6.0/lib/moneta/xattr.rb +0 -58
  189. data/vendor/gems/specifications/crack-0.1.1.gemspec +0 -29
  190. data/vendor/gems/specifications/fakeweb-1.2.5.gemspec +0 -34
  191. data/vendor/gems/specifications/json-1.1.3.gemspec +0 -33
  192. data/vendor/gems/specifications/rest-client-1.0.1.gemspec +0 -30
  193. data/vendor/gems/specifications/simple-rss-1.2.gemspec +0 -27
  194. data/vendor/gems/specifications/wycats-moneta-0.6.0.gemspec +0 -29
@@ -1,84 +0,0 @@
1
- module RestClient
2
- # This is the base RestClient exception class. Rescue it if you want to
3
- # catch any exception that your request might raise
4
- class Exception < RuntimeError
5
- def message(default=nil)
6
- self.class::ErrorMessage
7
- end
8
- end
9
-
10
- # Base RestClient exception when there's a response available
11
- class ExceptionWithResponse < Exception
12
- attr_accessor :response
13
-
14
- def initialize(response=nil)
15
- @response = response
16
- end
17
-
18
- def http_code
19
- @response.code.to_i if @response
20
- end
21
- end
22
-
23
- # A redirect was encountered; caught by execute to retry with the new url.
24
- class Redirect < Exception
25
- ErrorMessage = "Redirect"
26
-
27
- attr_accessor :url
28
- def initialize(url)
29
- @url = url
30
- end
31
- end
32
-
33
- class NotModified < ExceptionWithResponse
34
- ErrorMessage = 'NotModified'
35
- end
36
-
37
- # Authorization is required to access the resource specified.
38
- class Unauthorized < ExceptionWithResponse
39
- ErrorMessage = 'Unauthorized'
40
- end
41
-
42
- # No resource was found at the given URL.
43
- class ResourceNotFound < ExceptionWithResponse
44
- ErrorMessage = 'Resource not found'
45
- end
46
-
47
- # The server broke the connection prior to the request completing. Usually
48
- # this means it crashed, or sometimes that your network connection was
49
- # severed before it could complete.
50
- class ServerBrokeConnection < Exception
51
- ErrorMessage = 'Server broke connection'
52
- end
53
-
54
- # The server took too long to respond.
55
- class RequestTimeout < Exception
56
- ErrorMessage = 'Request timed out'
57
- end
58
-
59
- # The request failed, meaning the remote HTTP server returned a code other
60
- # than success, unauthorized, or redirect.
61
- #
62
- # The exception message attempts to extract the error from the XML, using
63
- # format returned by Rails: <errors><error>some message</error></errors>
64
- #
65
- # You can get the status code by e.http_code, or see anything about the
66
- # response via e.response. For example, the entire result body (which is
67
- # probably an HTML error page) is e.response.body.
68
- class RequestFailed < ExceptionWithResponse
69
- def message
70
- "HTTP status code #{http_code}"
71
- end
72
-
73
- def to_s
74
- message
75
- end
76
- end
77
- end
78
-
79
- # backwards compatibility
80
- class RestClient::Request
81
- Redirect = RestClient::Redirect
82
- Unauthorized = RestClient::Unauthorized
83
- RequestFailed = RestClient::RequestFailed
84
- end
@@ -1,43 +0,0 @@
1
- module RestClient
2
- module Mixin
3
- module Response
4
- attr_reader :net_http_res
5
-
6
- # HTTP status code, always 200 since RestClient throws exceptions for
7
- # other codes.
8
- def code
9
- @code ||= @net_http_res.code.to_i
10
- end
11
-
12
- # A hash of the headers, beautified with symbols and underscores.
13
- # e.g. "Content-type" will become :content_type.
14
- def headers
15
- @headers ||= self.class.beautify_headers(@net_http_res.to_hash)
16
- end
17
-
18
- # Hash of cookies extracted from response headers
19
- def cookies
20
- @cookies ||= (self.headers[:set_cookie] || "").split('; ').inject({}) do |out, raw_c|
21
- key, val = raw_c.split('=')
22
- unless %w(expires domain path secure).member?(key)
23
- out[key] = val
24
- end
25
- out
26
- end
27
- end
28
-
29
- def self.included(receiver)
30
- receiver.extend(RestClient::Mixin::Response::ClassMethods)
31
- end
32
-
33
- module ClassMethods
34
- def beautify_headers(headers)
35
- headers.inject({}) do |out, (key, value)|
36
- out[key.gsub(/-/, '_').to_sym] = value.first
37
- out
38
- end
39
- end
40
- end
41
- end
42
- end
43
- end
@@ -1,30 +0,0 @@
1
- require File.dirname(__FILE__) + '/mixin/response'
2
-
3
- module RestClient
4
- # The response from RestClient on a raw request looks like a string, but is
5
- # actually one of these. 99% of the time you're making a rest call all you
6
- # care about is the body, but on the occassion you want to fetch the
7
- # headers you can:
8
- #
9
- # RestClient.get('http://example.com').headers[:content_type]
10
- #
11
- # In addition, if you do not use the response as a string, you can access
12
- # a Tempfile object at res.file, which contains the path to the raw
13
- # downloaded request body.
14
- class RawResponse
15
- include RestClient::Mixin::Response
16
-
17
- attr_reader :file
18
-
19
- def initialize(tempfile, net_http_res)
20
- @net_http_res = net_http_res
21
- @file = tempfile
22
- end
23
-
24
- def to_s
25
- @file.open
26
- @file.read
27
- end
28
-
29
- end
30
- end
@@ -1,236 +0,0 @@
1
- require 'tempfile'
2
-
3
- module RestClient
4
- # This class is used internally by RestClient to send the request, but you can also
5
- # access it internally if you'd like to use a method not directly supported by the
6
- # main API. For example:
7
- #
8
- # RestClient::Request.execute(:method => :head, :url => 'http://example.com')
9
- #
10
- class Request
11
- attr_reader :method, :url, :payload, :headers,
12
- :cookies, :user, :password, :timeout, :open_timeout,
13
- :verify_ssl, :ssl_client_cert, :ssl_client_key, :ssl_ca_file,
14
- :raw_response
15
-
16
- def self.execute(args)
17
- new(args).execute
18
- end
19
-
20
- def initialize(args)
21
- @method = args[:method] or raise ArgumentError, "must pass :method"
22
- @url = args[:url] or raise ArgumentError, "must pass :url"
23
- @headers = args[:headers] || {}
24
- @cookies = @headers.delete(:cookies) || args[:cookies] || {}
25
- @payload = process_payload(args[:payload])
26
- @user = args[:user]
27
- @password = args[:password]
28
- @timeout = args[:timeout]
29
- @open_timeout = args[:open_timeout]
30
- @raw_response = args[:raw_response] || false
31
- @verify_ssl = args[:verify_ssl] || false
32
- @ssl_client_cert = args[:ssl_client_cert] || nil
33
- @ssl_client_key = args[:ssl_client_key] || nil
34
- @ssl_ca_file = args[:ssl_ca_file] || nil
35
- @tf = nil # If you are a raw request, this is your tempfile
36
- end
37
-
38
- def execute
39
- execute_inner
40
- rescue Redirect => e
41
- @url = e.url
42
- execute
43
- end
44
-
45
- def execute_inner
46
- uri = parse_url_with_auth(url)
47
- transmit uri, net_http_request_class(method).new(uri.request_uri, make_headers(headers)), payload
48
- end
49
-
50
- def make_headers(user_headers)
51
- unless @cookies.empty?
52
- user_headers[:cookie] = @cookies.map {|key, val| "#{key.to_s}=#{val}" }.join('; ')
53
- end
54
-
55
- default_headers.merge(user_headers).inject({}) do |final, (key, value)|
56
- final[key.to_s.gsub(/_/, '-').capitalize] = value.to_s
57
- final
58
- end
59
- end
60
-
61
- def net_http_class
62
- if RestClient.proxy
63
- proxy_uri = URI.parse(RestClient.proxy)
64
- Net::HTTP::Proxy(proxy_uri.host, proxy_uri.port, proxy_uri.user, proxy_uri.password)
65
- else
66
- Net::HTTP
67
- end
68
- end
69
-
70
- def net_http_request_class(method)
71
- Net::HTTP.const_get(method.to_s.capitalize)
72
- end
73
-
74
- def parse_url(url)
75
- url = "http://#{url}" unless url.match(/^http/)
76
- URI.parse(url)
77
- end
78
-
79
- def parse_url_with_auth(url)
80
- uri = parse_url(url)
81
- @user = uri.user if uri.user
82
- @password = uri.password if uri.password
83
- uri
84
- end
85
-
86
- def process_payload(p=nil, parent_key=nil)
87
- unless p.is_a?(Hash)
88
- p
89
- else
90
- @headers[:content_type] ||= 'application/x-www-form-urlencoded'
91
- p.keys.map do |k|
92
- key = parent_key ? "#{parent_key}[#{k}]" : k
93
- if p[k].is_a? Hash
94
- process_payload(p[k], key)
95
- else
96
- value = URI.escape(p[k].to_s, Regexp.new("[^#{URI::PATTERN::UNRESERVED}]"))
97
- "#{key}=#{value}"
98
- end
99
- end.join("&")
100
- end
101
- end
102
-
103
- def transmit(uri, req, payload)
104
- setup_credentials(req)
105
-
106
- net = net_http_class.new(uri.host, uri.port)
107
- net.use_ssl = uri.is_a?(URI::HTTPS)
108
- if @verify_ssl == false
109
- net.verify_mode = OpenSSL::SSL::VERIFY_NONE
110
- elsif @verify_ssl.is_a? Integer
111
- net.verify_mode = @verify_ssl
112
- end
113
- net.cert = @ssl_client_cert if @ssl_client_cert
114
- net.key = @ssl_client_key if @ssl_client_key
115
- net.ca_file = @ssl_ca_file if @ssl_ca_file
116
- net.read_timeout = @timeout if @timeout
117
- net.open_timeout = @open_timeout if @open_timeout
118
-
119
- display_log request_log
120
-
121
- net.start do |http|
122
- res = http.request(req, payload) { |http_response| fetch_body(http_response) }
123
- result = process_result(res)
124
- display_log response_log(res)
125
-
126
- if result.kind_of?(String) or @method == :head
127
- Response.new(result, res)
128
- elsif @raw_response
129
- RawResponse.new(@tf, res)
130
- else
131
- nil
132
- end
133
- end
134
- rescue EOFError
135
- raise RestClient::ServerBrokeConnection
136
- rescue Timeout::Error
137
- raise RestClient::RequestTimeout
138
- end
139
-
140
- def setup_credentials(req)
141
- req.basic_auth(user, password) if user
142
- end
143
-
144
- def fetch_body(http_response)
145
- if @raw_response
146
- # Taken from Chef, which as in turn...
147
- # Stolen from http://www.ruby-forum.com/topic/166423
148
- # Kudos to _why!
149
- @tf = Tempfile.new("rest-client")
150
- size, total = 0, http_response.header['Content-Length'].to_i
151
- http_response.read_body do |chunk|
152
- @tf.write(chunk)
153
- size += chunk.size
154
- if size == 0
155
- display_log("#{@method} #{@url} done (0 length file)")
156
- elsif total == 0
157
- display_log("#{@method} #{@url} (zero content length)")
158
- else
159
- display_log("#{@method} #{@url} %d%% done (%d of %d)" % [(size * 100) / total, size, total])
160
- end
161
- end
162
- @tf.close
163
- @tf
164
- else
165
- http_response.read_body
166
- end
167
- http_response
168
- end
169
-
170
- def process_result(res)
171
- if res.code =~ /\A2\d{2}\z/
172
- # We don't decode raw requests
173
- unless @raw_response
174
- decode res['content-encoding'], res.body if res.body
175
- end
176
- elsif %w(301 302 303).include? res.code
177
- url = res.header['Location']
178
-
179
- if url !~ /^http/
180
- uri = URI.parse(@url)
181
- uri.path = "/#{url}".squeeze('/')
182
- url = uri.to_s
183
- end
184
-
185
- raise Redirect, url
186
- elsif res.code == "304"
187
- raise NotModified, res
188
- elsif res.code == "401"
189
- raise Unauthorized, res
190
- elsif res.code == "404"
191
- raise ResourceNotFound, res
192
- else
193
- raise RequestFailed, res
194
- end
195
- end
196
-
197
- def decode(content_encoding, body)
198
- if content_encoding == 'gzip' and not body.empty?
199
- Zlib::GzipReader.new(StringIO.new(body)).read
200
- elsif content_encoding == 'deflate'
201
- Zlib::Inflate.new.inflate(body)
202
- else
203
- body
204
- end
205
- end
206
-
207
- def request_log
208
- out = []
209
- out << "RestClient.#{method} #{url.inspect}"
210
- out << (payload.size > 100 ? "(#{payload.size} byte payload)".inspect : payload.inspect) if payload
211
- out << headers.inspect.gsub(/^\{/, '').gsub(/\}$/, '') unless headers.empty?
212
- out.join(', ')
213
- end
214
-
215
- def response_log(res)
216
- size = @raw_response ? File.size(@tf.path) : (res.body.nil? ? 0 : res.body.size)
217
- "# => #{res.code} #{res.class.to_s.gsub(/^Net::HTTP/, '')} | #{(res['Content-type'] || '').gsub(/;.*$/, '')} #{size} bytes"
218
- end
219
-
220
- def display_log(msg)
221
- return unless log_to = RestClient.log
222
-
223
- if log_to == 'stdout'
224
- STDOUT.puts msg
225
- elsif log_to == 'stderr'
226
- STDERR.puts msg
227
- else
228
- File.open(log_to, 'a') { |f| f.puts msg }
229
- end
230
- end
231
-
232
- def default_headers
233
- { :accept => 'application/xml', :accept_encoding => 'gzip, deflate' }
234
- end
235
- end
236
- end
@@ -1,146 +0,0 @@
1
- module RestClient
2
- # A class that can be instantiated for access to a RESTful resource,
3
- # including authentication.
4
- #
5
- # Example:
6
- #
7
- # resource = RestClient::Resource.new('http://some/resource')
8
- # jpg = resource.get(:accept => 'image/jpg')
9
- #
10
- # With HTTP basic authentication:
11
- #
12
- # resource = RestClient::Resource.new('http://protected/resource', :user => 'user', :password => 'password')
13
- # resource.delete
14
- #
15
- # With a timeout (seconds):
16
- #
17
- # RestClient::Resource.new('http://slow', :timeout => 10)
18
- #
19
- # With an open timeout (seconds):
20
- #
21
- # RestClient::Resource.new('http://behindfirewall', :open_timeout => 10)
22
- #
23
- # You can also use resources to share common headers. For headers keys,
24
- # symbols are converted to strings. Example:
25
- #
26
- # resource = RestClient::Resource.new('http://some/resource', :headers => { :client_version => 1 })
27
- #
28
- # This header will be transported as X-Client-Version (notice the X prefix,
29
- # capitalization and hyphens)
30
- #
31
- # Use the [] syntax to allocate subresources:
32
- #
33
- # site = RestClient::Resource.new('http://example.com', :user => 'adam', :password => 'mypasswd')
34
- # site['posts/1/comments'].post 'Good article.', :content_type => 'text/plain'
35
- #
36
- class Resource
37
- attr_reader :url, :options
38
-
39
- def initialize(url, options={}, backwards_compatibility=nil)
40
- @url = url
41
- if options.class == Hash
42
- @options = options
43
- else # compatibility with previous versions
44
- @options = { :user => options, :password => backwards_compatibility }
45
- end
46
- end
47
-
48
- def get(additional_headers={})
49
- Request.execute(options.merge(
50
- :method => :get,
51
- :url => url,
52
- :headers => headers.merge(additional_headers)
53
- ))
54
- end
55
-
56
- def post(payload, additional_headers={})
57
- Request.execute(options.merge(
58
- :method => :post,
59
- :url => url,
60
- :payload => payload,
61
- :headers => headers.merge(additional_headers)
62
- ))
63
- end
64
-
65
- def put(payload, additional_headers={})
66
- Request.execute(options.merge(
67
- :method => :put,
68
- :url => url,
69
- :payload => payload,
70
- :headers => headers.merge(additional_headers)
71
- ))
72
- end
73
-
74
- def delete(additional_headers={})
75
- Request.execute(options.merge(
76
- :method => :delete,
77
- :url => url,
78
- :headers => headers.merge(additional_headers)
79
- ))
80
- end
81
-
82
- def to_s
83
- url
84
- end
85
-
86
- def user
87
- options[:user]
88
- end
89
-
90
- def password
91
- options[:password]
92
- end
93
-
94
- def headers
95
- options[:headers] || {}
96
- end
97
-
98
- def timeout
99
- options[:timeout]
100
- end
101
-
102
- def open_timeout
103
- options[:open_timeout]
104
- end
105
-
106
- # Construct a subresource, preserving authentication.
107
- #
108
- # Example:
109
- #
110
- # site = RestClient::Resource.new('http://example.com', 'adam', 'mypasswd')
111
- # site['posts/1/comments'].post 'Good article.', :content_type => 'text/plain'
112
- #
113
- # This is especially useful if you wish to define your site in one place and
114
- # call it in multiple locations:
115
- #
116
- # def orders
117
- # RestClient::Resource.new('http://example.com/orders', 'admin', 'mypasswd')
118
- # end
119
- #
120
- # orders.get # GET http://example.com/orders
121
- # orders['1'].get # GET http://example.com/orders/1
122
- # orders['1/items'].delete # DELETE http://example.com/orders/1/items
123
- #
124
- # Nest resources as far as you want:
125
- #
126
- # site = RestClient::Resource.new('http://example.com')
127
- # posts = site['posts']
128
- # first_post = posts['1']
129
- # comments = first_post['comments']
130
- # comments.post 'Hello', :content_type => 'text/plain'
131
- #
132
- def [](suburl)
133
- self.class.new(concat_urls(url, suburl), options)
134
- end
135
-
136
- def concat_urls(url, suburl) # :nodoc:
137
- url = url.to_s
138
- suburl = suburl.to_s
139
- if url.slice(-1, 1) == '/' or suburl.slice(0, 1) == '/'
140
- url + suburl
141
- else
142
- "#{url}/#{suburl}"
143
- end
144
- end
145
- end
146
- end