passety 0.0.8 → 0.0.9

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 133b4abe3e0bff51650678790c3df2c545dc4983
4
- data.tar.gz: 5b03dce74c6ed7ca46092edb900b169a1a058eec
3
+ metadata.gz: c62da73651525741c30d97b12331b3c566a22d30
4
+ data.tar.gz: c88ac290b82abe26d06f0ec22c28968b3a3108a8
5
5
  SHA512:
6
- metadata.gz: 26e9498d470b726519e5102578888ee53e06fafd15b61a90f0d1b41ea4d8c48d8f2ea27e5e53564482614b7e6d6850a6db446840eb86b57c0968d55aaaa1a954
7
- data.tar.gz: 2b6529739271c288b94b579c20573dbb887bcce37b3edc2f9c69790265247bd5f73a916cba5984069e33d28029d01b84b1d0ff65552f9b490dfcd10ca2ac618e
6
+ metadata.gz: 0625b23e117257b7816fd7b5e089ab3f1bb9a8762d573a445a1e33ae84ddd3d04eff5e84f2240ab5aa493cf3f93d28f78b9ef3d06cdadb4a12854f5216bfca4d
7
+ data.tar.gz: 9b8894fe91babedeec9f9cd7bd709687ee67b86e014fb3022fb3381aecf4ccda960c17468aa4ca9a0bee4c2400df3535e37b8d647a0453de6204c028c8c991ec
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- passety (0.0.8)
4
+ passety (0.0.9)
5
5
  faraday
6
6
  json
7
7
 
data/lib/passety/item.rb CHANGED
@@ -14,11 +14,11 @@ module Passety
14
14
  end
15
15
 
16
16
  def update(id, params)
17
- @wrapper.perform_request { |c| c.put(url(id), encode_params(params)) }
17
+ @wrapper.perform_request { |c| c.put(url(id), JSON.generate(params)) }
18
18
  end
19
19
 
20
20
  def create(params)
21
- @wrapper.perform_request { |c| c.post(@uri, encode_params(params)) }
21
+ @wrapper.perform_request { |c| c.post(@uri, JSON.generate(params)) }
22
22
  end
23
23
 
24
24
  def destroy(id)
@@ -29,18 +29,5 @@ module Passety
29
29
  def url(id)
30
30
  '/' + [ @uri, id ].join('/')
31
31
  end
32
-
33
- def encode_params(params)
34
- has_multipart?(params) ? params : JSON.generate(params)
35
- end
36
-
37
- def has_multipart?(obj)
38
- if obj.respond_to?(:each) && !obj.is_a?(String)
39
- (obj.respond_to?(:values) ? obj.values : obj).each do |val|
40
- return true if (val.respond_to?(:content_type) || has_multipart?(val))
41
- end
42
- end
43
- false
44
- end
45
32
  end
46
33
  end
@@ -15,11 +15,11 @@ module Passety
15
15
  end
16
16
 
17
17
  def update(pid, id, params)
18
- @wrapper.perform_request { |c| c.put(url(pid, id), encode_params(params)) }
18
+ @wrapper.perform_request { |c| c.put(url(pid, id), JSON.generate(params)) }
19
19
  end
20
20
 
21
21
  def create(pid, params)
22
- @wrapper.perform_request { |c| c.post(url(pid), encode_params(params)) }
22
+ @wrapper.perform_request { |c| c.post(url(pid), JSON.generate(params)) }
23
23
  end
24
24
 
25
25
  def destroy(pid, id)
data/lib/passety/photo.rb CHANGED
@@ -3,9 +3,5 @@ module Passety
3
3
  def initialize(wrapper, parent)
4
4
  super(wrapper, parent, 'photos')
5
5
  end
6
-
7
- def create(pid, params = {})
8
- Item.new(@wrapper, 'uploads').create(params.merge(tid: pid))
9
- end
10
6
  end
11
7
  end
@@ -0,0 +1,28 @@
1
+ module Passety
2
+ class Upload
3
+ def initialize(wrapper)
4
+ @wrapper = wrapper
5
+ end
6
+
7
+ def create(params)
8
+ @wrapper.perform_request { |c| c.post('/uploads', &upload_file(params)) }
9
+ end
10
+
11
+ private
12
+ def upload_file(params)
13
+ file = params.delete(:file)
14
+ proc do |req|
15
+ req.url(url_with_params(params))
16
+ req.body = file.tempfile.read
17
+ req.headers['Content-Type'] = file.content_type
18
+ req.headers['Content-Disposition'] = "attachment; filename=\"#{file.original_filename}\""
19
+ end unless file.nil?
20
+ end
21
+
22
+ def url_with_params(params)
23
+ uri = URI.parse('/uploads')
24
+ uri.query = URI.encode_www_form(params)
25
+ uri
26
+ end
27
+ end
28
+ end
@@ -1,3 +1,3 @@
1
1
  module Passety
2
- VERSION = "0.0.8"
2
+ VERSION = "0.0.9"
3
3
  end
@@ -17,6 +17,10 @@ module Passety
17
17
  @things ||= Thing.new(self)
18
18
  end
19
19
 
20
+ def uploads
21
+ @uploads ||= Upload.new(self)
22
+ end
23
+
20
24
  def search(name, options = {})
21
25
  perform_request { |c| c.get('/explore', options.merge(q: name)) }
22
26
  end
data/lib/passety.rb CHANGED
@@ -13,6 +13,7 @@ require 'passety/collection'
13
13
  require 'passety/property'
14
14
  require 'passety/thing'
15
15
  require 'passety/photo'
16
+ require 'passety/upload'
16
17
 
17
18
  require 'passety/exceptions/not_found_error'
18
19
  require 'passety/exceptions/read_only_error'
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: passety
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.8
4
+ version: 0.0.9
5
5
  platform: ruby
6
6
  authors:
7
7
  - Passety Team
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-05-21 00:00:00.000000000 Z
11
+ date: 2014-05-26 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -163,6 +163,7 @@ files:
163
163
  - lib/passety/property.rb
164
164
  - lib/passety/response.rb
165
165
  - lib/passety/thing.rb
166
+ - lib/passety/upload.rb
166
167
  - lib/passety/version.rb
167
168
  - lib/passety/wrapper.rb
168
169
  - passety.gemspec