From 1a0fe646f92ec47ce73e7804897cc2cb939490dd Mon Sep 17 00:00:00 2001 From: cfbonner Date: Tue, 14 Jul 2020 11:57:34 +0100 Subject: [PATCH] Add organization API --- README.md | 75 ++++++++++++++++++++++-- lib/eventbrite.rb | 1 + lib/eventbrite/resources/organization.rb | 20 +++++++ lib/eventbrite/resources/user.rb | 2 +- 4 files changed, 91 insertions(+), 7 deletions(-) create mode 100644 lib/eventbrite/resources/organization.rb diff --git a/README.md b/README.md index 651fe73..8300e35 100644 --- a/README.md +++ b/README.md @@ -158,14 +158,14 @@ Eventbrite::Team.attendees('event_id', 'team_id') Eventbrite::User.retrieve('user_id') ``` -### [User Orders](http://developer.eventbrite.com/docs/user-orders/) +### [User Orders (DEPRECATED)](https://www.eventbrite.com/platform/docs/changelog) ```ruby # The parameter `user_id` is required. Eventbrite::User.orders({ user_id: 'user_id' }) ``` -### [User Owned Events](http://developer.eventbrite.com/docs/user-owned-events/) +### [User Owned Events (DEPRECATED)](https://www.eventbrite.com/platform/docs/changelog) ```ruby # For supported parameters, check out the link above. @@ -173,7 +173,7 @@ Eventbrite::User.orders({ user_id: 'user_id' }) Eventbrite::User.owned_events({ user_id: 'user_id' }) ``` -### [User Owned Events’ Orders](http://developer.eventbrite.com/docs/user-owned-events-orders/) +### [User Owned Events’ Orders (DEPRECATED)](https://www.eventbrite.com/platform/docs/changelog) ```ruby # For supported parameters, check out the link above. @@ -181,7 +181,7 @@ Eventbrite::User.owned_events({ user_id: 'user_id' }) Eventbrite::User.owned_event_orders({ user_id: 'user_id' }) ``` -### [User Owned Event’s Attendees](http://developer.eventbrite.com/docs/user-owned-events-attendees/) +### [User Owned Event’s Attendees (DEPRECATED)](https://www.eventbrite.com/platform/docs/changelog) ```ruby # For supported parameters, check out the link above. @@ -189,7 +189,7 @@ Eventbrite::User.owned_event_orders({ user_id: 'user_id' }) Eventbrite::User.owned_event_attendees({ user_id: 'user_id' }) ``` -### [User Venues](http://developer.eventbrite.com/docs/user-venues/) +### [User Venues (DEPRECATED)](https://www.eventbrite.com/platform/docs/changelog) ```ruby # Retrieve a User’s Venues @@ -199,11 +199,73 @@ Eventbrite::User.venues({ user_id: 'user_id' }) Eventbrite::Venue.retrieve('venue_id') ``` -### [User Organizers](http://developer.eventbrite.com/docs/user-organizers/) +### [User Organizers (DEPRECATED)](https://www.eventbrite.com/platform/docs/changelog) ```ruby # The parameter `user_id` is required. Eventbrite::User.organizers({ user_id: 'user_id' }) +``` + + ### [User Organizations](https://www.eventbrite.com/platform/api#/reference/organization/list-your-organizations/list-your-organizations) + +```ruby +# Retrieve an User’s Organizations +# You will need the users organization ID to retrieve resources from the organization endpoints. +# You can use 'me' as a user_id to retrieve your organizations. +Eventbrite::User.organizations({ user_id: 'user_id' }) +``` + +### [Organization Events](https://www.eventbrite.com/platform/api#/reference/event/update/list-events-by-organization) + +```ruby +# Retrieve an Organization’s Events +# For supported parameters, check out the link above. +# Also, the parameter `organization_id` is required. +Eventbrite::Organization.events({ organization_id: 'organization_id' }) +``` + +### [Organization Orders](https://www.eventbrite.com/platform/api#/reference/order/retrieve/list-orders-by-organization-id) + +```ruby +# Retrieve an Organization’s Orders +# For supported parameters, check out the link above. +# Also, the parameter `organization_id` is required. +Eventbrite::Organization.orders({ organization_id: 'organization_id' }) +``` + +### [Organization Attendees](https://www.eventbrite.com/platform/api#/reference/attendee/list-attendees-by-organization) + +```ruby +# Retrieve an Organization’s Attendees +# For supported parameters, check out the link above. +# Also, the parameter `organization_id` is required. +Eventbrite::Organization.attendees({ organization_id: 'organization_id' }) +``` + +### [Organization Venues](https://www.eventbrite.com/platform/api#/reference/venue/list/list-venues-by-organization) + +```ruby +# Retrieve an Organization’s Venues +# The parameter `organization_id` is required. +Eventbrite::Organization.venues({ organization_id: 'organization_id' }) +# Retrieve a Venue +Eventbrite::Venue.retrieve('venue_id') +``` + +### [Organization Webhooks](https://www.eventbrite.com/platform/api#/reference/webhooks/list/list-webhook-by-organization-id) + +```ruby +# Retrieve an Organization’s Webhooks +# The parameter `organization_id` is required. +Eventbrite::Organization.webhooks({ organization_id: 'organization_id' }) +``` + +### [Organization Organizers](https://www.eventbrite.com/platform/docs/changelog) + +```ruby +# Retrieve an Organization’s Organizers +# The parameter `organization_id` is required. +Eventbrite::Organization.organizers({ organization_id: 'organization_id' }) ``` ### [Order Details](http://developer.eventbrite.com/docs/order-details/) @@ -271,3 +333,4 @@ Eventbrite::User.owned_events({ user_id: 'user_id', expand: 'organizer,venue' }) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Create new Pull Request + diff --git a/lib/eventbrite.rb b/lib/eventbrite.rb index 6876939..9fd63bb 100644 --- a/lib/eventbrite.rb +++ b/lib/eventbrite.rb @@ -27,6 +27,7 @@ require 'eventbrite/resources/contact_list' require 'eventbrite/resources/venue' require 'eventbrite/resources/webhook' +require 'eventbrite/resources/organization' # Errors require 'eventbrite/errors/eventbrite_error' diff --git a/lib/eventbrite/resources/organization.rb b/lib/eventbrite/resources/organization.rb new file mode 100644 index 0000000..0e16d55 --- /dev/null +++ b/lib/eventbrite/resources/organization.rb @@ -0,0 +1,20 @@ +module Eventbrite + class Organization < APIResource + ['attendees', 'events', 'orders', 'organizers', 'venues', 'webhooks'].each do |m| + define_singleton_method m do |params={}, token=nil| + unless organization_id = params.delete(:organization_id) + raise InvalidRequestError.new('No organization_id provided.') + end + + response, token = Eventbrite.request(:get, self.send("#{m}_url", organization_id), token, params) + Util.convert_to_eventbrite_object(response, token) + end + + private + + define_singleton_method "#{m}_url" do |organization_id| + "/#{CGI.escape(class_name.downcase)}s/#{organization_id}/#{m}" + end + end + end +end diff --git a/lib/eventbrite/resources/user.rb b/lib/eventbrite/resources/user.rb index fdd10b2..ef88eca 100644 --- a/lib/eventbrite/resources/user.rb +++ b/lib/eventbrite/resources/user.rb @@ -1,6 +1,6 @@ module Eventbrite class User < APIResource - ['orders', 'owned_events', 'owned_event_orders', 'owned_event_attendees', 'venues', 'organizers'].each do |m| + ['orders', 'owned_events', 'owned_event_orders', 'owned_event_attendees', 'venues', 'organizers', 'organizations'].each do |m| define_singleton_method m do |params={}, token=nil| unless user_id = params.delete(:user_id) raise InvalidRequestError.new('No user_id provided.')