eventbrite 0.0.1

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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 7ba321779cc37aa069ce9c37599b3dfc28a55271
4
+ data.tar.gz: c6526dcc66929712de9db0ec0d47783f0dde8b3f
5
+ SHA512:
6
+ metadata.gz: e39d14d1ff19a3db865e0fb7fc81c55c36e74873edd02cdedb444f4d19b96c9154ff53d99f560b83340dd1bbda438f1e7c3f8f70c77d73c0436a987fa18cc27b
7
+ data.tar.gz: 1adbdac81eaebe6c610f33df6d06c5cbef126b8145cfea900b973509f34177ec7960585f911ad0ff997bf4c41880641f209121f482b1128e9e496b9b3d67c650
data/.gitignore ADDED
@@ -0,0 +1,21 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
18
+
19
+ # Vagrant
20
+ Vagrantfile
21
+ .vagrant
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in eventbrite.gemspec
4
+ gemspec
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2014 Teng Siong Ong
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,225 @@
1
+ # Eventbrite
2
+
3
+ [Eventbrite](http://developer.eventbrite.com/docs/) rubygem for API v3.
4
+
5
+ ## Installation
6
+
7
+ NOTE: PLEASE NOTE THAT WE ARE STILL TRYING TO ACQUIRE THE GEM NAME `eventbrite`.
8
+
9
+ Add this line to your application's Gemfile:
10
+
11
+ gem 'eventbrite'
12
+
13
+ And then execute:
14
+
15
+ $ bundle
16
+
17
+ Or install it yourself as:
18
+
19
+ $ gem install eventbrite
20
+
21
+ ## Usage
22
+
23
+ ### Access Token
24
+
25
+ Each method requires you have to a valid `access_token` that you obtain
26
+ via Eventbrite [OAuth 2.0](http://developer.eventbrite.com/docs/auth/) protocol.
27
+
28
+ There are two ways to use your `access_token` with this gem.
29
+
30
+ ```ruby
31
+ # This token will be used globally each time you used the gem API.
32
+ Eventbrite.token = `your_access_token`
33
+ Eventbrite::Event.search({q: 'Dogecoin'})
34
+
35
+ # This is to specific the token you want to use for each API call.
36
+ Eventbrite::Event.search({q: 'Dogecoin'}, 'your_access_token')
37
+ ```
38
+
39
+ ### Pagination
40
+
41
+ Please not that not all APIs have pagination.
42
+
43
+ ```ruby
44
+ events = Eventbrite::Event.searh({q: 'Dogecoin'})
45
+ events.paginated? # => true
46
+
47
+ # Get all events
48
+ all_events = events.events
49
+ while events.next?
50
+ events = Eventbrite::Event.searh({q: 'Dogecoin', page: events.next_page})
51
+ all_events.concat(events.events)
52
+ end
53
+ ```
54
+
55
+ ### [Event Search](http://developer.eventbrite.com/docs/event-search/)
56
+
57
+ ```ruby
58
+ # For supported parameters, check out the link above.
59
+ Eventbrite::Event.searh({q: 'Dogecoin'})
60
+ ```
61
+
62
+ ### [Event Categories](http://developer.eventbrite.com/docs/event-categories/)
63
+
64
+ ```ruby
65
+ Eventbrite::Category.all
66
+ ```
67
+
68
+ ### [Event Details](http://developer.eventbrite.com/docs/event-details/)
69
+
70
+ ```ruby
71
+ Eventbrite::Event.retrieve('event_id')
72
+ ```
73
+
74
+ ### [Event Attendees](http://developer.eventbrite.com/docs/event-attendees/)
75
+
76
+ ```ruby
77
+ # For supported parameters, check out the link above.
78
+ # Also, the parameter `event_id` is required.
79
+ Eventbrite::Attendee.all({ event_id: 'event_id' })
80
+ ```
81
+
82
+ ### [Event Attendees’ Details](http://developer.eventbrite.com/docs/event-attendees-details/)
83
+
84
+ ```ruby
85
+ Eventbrite::Attendee.retrieve('event_id', 'attendee_id')
86
+ ```
87
+
88
+ ### [Event Orders](http://developer.eventbrite.com/docs/event-orders/)
89
+
90
+ ```ruby
91
+ # For supported parameters, check out the link above.
92
+ # Also, the parameter `event_id` is required.
93
+ Eventbrite::Order.all({ event_id: 'event_id' })
94
+ ```
95
+
96
+ ### [Event Discounts](http://developer.eventbrite.com/docs/event-discounts/)
97
+
98
+ ```ruby
99
+ # For supported parameters, check out the link above.
100
+ # Also, the parameter `event_id` is required.
101
+ Eventbrite::Discount.all({ event_id: 'event_id' })
102
+ ```
103
+
104
+ ### [Event Access Codes](http://developer.eventbrite.com/doc/event-access-codes/)
105
+
106
+ ```ruby
107
+ # For supported parameters, check out the link above.
108
+ # Also, the parameter `event_id` is required.
109
+ Eventbrite::AccessCode.all({ event_id: 'event_id' })
110
+ ```
111
+
112
+ ### [Event Transfers](http://developer.eventbrite.com/docs/event-transfers/)
113
+
114
+ ```ruby
115
+ # The parameter `event_id` is required.
116
+ Eventbrite::Transfer.all({ event_id: 'event_id' })
117
+ ```
118
+
119
+ ### [Event Teams](http://developer.eventbrite.com/docs/event-teams/)
120
+
121
+ ```ruby
122
+ # The parameter `event_id` is required.
123
+ Eventbrite::Team.all({ event_id: 'event_id' })
124
+ ```
125
+
126
+ ### [Event Teams Details](http://developer.eventbrite.com/docs/event-teams-details/)
127
+
128
+ ```ruby
129
+ Eventbrite::Team.retrieve('event_id', 'team_id')
130
+ ```
131
+
132
+ ### [Event Teams’ Attendees](http://developer.eventbrite.com/docs/event-teams-attendees/)
133
+
134
+ ```ruby
135
+ Eventbrite::Team.attendees('event_id', 'team_id')
136
+ ```
137
+
138
+ ### [User Details](http://developer.eventbrite.com/docs/user-details/)
139
+
140
+ ```ruby
141
+ Eventbrite::User.retrieve('user_id')
142
+ ```
143
+
144
+ ### [User Orders](http://developer.eventbrite.com/docs/user-orders/)
145
+
146
+ ```ruby
147
+ # The parameter `user_id` is required.
148
+ Eventbrite::User.orders({ user_id: 'user_id' })
149
+ ```
150
+
151
+ ### [User Owned Events](http://developer.eventbrite.com/docs/user-owned-events/)
152
+
153
+ ```ruby
154
+ # For supported parameters, check out the link above.
155
+ # Also, the parameter `user_id` is required.
156
+ Eventbrite::User.owned_events({ user_id: 'user_id' })
157
+ ```
158
+
159
+ ### [User Owned Events’ Orders](http://developer.eventbrite.com/docs/user-owned-events-orders/)
160
+
161
+ ```ruby
162
+ # For supported parameters, check out the link above.
163
+ # Also, the parameter `user_id` is required.
164
+ Eventbrite::User.owned_event_orders({ user_id: 'user_id' })
165
+ ```
166
+
167
+ ### [User Owned Event’s Attendees](http://developer.eventbrite.com/docs/user-owned-events-attendees/)
168
+
169
+ ```ruby
170
+ # For supported parameters, check out the link above.
171
+ # Also, the parameter `user_id` is required.
172
+ Eventbrite::User.owned_event_attendees({ user_id: 'user_id' })
173
+ ```
174
+
175
+ ### [User Venues](http://developer.eventbrite.com/docs/user-venues/)
176
+
177
+ ```ruby
178
+ # The parameter `user_id` is required.
179
+ Eventbrite::User.venues({ user_id: 'user_id' })
180
+ ```
181
+
182
+ ### [User Organizers](http://developer.eventbrite.com/docs/user-organizers/)
183
+
184
+ ```ruby
185
+ # The parameter `user_id` is required.
186
+ Eventbrite::User.organizers({ user_id: 'user_id' })
187
+ ```
188
+
189
+ ### [Order Details](http://developer.eventbrite.com/docs/order-details/)
190
+
191
+ ```ruby
192
+ Eventbrite::Order.retrieve('order_id')
193
+ ```
194
+
195
+ ### [Contact Lists](http://developer.eventbrite.com/docs/contact-lists/)
196
+
197
+ ```ruby
198
+ # For supported parameters, check out the link above.
199
+ # Also, the parameter `user_id` is required.
200
+ Eventbrite::ContactList.all({ user_id: 'user_id' })
201
+ ```
202
+
203
+ ### [Contact List Details](http://developer.eventbrite.com/docs/contact-list-details/)
204
+
205
+ ```ruby
206
+ Eventbrite::ContactList.retrieve('user_id', 'contact_list_id')
207
+ ```
208
+
209
+ ## Todo
210
+
211
+ * Event Atteedees' Details API should support parameters
212
+ * POST/UPDATE/DELETE request for the API
213
+ * Support for chained method
214
+
215
+ ## Thanks
216
+
217
+ * [Stripe Rubygem](https://github.com/stripe/stripe-ruby)
218
+
219
+ ## Contributing
220
+
221
+ 1. Fork it
222
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
223
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
224
+ 4. Push to the branch (`git push origin my-new-feature`)
225
+ 5. Create new Pull Request
data/Rakefile ADDED
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+
3
+ desc "Open an irb session preloaded with this library"
4
+ task :console do
5
+ sh "irb -rubygems -I lib -r eventbrite.rb"
6
+ end
@@ -0,0 +1,27 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'eventbrite/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "eventbrite"
8
+ spec.version = Eventbrite::VERSION
9
+ spec.authors = ["Teng Siong Ong"]
10
+ spec.email = ["hi@signwithenvoy.com"]
11
+ spec.description = %q{This gem provides access to the Eventbrite V3 api. We are not affiliated with Eventbrite.}
12
+ spec.summary = %q{API access to Eventbrite V3}
13
+ spec.homepage = ""
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files`.split($/)
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_dependency "rest-client", "~> 1.4"
22
+ spec.add_dependency "hashie", "~> 3.0"
23
+
24
+ spec.add_development_dependency "bundler", "~> 1.3"
25
+ spec.add_development_dependency "byebug"
26
+ spec.add_development_dependency "rake"
27
+ end
data/lib/eventbrite.rb ADDED
@@ -0,0 +1,136 @@
1
+ require 'rest_client'
2
+ require 'hashie'
3
+
4
+ # Version
5
+ require 'eventbrite/version'
6
+
7
+ # Util
8
+ require 'eventbrite/util'
9
+
10
+ # Base
11
+ require 'eventbrite/eventbrite_object'
12
+ require 'eventbrite/api_resource'
13
+ require 'eventbrite/api_array_resource'
14
+
15
+ # Resources
16
+ require 'eventbrite/resources/event'
17
+ require 'eventbrite/resources/category'
18
+ require 'eventbrite/resources/user'
19
+ require 'eventbrite/resources/attendee'
20
+ require 'eventbrite/resources/order'
21
+ require 'eventbrite/resources/discount'
22
+ require 'eventbrite/resources/access_code'
23
+ require 'eventbrite/resources/transfer'
24
+ require 'eventbrite/resources/team'
25
+ require 'eventbrite/resources/contact_list'
26
+
27
+ # Errors
28
+ require 'eventbrite/errors/eventbrite_error'
29
+ require 'eventbrite/errors/api_error'
30
+ require 'eventbrite/errors/authentication_error'
31
+ require 'eventbrite/errors/invalid_request_error'
32
+
33
+ module Eventbrite
34
+ @api_base = 'https://www.eventbriteapi.com'
35
+ @api_version = 'v3'
36
+
37
+ class << self
38
+ attr_accessor :api_base, :api_version, :token
39
+ end
40
+
41
+ def self.api_url(url='')
42
+ "#{@api_base}/#{api_version}#{url}"
43
+ end
44
+
45
+ def self.request(method, url, token, params={})
46
+ unless token ||= @token
47
+ raise AuthenticationError.new('No access token provided. Set your token using "Eventbrite.token = <access-token>"."')
48
+ end
49
+
50
+ url = api_url(url)
51
+
52
+ case method.to_s.downcase.to_sym
53
+ when :get
54
+ # Make params into GET parameters
55
+ url += "#{URI.parse(url).query ? '&' : '?'}#{uri_encode(params)}" if params && params.any?
56
+ payload = nil
57
+ else
58
+ payload = uri_encode(params)
59
+ end
60
+
61
+ request_opts = {
62
+ headers: request_headers(token),
63
+ method: method,
64
+ open_timeout: 30,
65
+ payload: payload,
66
+ url: url,
67
+ timeout: 120
68
+ }
69
+
70
+ begin
71
+ response = execute_request(request_opts)
72
+ rescue RestClient::ExceptionWithResponse => e
73
+ if rcode = e.http_code and rbody = e.http_body
74
+ handle_api_error(rcode, rbody)
75
+ else
76
+ raise
77
+ end
78
+ end
79
+
80
+ [parse(response), token]
81
+ end
82
+
83
+ private
84
+
85
+ def self.uri_encode(params)
86
+ Util.flatten_params(params).map { |k,v| "#{k}=#{Util.url_encode(v)}" }.join('&')
87
+ end
88
+
89
+ def self.request_headers(token)
90
+ headers = {
91
+ user_agent: "Eventbrite RubyBindings/#{Eventbrite::VERSION}",
92
+ authorization: "Bearer #{token}"
93
+ }
94
+
95
+ headers
96
+ end
97
+
98
+ def self.execute_request(opts)
99
+ RestClient::Request.execute(opts)
100
+ end
101
+
102
+ def self.parse(response)
103
+ begin
104
+ # Would use :symbolize_names => true, but apparently there is
105
+ # some library out there that makes symbolize_names not work.
106
+ response = JSON.parse(response.body)
107
+ rescue JSON::ParserError
108
+ raise general_api_error(response.code, response.body)
109
+ end
110
+
111
+ Util.symbolize_names(response)
112
+ end
113
+
114
+ def self.general_api_error(rcode, rbody)
115
+ APIError.new("Invalid response object from API: #{rbody.inspect} (HTTP response code was #{rcode})", rcode, rbody)
116
+ end
117
+
118
+ def self.handle_api_error(rcode, rbody)
119
+ begin
120
+ error = JSON.parse(rbody)
121
+ error = Util.symbolize_names(error)
122
+ rescue JSON::ParserError
123
+ raise general_api_error(rcode, rbody)
124
+ end
125
+
126
+ case rcode
127
+ when 400, 404
128
+ # TODO: fix this
129
+ raise InvalidRequestError.new(error[:error_description], rcode, rbody, error)
130
+ when 401
131
+ raise AuthenticationError.new(error[:error_description], rcode, rbody, error)
132
+ else
133
+ raise APIError.new(error[:error_description], rcode, rbody, error)
134
+ end
135
+ end
136
+ end
@@ -0,0 +1,18 @@
1
+ module Eventbrite
2
+ class APIArrayResource < APIResource
3
+ def self.all(params={}, token=nil)
4
+ unless event_id = params.delete(:event_id)
5
+ raise InvalidRequestError.new('No event_id provided.')
6
+ end
7
+
8
+ response, token = Eventbrite.request(:get, self.all_url(event_id), token, params)
9
+ Util.convert_to_eventbrite_object(response, token)
10
+ end
11
+
12
+ private
13
+
14
+ def self.all_url(event_id)
15
+ "/events/#{event_id}/#{CGI.escape(class_name.downcase)}s"
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,34 @@
1
+ module Eventbrite
2
+ class APIResource < EventbriteObject
3
+ def self.class_name
4
+ name_without_namespace = self.name.split('::')[-1]
5
+ name_without_namespace.gsub(/([^\^])([A-Z])/,'\1_\2').downcase
6
+ end
7
+
8
+ def self.url
9
+ if self == APIResource
10
+ raise NotImplementedError.new('APIResource is an abstract class. You should perform actions on its subclasses (Event, Attendee, etc.)')
11
+ end
12
+ "/#{CGI.escape(class_name.downcase)}s"
13
+ end
14
+
15
+ def url
16
+ unless id = self.id
17
+ raise InvalidRequestError.new("Could not determine which URL to request: #{self.class} instance has invalid ID: #{id.inspect}")
18
+ end
19
+ "#{self.class.url}/#{CGI.escape(id)}"
20
+ end
21
+
22
+ def refresh
23
+ response, token = Eventbrite.request(:get, url, @token, @retrieve_options)
24
+ refresh_from(response, token)
25
+ self
26
+ end
27
+
28
+ def self.retrieve(id, token=nil)
29
+ instance = self.new(id, token)
30
+ instance.refresh
31
+ instance
32
+ end
33
+ end
34
+ end
@@ -0,0 +1,4 @@
1
+ module Eventbrite
2
+ class APIError < EventbriteError
3
+ end
4
+ end
@@ -0,0 +1,4 @@
1
+ module Eventbrite
2
+ class AuthenticationError < EventbriteError
3
+ end
4
+ end
@@ -0,0 +1,20 @@
1
+ module Eventbrite
2
+ class EventbriteError < StandardError
3
+ attr_reader :message
4
+ attr_reader :http_status
5
+ attr_reader :http_body
6
+ attr_reader :json_body
7
+
8
+ def initialize(message=nil, http_status=nil, http_body=nil, json_body=nil)
9
+ @message = message
10
+ @http_status = http_status
11
+ @http_body = http_body
12
+ @json_body = json_body
13
+ end
14
+
15
+ def to_s
16
+ status_string = @http_status.nil? ? "" : "(Status #{@http_status}) "
17
+ "#{status_string}#{@message}"
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,4 @@
1
+ module Eventbrite
2
+ class InvalidRequestError < EventbriteError
3
+ end
4
+ end
@@ -0,0 +1,171 @@
1
+ module Eventbrite
2
+ class EventbriteObject
3
+ include Enumerable
4
+
5
+ attr_accessor :token
6
+ @@permanent_attributes = Set.new([:id, :token])
7
+
8
+ # The default :id method is deprecated and isn't useful to us
9
+ if method_defined?(:id)
10
+ undef :id
11
+ end
12
+
13
+ def initialize(id=nil, token=nil)
14
+ # parameter overloading!
15
+ if id.kind_of?(Hash)
16
+ @retrieve_options = id.dup
17
+ @retrieve_options.delete(:id)
18
+ id = id[:id]
19
+ else
20
+ @retrieve_options = {}
21
+ end
22
+
23
+ @token = token
24
+ @values = {}
25
+ # This really belongs in APIResource, but not putting it there allows us
26
+ # to have a unified inspect method
27
+ @unsaved_values = Set.new
28
+ @transient_values = Set.new
29
+ self.id = id if id
30
+ end
31
+
32
+ def self.construct_from(values, token=nil)
33
+ obj = self.new(values[:id], token)
34
+ obj.refresh_from(values, token)
35
+ obj
36
+ end
37
+
38
+ def to_s(*args)
39
+ JSON.pretty_generate(@values)
40
+ end
41
+
42
+ def inspect()
43
+ id_string = (self.respond_to?(:id) && !self.id.nil?) ? " id=#{self.id}" : ""
44
+ "#<#{self.class}:0x#{self.object_id.to_s(16)}#{id_string}> JSON: " + JSON.pretty_generate(@values)
45
+ end
46
+
47
+ def paginated?
48
+ self.respond_to?(:pagination)
49
+ end
50
+
51
+ def next?
52
+ paginated? && (self.pagination.page_number < self.pagination.page_count)
53
+ end
54
+
55
+ def next_page
56
+ self.pagination.page_number + 1
57
+ end
58
+
59
+ def refresh_from(values, token, partial=false)
60
+ @token = token
61
+
62
+ removed = partial ? Set.new : Set.new(@values.keys - values.keys)
63
+ added = Set.new(values.keys - @values.keys)
64
+ # Wipe old state before setting new. This is useful for e.g. updating a
65
+ # customer, where there is no persistent card parameter. Mark those values
66
+ # which don't persist as transient
67
+
68
+ instance_eval do
69
+ remove_accessors(removed)
70
+ add_accessors(added)
71
+ end
72
+ removed.each do |k|
73
+ @values.delete(k)
74
+ @transient_values.add(k)
75
+ @unsaved_values.delete(k)
76
+ end
77
+ values.each do |k, v|
78
+ # TODO: fix this
79
+ @values[k] = Util.convert_to_eventbrite_object(v, token, k)
80
+ @transient_values.delete(k)
81
+ @unsaved_values.delete(k)
82
+ end
83
+ end
84
+
85
+ def [](k)
86
+ @values[k.to_sym]
87
+ end
88
+
89
+ def []=(k, v)
90
+ send(:"#{k}=", v)
91
+ end
92
+
93
+ def keys
94
+ @values.keys
95
+ end
96
+
97
+ def values
98
+ @values.values
99
+ end
100
+
101
+ def to_json(*a)
102
+ JSON.generate(@values)
103
+ end
104
+
105
+ def as_json(*a)
106
+ @values.as_json(*a)
107
+ end
108
+
109
+ def to_hash
110
+ @values
111
+ end
112
+
113
+ def each(&blk)
114
+ @values.each(&blk)
115
+ end
116
+
117
+ protected
118
+
119
+ def metaclass
120
+ class << self; self; end
121
+ end
122
+
123
+ def remove_accessors(keys)
124
+ metaclass.instance_eval do
125
+ keys.each do |k|
126
+ next if @@permanent_attributes.include?(k)
127
+ k_eq = :"#{k}="
128
+ remove_method(k) if method_defined?(k)
129
+ remove_method(k_eq) if method_defined?(k_eq)
130
+ end
131
+ end
132
+ end
133
+
134
+ def add_accessors(keys)
135
+ metaclass.instance_eval do
136
+ keys.each do |k|
137
+ next if @@permanent_attributes.include?(k)
138
+ k_eq = :"#{k}="
139
+ define_method(k) { @values[k] }
140
+ define_method(k_eq) do |v|
141
+ @values[k] = v
142
+ @unsaved_values.add(k)
143
+ end
144
+ end
145
+ end
146
+ end
147
+
148
+ def method_missing(name, *args)
149
+ # TODO: only allow setting in updateable classes.
150
+ if name.to_s.end_with?('=')
151
+ attr = name.to_s[0...-1].to_sym
152
+ @values[attr] = args[0]
153
+ @unsaved_values.add(attr)
154
+ add_accessors([attr])
155
+ return
156
+ else
157
+ return @values[name] if @values.has_key?(name)
158
+ end
159
+
160
+ begin
161
+ super
162
+ rescue NoMethodError => e
163
+ if @transient_values.include?(name)
164
+ raise NoMethodError.new(e.message + ". HINT: The '#{name}' attribute was set in the past, however. It was then wiped when refreshing the object with the result returned by Eventbrite's API, probably as a result of a save(). The attributes currently available on this object are: #{@values.keys.join(', ')}")
165
+ else
166
+ raise
167
+ end
168
+ end
169
+ end
170
+ end
171
+ end
@@ -0,0 +1,4 @@
1
+ module Eventbrite
2
+ class AccessCode < APIArrayResource
3
+ end
4
+ end
@@ -0,0 +1,14 @@
1
+ module Eventbrite
2
+ class Attendee < APIArrayResource
3
+ def self.retrieve(event_id, id, token=nil)
4
+ instance = self.new(id, token)
5
+ instance.event_id = event_id
6
+ instance.refresh
7
+ instance
8
+ end
9
+
10
+ def url
11
+ "/events/#{CGI.escape(self.event_id)}#{self.class.url}/#{CGI.escape(self.id)}"
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,12 @@
1
+ module Eventbrite
2
+ class Category < APIResource
3
+ def self.url
4
+ "/categories"
5
+ end
6
+
7
+ def self.all(params={}, token=nil)
8
+ response, token = Eventbrite.request(:get, url, token, params)
9
+ Util.convert_to_eventbrite_object(response, token)
10
+ end
11
+ end
12
+ end
@@ -0,0 +1,29 @@
1
+ module Eventbrite
2
+ class ContactList < APIResource
3
+ def self.all(params={}, token=nil)
4
+ unless user_id = params.delete(:user_id)
5
+ raise InvalidRequestError.new('No user_id provided.')
6
+ end
7
+
8
+ response, token = Eventbrite.request(:get, self.all_url(user_id), token, params)
9
+ Util.convert_to_eventbrite_object(response, token)
10
+ end
11
+
12
+ def self.retrieve(user_id, id, token=nil)
13
+ instance = self.new(id, token)
14
+ instance.user_id = user_id
15
+ instance.refresh
16
+ instance
17
+ end
18
+
19
+ def url
20
+ "/users/#{CGI.escape(self.user_id)}#{self.class.url}/#{CGI.escape(self.id)}"
21
+ end
22
+
23
+ private
24
+
25
+ def self.all_url(user_id)
26
+ "/users/#{user_id}/#{CGI.escape(class_name.downcase)}s"
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,4 @@
1
+ module Eventbrite
2
+ class Discount < APIArrayResource
3
+ end
4
+ end
@@ -0,0 +1,14 @@
1
+ module Eventbrite
2
+ class Event < APIResource
3
+ def self.search(params={}, token=nil)
4
+ response, token = Eventbrite.request(:get, self.search_url, token, params)
5
+ Util.convert_to_eventbrite_object(response, token)
6
+ end
7
+
8
+ private
9
+
10
+ def self.search_url
11
+ url + '/search'
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,4 @@
1
+ module Eventbrite
2
+ class Order < APIArrayResource
3
+ end
4
+ end
@@ -0,0 +1,25 @@
1
+ module Eventbrite
2
+ class Team < APIArrayResource
3
+ def self.retrieve(event_id, id, token=nil)
4
+ instance = self.new(id, token)
5
+ instance.event_id = event_id
6
+ instance.refresh
7
+ instance
8
+ end
9
+
10
+ def self.attendees(event_id, id, token=nil)
11
+ response, token = Eventbrite.request(:get, self.attendees_url(event_id, id), token, params)
12
+ Util.convert_to_eventbrite_object(response, token)
13
+ end
14
+
15
+ def url
16
+ "/events/#{CGI.escape(self.event_id)}#{self.class.url}/#{CGI.escape(self.id)}"
17
+ end
18
+
19
+ private
20
+
21
+ def self.attendees_url(event_id, id)
22
+ "/events/#{CGI.escape(event_id)}#{url}/#{CGI.escape(id)}/attendees"
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,4 @@
1
+ module Eventbrite
2
+ class Transfer < APIArrayResource
3
+ end
4
+ end
@@ -0,0 +1,20 @@
1
+ module Eventbrite
2
+ class User < APIResource
3
+ ['orders', 'owned_events', 'owned_event_orders', 'owned_event_attendees', 'venues', 'organizers'].each do |m|
4
+ define_singleton_method m do |params={}, token=nil|
5
+ unless user_id = params.delete(:user_id)
6
+ raise InvalidRequestError.new('No user_id provided.')
7
+ end
8
+
9
+ response, token = Eventbrite.request(:get, self.send("#{m}_url", user_id), token, params)
10
+ Util.convert_to_eventbrite_object(response, token)
11
+ end
12
+
13
+ private
14
+
15
+ define_singleton_method "#{m}_url" do |user_id|
16
+ "/#{CGI.escape(class_name.downcase)}s/#{user_id}/#{m}"
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,93 @@
1
+ module Eventbrite
2
+ module Util
3
+ def self.object_classes
4
+ @object_classes ||= {
5
+ events: Event,
6
+ categories: Category,
7
+ attendees: Attendee,
8
+ orders: Order,
9
+ discouns: Discount,
10
+ access_codes: AccessCode,
11
+ transfers: Transfer,
12
+ teams: Team
13
+ # 'balance' => Balance,
14
+ # 'balance_transaction' => BalanceTransaction,
15
+ # 'charge' => Charge,
16
+ # 'customer' => Customer,
17
+ # 'invoiceitem' => InvoiceItem,
18
+ # 'invoice' => Invoice,
19
+ # 'plan' => Plan,
20
+ # 'coupon' => Coupon,
21
+ # 'event' => Event,
22
+ # 'transfer' => Transfer,
23
+ # 'recipient' => Recipient,
24
+ # 'card' => Card,
25
+ # 'subscription' => Subscription,
26
+ # 'list' => ListObject,
27
+ # 'application_fee' => ApplicationFee
28
+ }
29
+ end
30
+
31
+ def self.convert_to_eventbrite_object(resp, token, parent=nil)
32
+ # TODO: fix this
33
+ case resp
34
+ when Array
35
+ resp.map { |i| convert_to_eventbrite_object(i, token, parent) }
36
+ when Hash
37
+ # Try converting to a known object class. If none available, fall back to generic EventbriteObject
38
+ object_classes.fetch(parent, EventbriteObject).construct_from(resp, token)
39
+ else
40
+ resp
41
+ end
42
+ end
43
+
44
+ def self.symbolize_names(object)
45
+ case object
46
+ when Hash
47
+ new = {}
48
+ object.each do |key, value|
49
+ key = (key.to_sym rescue key) || key
50
+ new[key] = symbolize_names(value)
51
+ end
52
+ new
53
+ when Array
54
+ object.map { |value| symbolize_names(value) }
55
+ else
56
+ object
57
+ end
58
+ end
59
+
60
+ def self.url_encode(key)
61
+ URI.escape(key.to_s, Regexp.new("[^#{URI::PATTERN::UNRESERVED}]"))
62
+ end
63
+
64
+ def self.flatten_params(params, parent_key=nil)
65
+ result = []
66
+ params.each do |key, value|
67
+ calculated_key = parent_key ? "#{parent_key}[#{url_encode(key)}]" : url_encode(key)
68
+ if value.is_a?(Hash)
69
+ result += flatten_params(value, calculated_key)
70
+ elsif value.is_a?(Array)
71
+ result += flatten_params_array(value, calculated_key)
72
+ else
73
+ result << [calculated_key, value]
74
+ end
75
+ end
76
+ result
77
+ end
78
+
79
+ def self.flatten_params_array(value, calculated_key)
80
+ result = []
81
+ value.each do |elem|
82
+ if elem.is_a?(Hash)
83
+ result += flatten_params(elem, calculated_key)
84
+ elsif elem.is_a?(Array)
85
+ result += flatten_params_array(elem, calculated_key)
86
+ else
87
+ result << ["#{calculated_key}[]", elem]
88
+ end
89
+ end
90
+ result
91
+ end
92
+ end
93
+ end
@@ -0,0 +1,3 @@
1
+ module Eventbrite
2
+ VERSION = "0.0.1"
3
+ end
metadata ADDED
@@ -0,0 +1,141 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: eventbrite
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Teng Siong Ong
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-02-12 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rest-client
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.4'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.4'
27
+ - !ruby/object:Gem::Dependency
28
+ name: hashie
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '3.0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '3.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: bundler
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '1.3'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '1.3'
55
+ - !ruby/object:Gem::Dependency
56
+ name: byebug
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rake
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ description: This gem provides access to the Eventbrite V3 api. We are not affiliated
84
+ with Eventbrite.
85
+ email:
86
+ - hi@signwithenvoy.com
87
+ executables: []
88
+ extensions: []
89
+ extra_rdoc_files: []
90
+ files:
91
+ - ".gitignore"
92
+ - Gemfile
93
+ - LICENSE.txt
94
+ - README.md
95
+ - Rakefile
96
+ - eventbrite.gemspec
97
+ - lib/eventbrite.rb
98
+ - lib/eventbrite/api_array_resource.rb
99
+ - lib/eventbrite/api_resource.rb
100
+ - lib/eventbrite/errors/api_error.rb
101
+ - lib/eventbrite/errors/authentication_error.rb
102
+ - lib/eventbrite/errors/eventbrite_error.rb
103
+ - lib/eventbrite/errors/invalid_request_error.rb
104
+ - lib/eventbrite/eventbrite_object.rb
105
+ - lib/eventbrite/resources/access_code.rb
106
+ - lib/eventbrite/resources/attendee.rb
107
+ - lib/eventbrite/resources/category.rb
108
+ - lib/eventbrite/resources/contact_list.rb
109
+ - lib/eventbrite/resources/discount.rb
110
+ - lib/eventbrite/resources/event.rb
111
+ - lib/eventbrite/resources/order.rb
112
+ - lib/eventbrite/resources/team.rb
113
+ - lib/eventbrite/resources/transfer.rb
114
+ - lib/eventbrite/resources/user.rb
115
+ - lib/eventbrite/util.rb
116
+ - lib/eventbrite/version.rb
117
+ homepage: ''
118
+ licenses:
119
+ - MIT
120
+ metadata: {}
121
+ post_install_message:
122
+ rdoc_options: []
123
+ require_paths:
124
+ - lib
125
+ required_ruby_version: !ruby/object:Gem::Requirement
126
+ requirements:
127
+ - - ">="
128
+ - !ruby/object:Gem::Version
129
+ version: '0'
130
+ required_rubygems_version: !ruby/object:Gem::Requirement
131
+ requirements:
132
+ - - ">="
133
+ - !ruby/object:Gem::Version
134
+ version: '0'
135
+ requirements: []
136
+ rubyforge_project:
137
+ rubygems_version: 2.4.5
138
+ signing_key:
139
+ specification_version: 4
140
+ summary: API access to Eventbrite V3
141
+ test_files: []