spotify-api-sdk 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (178) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +30 -0
  3. data/README.md +107 -0
  4. data/lib/spotify_web_api/api_helper.rb +10 -0
  5. data/lib/spotify_web_api/client.rb +154 -0
  6. data/lib/spotify_web_api/configuration.rb +180 -0
  7. data/lib/spotify_web_api/controllers/albums_controller.rb +295 -0
  8. data/lib/spotify_web_api/controllers/artists_controller.rb +187 -0
  9. data/lib/spotify_web_api/controllers/audiobooks_controller.rb +258 -0
  10. data/lib/spotify_web_api/controllers/base_controller.rb +66 -0
  11. data/lib/spotify_web_api/controllers/categories_controller.rb +83 -0
  12. data/lib/spotify_web_api/controllers/chapters_controller.rb +82 -0
  13. data/lib/spotify_web_api/controllers/episodes_controller.rb +239 -0
  14. data/lib/spotify_web_api/controllers/genres_controller.rb +39 -0
  15. data/lib/spotify_web_api/controllers/markets_controller.rb +38 -0
  16. data/lib/spotify_web_api/controllers/o_auth_authorization_controller.rb +82 -0
  17. data/lib/spotify_web_api/controllers/player_controller.rb +509 -0
  18. data/lib/spotify_web_api/controllers/playlists_controller.rb +521 -0
  19. data/lib/spotify_web_api/controllers/search_controller.rb +60 -0
  20. data/lib/spotify_web_api/controllers/shows_controller.rb +261 -0
  21. data/lib/spotify_web_api/controllers/tracks_controller.rb +491 -0
  22. data/lib/spotify_web_api/controllers/users_controller.rb +396 -0
  23. data/lib/spotify_web_api/exceptions/api_exception.rb +10 -0
  24. data/lib/spotify_web_api/exceptions/bad_request_exception.rb +32 -0
  25. data/lib/spotify_web_api/exceptions/forbidden_exception.rb +32 -0
  26. data/lib/spotify_web_api/exceptions/not_found_exception.rb +32 -0
  27. data/lib/spotify_web_api/exceptions/o_auth_provider_exception.rb +48 -0
  28. data/lib/spotify_web_api/exceptions/too_many_requests_exception.rb +32 -0
  29. data/lib/spotify_web_api/exceptions/unauthorized_exception.rb +32 -0
  30. data/lib/spotify_web_api/http/api_response.rb +21 -0
  31. data/lib/spotify_web_api/http/auth/o_auth2.rb +146 -0
  32. data/lib/spotify_web_api/http/http_call_back.rb +10 -0
  33. data/lib/spotify_web_api/http/http_method_enum.rb +10 -0
  34. data/lib/spotify_web_api/http/http_request.rb +10 -0
  35. data/lib/spotify_web_api/http/http_response.rb +10 -0
  36. data/lib/spotify_web_api/models/album_base.rb +168 -0
  37. data/lib/spotify_web_api/models/album_group_enum.rb +29 -0
  38. data/lib/spotify_web_api/models/album_object.rb +247 -0
  39. data/lib/spotify_web_api/models/album_restriction_object.rb +53 -0
  40. data/lib/spotify_web_api/models/album_type_enum.rb +26 -0
  41. data/lib/spotify_web_api/models/artist_discography_album_object.rb +194 -0
  42. data/lib/spotify_web_api/models/artist_object.rb +147 -0
  43. data/lib/spotify_web_api/models/audio_analysis_object.rb +156 -0
  44. data/lib/spotify_web_api/models/audio_features_object.rb +249 -0
  45. data/lib/spotify_web_api/models/audiobook_base.rb +245 -0
  46. data/lib/spotify_web_api/models/audiobook_object.rb +253 -0
  47. data/lib/spotify_web_api/models/author_object.rb +50 -0
  48. data/lib/spotify_web_api/models/base_model.rb +62 -0
  49. data/lib/spotify_web_api/models/categories.rb +110 -0
  50. data/lib/spotify_web_api/models/category_object.rb +82 -0
  51. data/lib/spotify_web_api/models/chapter_base.rb +237 -0
  52. data/lib/spotify_web_api/models/chapter_object.rb +245 -0
  53. data/lib/spotify_web_api/models/chapter_restriction_object.rb +59 -0
  54. data/lib/spotify_web_api/models/context_object.rb +78 -0
  55. data/lib/spotify_web_api/models/copyright_object.rb +60 -0
  56. data/lib/spotify_web_api/models/currently_playing_context_object.rb +137 -0
  57. data/lib/spotify_web_api/models/currently_playing_object.rb +109 -0
  58. data/lib/spotify_web_api/models/cursor_object.rb +59 -0
  59. data/lib/spotify_web_api/models/cursor_paged_artists.rb +48 -0
  60. data/lib/spotify_web_api/models/cursor_paging_object.rb +88 -0
  61. data/lib/spotify_web_api/models/cursor_paging_play_history_object.rb +106 -0
  62. data/lib/spotify_web_api/models/cursor_paging_simplified_artist_object.rb +106 -0
  63. data/lib/spotify_web_api/models/device_object.rb +126 -0
  64. data/lib/spotify_web_api/models/disallows_object.rb +140 -0
  65. data/lib/spotify_web_api/models/episode_base.rb +237 -0
  66. data/lib/spotify_web_api/models/episode_object.rb +246 -0
  67. data/lib/spotify_web_api/models/episode_restriction_object.rb +58 -0
  68. data/lib/spotify_web_api/models/error_object.rb +59 -0
  69. data/lib/spotify_web_api/models/explicit_content_settings_object.rb +61 -0
  70. data/lib/spotify_web_api/models/external_id_object.rb +72 -0
  71. data/lib/spotify_web_api/models/external_url_object.rb +51 -0
  72. data/lib/spotify_web_api/models/followers_object.rb +62 -0
  73. data/lib/spotify_web_api/models/image_object.rb +67 -0
  74. data/lib/spotify_web_api/models/include_external_enum.rb +23 -0
  75. data/lib/spotify_web_api/models/item_type1_enum.rb +20 -0
  76. data/lib/spotify_web_api/models/item_type2_enum.rb +23 -0
  77. data/lib/spotify_web_api/models/item_type3_enum.rb +23 -0
  78. data/lib/spotify_web_api/models/item_type_enum.rb +38 -0
  79. data/lib/spotify_web_api/models/linked_track_object.rb +89 -0
  80. data/lib/spotify_web_api/models/many_albums.rb +57 -0
  81. data/lib/spotify_web_api/models/many_artists.rb +57 -0
  82. data/lib/spotify_web_api/models/many_audio_features.rb +57 -0
  83. data/lib/spotify_web_api/models/many_audiobooks.rb +57 -0
  84. data/lib/spotify_web_api/models/many_chapters.rb +57 -0
  85. data/lib/spotify_web_api/models/many_devices.rb +57 -0
  86. data/lib/spotify_web_api/models/many_episodes.rb +57 -0
  87. data/lib/spotify_web_api/models/many_genres.rb +48 -0
  88. data/lib/spotify_web_api/models/many_simplified_shows.rb +57 -0
  89. data/lib/spotify_web_api/models/many_tracks.rb +57 -0
  90. data/lib/spotify_web_api/models/markets.rb +50 -0
  91. data/lib/spotify_web_api/models/me_albums_request.rb +55 -0
  92. data/lib/spotify_web_api/models/me_episodes_request.rb +52 -0
  93. data/lib/spotify_web_api/models/me_episodes_request1.rb +54 -0
  94. data/lib/spotify_web_api/models/me_following_request.rb +53 -0
  95. data/lib/spotify_web_api/models/me_following_request1.rb +55 -0
  96. data/lib/spotify_web_api/models/me_player_play_request.rb +89 -0
  97. data/lib/spotify_web_api/models/me_player_request.rb +63 -0
  98. data/lib/spotify_web_api/models/me_shows_request.rb +55 -0
  99. data/lib/spotify_web_api/models/me_tracks_request.rb +53 -0
  100. data/lib/spotify_web_api/models/me_tracks_request1.rb +55 -0
  101. data/lib/spotify_web_api/models/meta.rb +110 -0
  102. data/lib/spotify_web_api/models/mode_enum.rb +30 -0
  103. data/lib/spotify_web_api/models/narrator_object.rb +50 -0
  104. data/lib/spotify_web_api/models/o_auth_provider_error_enum.rb +45 -0
  105. data/lib/spotify_web_api/models/o_auth_scope_enum.rb +94 -0
  106. data/lib/spotify_web_api/models/o_auth_token.rb +96 -0
  107. data/lib/spotify_web_api/models/paged_albums.rb +48 -0
  108. data/lib/spotify_web_api/models/paged_categories.rb +48 -0
  109. data/lib/spotify_web_api/models/paging_artist_discography_album_object.rb +110 -0
  110. data/lib/spotify_web_api/models/paging_artist_object.rb +110 -0
  111. data/lib/spotify_web_api/models/paging_featured_playlist_object.rb +59 -0
  112. data/lib/spotify_web_api/models/paging_object.rb +93 -0
  113. data/lib/spotify_web_api/models/paging_playlist_object.rb +110 -0
  114. data/lib/spotify_web_api/models/paging_playlist_track_object.rb +110 -0
  115. data/lib/spotify_web_api/models/paging_saved_album_object.rb +110 -0
  116. data/lib/spotify_web_api/models/paging_saved_audiobook_object.rb +110 -0
  117. data/lib/spotify_web_api/models/paging_saved_episode_object.rb +110 -0
  118. data/lib/spotify_web_api/models/paging_saved_show_object.rb +110 -0
  119. data/lib/spotify_web_api/models/paging_saved_track_object.rb +110 -0
  120. data/lib/spotify_web_api/models/paging_simplified_album_object.rb +110 -0
  121. data/lib/spotify_web_api/models/paging_simplified_audiobook_object.rb +110 -0
  122. data/lib/spotify_web_api/models/paging_simplified_chapter_object.rb +110 -0
  123. data/lib/spotify_web_api/models/paging_simplified_episode_object.rb +110 -0
  124. data/lib/spotify_web_api/models/paging_simplified_show_object.rb +110 -0
  125. data/lib/spotify_web_api/models/paging_simplified_track_object.rb +110 -0
  126. data/lib/spotify_web_api/models/paging_track_object.rb +110 -0
  127. data/lib/spotify_web_api/models/play_history_object.rb +77 -0
  128. data/lib/spotify_web_api/models/playlist_object.rb +193 -0
  129. data/lib/spotify_web_api/models/playlist_owner_object.rb +109 -0
  130. data/lib/spotify_web_api/models/playlist_snapshot_id.rb +50 -0
  131. data/lib/spotify_web_api/models/playlist_track_object.rb +90 -0
  132. data/lib/spotify_web_api/models/playlist_tracks_ref_object.rb +60 -0
  133. data/lib/spotify_web_api/models/playlist_user_object.rb +98 -0
  134. data/lib/spotify_web_api/models/playlists_followers_request.rb +51 -0
  135. data/lib/spotify_web_api/models/playlists_request.rb +82 -0
  136. data/lib/spotify_web_api/models/playlists_tracks_request.rb +72 -0
  137. data/lib/spotify_web_api/models/playlists_tracks_request1.rb +97 -0
  138. data/lib/spotify_web_api/models/playlists_tracks_request2.rb +75 -0
  139. data/lib/spotify_web_api/models/private_user_object.rb +181 -0
  140. data/lib/spotify_web_api/models/public_user_object.rb +128 -0
  141. data/lib/spotify_web_api/models/queue_object.rb +60 -0
  142. data/lib/spotify_web_api/models/reason_enum.rb +29 -0
  143. data/lib/spotify_web_api/models/recommendation_seed_object.rb +104 -0
  144. data/lib/spotify_web_api/models/recommendations_object.rb +74 -0
  145. data/lib/spotify_web_api/models/release_date_precision_enum.rb +26 -0
  146. data/lib/spotify_web_api/models/resume_point_object.rb +60 -0
  147. data/lib/spotify_web_api/models/saved_album_object.rb +73 -0
  148. data/lib/spotify_web_api/models/saved_audiobook_object.rb +73 -0
  149. data/lib/spotify_web_api/models/saved_episode_object.rb +70 -0
  150. data/lib/spotify_web_api/models/saved_show_object.rb +73 -0
  151. data/lib/spotify_web_api/models/saved_track_object.rb +73 -0
  152. data/lib/spotify_web_api/models/search_items.rb +107 -0
  153. data/lib/spotify_web_api/models/section_object.rb +180 -0
  154. data/lib/spotify_web_api/models/segment_object.rb +166 -0
  155. data/lib/spotify_web_api/models/show_base.rb +211 -0
  156. data/lib/spotify_web_api/models/show_object.rb +219 -0
  157. data/lib/spotify_web_api/models/simplified_album_object.rb +186 -0
  158. data/lib/spotify_web_api/models/simplified_artist_object.rb +98 -0
  159. data/lib/spotify_web_api/models/simplified_playlist_object.rb +184 -0
  160. data/lib/spotify_web_api/models/simplified_track_object.rb +227 -0
  161. data/lib/spotify_web_api/models/time_interval_object.rb +68 -0
  162. data/lib/spotify_web_api/models/track.rb +331 -0
  163. data/lib/spotify_web_api/models/track1.rb +50 -0
  164. data/lib/spotify_web_api/models/track_object.rb +265 -0
  165. data/lib/spotify_web_api/models/track_restriction_object.rb +58 -0
  166. data/lib/spotify_web_api/models/type2_enum.rb +20 -0
  167. data/lib/spotify_web_api/models/type3_enum.rb +20 -0
  168. data/lib/spotify_web_api/models/type4_enum.rb +20 -0
  169. data/lib/spotify_web_api/models/type6_enum.rb +20 -0
  170. data/lib/spotify_web_api/models/type7_enum.rb +20 -0
  171. data/lib/spotify_web_api/models/type8_enum.rb +20 -0
  172. data/lib/spotify_web_api/models/type9_enum.rb +20 -0
  173. data/lib/spotify_web_api/models/type_enum.rb +20 -0
  174. data/lib/spotify_web_api/models/users_playlists_request.rb +87 -0
  175. data/lib/spotify_web_api/utilities/date_time_helper.rb +11 -0
  176. data/lib/spotify_web_api/utilities/file_wrapper.rb +16 -0
  177. data/lib/spotify_web_api.rb +198 -0
  178. metadata +264 -0
@@ -0,0 +1,110 @@
1
+ # spotify_web_api
2
+ #
3
+ # This file was automatically generated by APIMATIC v2.0
4
+ # ( https://apimatic.io ).
5
+
6
+ module SpotifyWebApi
7
+ # PagingSimplifiedEpisodeObject Model.
8
+ class PagingSimplifiedEpisodeObject < BaseModel
9
+ SKIP = Object.new
10
+ private_constant :SKIP
11
+
12
+ # A link to the Web API endpoint returning the full result of the request
13
+ # @return [String]
14
+ attr_accessor :href
15
+
16
+ # The maximum number of items in the response (as set in the query or by
17
+ # default).
18
+ # @return [Integer]
19
+ attr_accessor :limit
20
+
21
+ # URL to the next page of items. ( `null` if none)
22
+ # @return [String]
23
+ attr_accessor :mnext
24
+
25
+ # The offset of the items returned (as set in the query or by default)
26
+ # @return [Integer]
27
+ attr_accessor :offset
28
+
29
+ # URL to the previous page of items. ( `null` if none)
30
+ # @return [String]
31
+ attr_accessor :previous
32
+
33
+ # The total number of items available to return.
34
+ # @return [Integer]
35
+ attr_accessor :total
36
+
37
+ # The total number of items available to return.
38
+ # @return [Array[EpisodeBase]]
39
+ attr_accessor :items
40
+
41
+ # A mapping from model property names to API property names.
42
+ def self.names
43
+ @_hash = {} if @_hash.nil?
44
+ @_hash['href'] = 'href'
45
+ @_hash['limit'] = 'limit'
46
+ @_hash['mnext'] = 'next'
47
+ @_hash['offset'] = 'offset'
48
+ @_hash['previous'] = 'previous'
49
+ @_hash['total'] = 'total'
50
+ @_hash['items'] = 'items'
51
+ @_hash
52
+ end
53
+
54
+ # An array for optional fields
55
+ def self.optionals
56
+ []
57
+ end
58
+
59
+ # An array for nullable fields
60
+ def self.nullables
61
+ %w[
62
+ mnext
63
+ previous
64
+ ]
65
+ end
66
+
67
+ def initialize(href = nil, limit = nil, mnext = nil, offset = nil,
68
+ previous = nil, total = nil, items = nil)
69
+ @href = href
70
+ @limit = limit
71
+ @mnext = mnext
72
+ @offset = offset
73
+ @previous = previous
74
+ @total = total
75
+ @items = items
76
+ end
77
+
78
+ # Creates an instance of the object from a hash.
79
+ def self.from_hash(hash)
80
+ return nil unless hash
81
+
82
+ # Extract variables from the hash.
83
+ href = hash.key?('href') ? hash['href'] : nil
84
+ limit = hash.key?('limit') ? hash['limit'] : nil
85
+ mnext = hash.key?('next') ? hash['next'] : nil
86
+ offset = hash.key?('offset') ? hash['offset'] : nil
87
+ previous = hash.key?('previous') ? hash['previous'] : nil
88
+ total = hash.key?('total') ? hash['total'] : nil
89
+ # Parameter is an array, so we need to iterate through it
90
+ items = nil
91
+ unless hash['items'].nil?
92
+ items = []
93
+ hash['items'].each do |structure|
94
+ items << (EpisodeBase.from_hash(structure) if structure)
95
+ end
96
+ end
97
+
98
+ items = nil unless hash.key?('items')
99
+
100
+ # Create object from extracted values.
101
+ PagingSimplifiedEpisodeObject.new(href,
102
+ limit,
103
+ mnext,
104
+ offset,
105
+ previous,
106
+ total,
107
+ items)
108
+ end
109
+ end
110
+ end
@@ -0,0 +1,110 @@
1
+ # spotify_web_api
2
+ #
3
+ # This file was automatically generated by APIMATIC v2.0
4
+ # ( https://apimatic.io ).
5
+
6
+ module SpotifyWebApi
7
+ # PagingSimplifiedShowObject Model.
8
+ class PagingSimplifiedShowObject < BaseModel
9
+ SKIP = Object.new
10
+ private_constant :SKIP
11
+
12
+ # A link to the Web API endpoint returning the full result of the request
13
+ # @return [String]
14
+ attr_accessor :href
15
+
16
+ # The maximum number of items in the response (as set in the query or by
17
+ # default).
18
+ # @return [Integer]
19
+ attr_accessor :limit
20
+
21
+ # URL to the next page of items. ( `null` if none)
22
+ # @return [String]
23
+ attr_accessor :mnext
24
+
25
+ # The offset of the items returned (as set in the query or by default)
26
+ # @return [Integer]
27
+ attr_accessor :offset
28
+
29
+ # URL to the previous page of items. ( `null` if none)
30
+ # @return [String]
31
+ attr_accessor :previous
32
+
33
+ # The total number of items available to return.
34
+ # @return [Integer]
35
+ attr_accessor :total
36
+
37
+ # The total number of items available to return.
38
+ # @return [Array[ShowBase]]
39
+ attr_accessor :items
40
+
41
+ # A mapping from model property names to API property names.
42
+ def self.names
43
+ @_hash = {} if @_hash.nil?
44
+ @_hash['href'] = 'href'
45
+ @_hash['limit'] = 'limit'
46
+ @_hash['mnext'] = 'next'
47
+ @_hash['offset'] = 'offset'
48
+ @_hash['previous'] = 'previous'
49
+ @_hash['total'] = 'total'
50
+ @_hash['items'] = 'items'
51
+ @_hash
52
+ end
53
+
54
+ # An array for optional fields
55
+ def self.optionals
56
+ []
57
+ end
58
+
59
+ # An array for nullable fields
60
+ def self.nullables
61
+ %w[
62
+ mnext
63
+ previous
64
+ ]
65
+ end
66
+
67
+ def initialize(href = nil, limit = nil, mnext = nil, offset = nil,
68
+ previous = nil, total = nil, items = nil)
69
+ @href = href
70
+ @limit = limit
71
+ @mnext = mnext
72
+ @offset = offset
73
+ @previous = previous
74
+ @total = total
75
+ @items = items
76
+ end
77
+
78
+ # Creates an instance of the object from a hash.
79
+ def self.from_hash(hash)
80
+ return nil unless hash
81
+
82
+ # Extract variables from the hash.
83
+ href = hash.key?('href') ? hash['href'] : nil
84
+ limit = hash.key?('limit') ? hash['limit'] : nil
85
+ mnext = hash.key?('next') ? hash['next'] : nil
86
+ offset = hash.key?('offset') ? hash['offset'] : nil
87
+ previous = hash.key?('previous') ? hash['previous'] : nil
88
+ total = hash.key?('total') ? hash['total'] : nil
89
+ # Parameter is an array, so we need to iterate through it
90
+ items = nil
91
+ unless hash['items'].nil?
92
+ items = []
93
+ hash['items'].each do |structure|
94
+ items << (ShowBase.from_hash(structure) if structure)
95
+ end
96
+ end
97
+
98
+ items = nil unless hash.key?('items')
99
+
100
+ # Create object from extracted values.
101
+ PagingSimplifiedShowObject.new(href,
102
+ limit,
103
+ mnext,
104
+ offset,
105
+ previous,
106
+ total,
107
+ items)
108
+ end
109
+ end
110
+ end
@@ -0,0 +1,110 @@
1
+ # spotify_web_api
2
+ #
3
+ # This file was automatically generated by APIMATIC v2.0
4
+ # ( https://apimatic.io ).
5
+
6
+ module SpotifyWebApi
7
+ # PagingSimplifiedTrackObject Model.
8
+ class PagingSimplifiedTrackObject < BaseModel
9
+ SKIP = Object.new
10
+ private_constant :SKIP
11
+
12
+ # A link to the Web API endpoint returning the full result of the request
13
+ # @return [String]
14
+ attr_accessor :href
15
+
16
+ # The maximum number of items in the response (as set in the query or by
17
+ # default).
18
+ # @return [Integer]
19
+ attr_accessor :limit
20
+
21
+ # URL to the next page of items. ( `null` if none)
22
+ # @return [String]
23
+ attr_accessor :mnext
24
+
25
+ # The offset of the items returned (as set in the query or by default)
26
+ # @return [Integer]
27
+ attr_accessor :offset
28
+
29
+ # URL to the previous page of items. ( `null` if none)
30
+ # @return [String]
31
+ attr_accessor :previous
32
+
33
+ # The total number of items available to return.
34
+ # @return [Integer]
35
+ attr_accessor :total
36
+
37
+ # The total number of items available to return.
38
+ # @return [Array[SimplifiedTrackObject]]
39
+ attr_accessor :items
40
+
41
+ # A mapping from model property names to API property names.
42
+ def self.names
43
+ @_hash = {} if @_hash.nil?
44
+ @_hash['href'] = 'href'
45
+ @_hash['limit'] = 'limit'
46
+ @_hash['mnext'] = 'next'
47
+ @_hash['offset'] = 'offset'
48
+ @_hash['previous'] = 'previous'
49
+ @_hash['total'] = 'total'
50
+ @_hash['items'] = 'items'
51
+ @_hash
52
+ end
53
+
54
+ # An array for optional fields
55
+ def self.optionals
56
+ []
57
+ end
58
+
59
+ # An array for nullable fields
60
+ def self.nullables
61
+ %w[
62
+ mnext
63
+ previous
64
+ ]
65
+ end
66
+
67
+ def initialize(href = nil, limit = nil, mnext = nil, offset = nil,
68
+ previous = nil, total = nil, items = nil)
69
+ @href = href
70
+ @limit = limit
71
+ @mnext = mnext
72
+ @offset = offset
73
+ @previous = previous
74
+ @total = total
75
+ @items = items
76
+ end
77
+
78
+ # Creates an instance of the object from a hash.
79
+ def self.from_hash(hash)
80
+ return nil unless hash
81
+
82
+ # Extract variables from the hash.
83
+ href = hash.key?('href') ? hash['href'] : nil
84
+ limit = hash.key?('limit') ? hash['limit'] : nil
85
+ mnext = hash.key?('next') ? hash['next'] : nil
86
+ offset = hash.key?('offset') ? hash['offset'] : nil
87
+ previous = hash.key?('previous') ? hash['previous'] : nil
88
+ total = hash.key?('total') ? hash['total'] : nil
89
+ # Parameter is an array, so we need to iterate through it
90
+ items = nil
91
+ unless hash['items'].nil?
92
+ items = []
93
+ hash['items'].each do |structure|
94
+ items << (SimplifiedTrackObject.from_hash(structure) if structure)
95
+ end
96
+ end
97
+
98
+ items = nil unless hash.key?('items')
99
+
100
+ # Create object from extracted values.
101
+ PagingSimplifiedTrackObject.new(href,
102
+ limit,
103
+ mnext,
104
+ offset,
105
+ previous,
106
+ total,
107
+ items)
108
+ end
109
+ end
110
+ end
@@ -0,0 +1,110 @@
1
+ # spotify_web_api
2
+ #
3
+ # This file was automatically generated by APIMATIC v2.0
4
+ # ( https://apimatic.io ).
5
+
6
+ module SpotifyWebApi
7
+ # PagingTrackObject Model.
8
+ class PagingTrackObject < BaseModel
9
+ SKIP = Object.new
10
+ private_constant :SKIP
11
+
12
+ # A link to the Web API endpoint returning the full result of the request
13
+ # @return [String]
14
+ attr_accessor :href
15
+
16
+ # The maximum number of items in the response (as set in the query or by
17
+ # default).
18
+ # @return [Integer]
19
+ attr_accessor :limit
20
+
21
+ # URL to the next page of items. ( `null` if none)
22
+ # @return [String]
23
+ attr_accessor :mnext
24
+
25
+ # The offset of the items returned (as set in the query or by default)
26
+ # @return [Integer]
27
+ attr_accessor :offset
28
+
29
+ # URL to the previous page of items. ( `null` if none)
30
+ # @return [String]
31
+ attr_accessor :previous
32
+
33
+ # The total number of items available to return.
34
+ # @return [Integer]
35
+ attr_accessor :total
36
+
37
+ # The total number of items available to return.
38
+ # @return [Array[TrackObject]]
39
+ attr_accessor :items
40
+
41
+ # A mapping from model property names to API property names.
42
+ def self.names
43
+ @_hash = {} if @_hash.nil?
44
+ @_hash['href'] = 'href'
45
+ @_hash['limit'] = 'limit'
46
+ @_hash['mnext'] = 'next'
47
+ @_hash['offset'] = 'offset'
48
+ @_hash['previous'] = 'previous'
49
+ @_hash['total'] = 'total'
50
+ @_hash['items'] = 'items'
51
+ @_hash
52
+ end
53
+
54
+ # An array for optional fields
55
+ def self.optionals
56
+ []
57
+ end
58
+
59
+ # An array for nullable fields
60
+ def self.nullables
61
+ %w[
62
+ mnext
63
+ previous
64
+ ]
65
+ end
66
+
67
+ def initialize(href = nil, limit = nil, mnext = nil, offset = nil,
68
+ previous = nil, total = nil, items = nil)
69
+ @href = href
70
+ @limit = limit
71
+ @mnext = mnext
72
+ @offset = offset
73
+ @previous = previous
74
+ @total = total
75
+ @items = items
76
+ end
77
+
78
+ # Creates an instance of the object from a hash.
79
+ def self.from_hash(hash)
80
+ return nil unless hash
81
+
82
+ # Extract variables from the hash.
83
+ href = hash.key?('href') ? hash['href'] : nil
84
+ limit = hash.key?('limit') ? hash['limit'] : nil
85
+ mnext = hash.key?('next') ? hash['next'] : nil
86
+ offset = hash.key?('offset') ? hash['offset'] : nil
87
+ previous = hash.key?('previous') ? hash['previous'] : nil
88
+ total = hash.key?('total') ? hash['total'] : nil
89
+ # Parameter is an array, so we need to iterate through it
90
+ items = nil
91
+ unless hash['items'].nil?
92
+ items = []
93
+ hash['items'].each do |structure|
94
+ items << (TrackObject.from_hash(structure) if structure)
95
+ end
96
+ end
97
+
98
+ items = nil unless hash.key?('items')
99
+
100
+ # Create object from extracted values.
101
+ PagingTrackObject.new(href,
102
+ limit,
103
+ mnext,
104
+ offset,
105
+ previous,
106
+ total,
107
+ items)
108
+ end
109
+ end
110
+ end
@@ -0,0 +1,77 @@
1
+ # spotify_web_api
2
+ #
3
+ # This file was automatically generated by APIMATIC v2.0
4
+ # ( https://apimatic.io ).
5
+
6
+ require 'date'
7
+ module SpotifyWebApi
8
+ # PlayHistoryObject Model.
9
+ class PlayHistoryObject < BaseModel
10
+ SKIP = Object.new
11
+ private_constant :SKIP
12
+
13
+ # The track the user listened to.
14
+ # @return [TrackObject]
15
+ attr_accessor :track
16
+
17
+ # The date and time the track was played.
18
+ # @return [DateTime]
19
+ attr_accessor :played_at
20
+
21
+ # The context the track was played from.
22
+ # @return [ContextObject]
23
+ attr_accessor :context
24
+
25
+ # A mapping from model property names to API property names.
26
+ def self.names
27
+ @_hash = {} if @_hash.nil?
28
+ @_hash['track'] = 'track'
29
+ @_hash['played_at'] = 'played_at'
30
+ @_hash['context'] = 'context'
31
+ @_hash
32
+ end
33
+
34
+ # An array for optional fields
35
+ def self.optionals
36
+ %w[
37
+ track
38
+ played_at
39
+ context
40
+ ]
41
+ end
42
+
43
+ # An array for nullable fields
44
+ def self.nullables
45
+ []
46
+ end
47
+
48
+ def initialize(track = SKIP, played_at = SKIP, context = SKIP)
49
+ @track = track unless track == SKIP
50
+ @played_at = played_at unless played_at == SKIP
51
+ @context = context unless context == SKIP
52
+ end
53
+
54
+ # Creates an instance of the object from a hash.
55
+ def self.from_hash(hash)
56
+ return nil unless hash
57
+
58
+ # Extract variables from the hash.
59
+ track = TrackObject.from_hash(hash['track']) if hash['track']
60
+ played_at = if hash.key?('played_at')
61
+ (DateTimeHelper.from_rfc3339(hash['played_at']) if hash['played_at'])
62
+ else
63
+ SKIP
64
+ end
65
+ context = ContextObject.from_hash(hash['context']) if hash['context']
66
+
67
+ # Create object from extracted values.
68
+ PlayHistoryObject.new(track,
69
+ played_at,
70
+ context)
71
+ end
72
+
73
+ def to_custom_played_at
74
+ DateTimeHelper.to_rfc3339(played_at)
75
+ end
76
+ end
77
+ end
@@ -0,0 +1,193 @@
1
+ # spotify_web_api
2
+ #
3
+ # This file was automatically generated by APIMATIC v2.0
4
+ # ( https://apimatic.io ).
5
+
6
+ module SpotifyWebApi
7
+ # PlaylistObject Model.
8
+ class PlaylistObject < BaseModel
9
+ SKIP = Object.new
10
+ private_constant :SKIP
11
+
12
+ # `true` if the owner allows other users to modify the playlist.
13
+ # @return [TrueClass | FalseClass]
14
+ attr_accessor :collaborative
15
+
16
+ # The playlist description. _Only returned for modified, verified playlists,
17
+ # otherwise_ `null`.
18
+ # @return [String]
19
+ attr_accessor :description
20
+
21
+ # Known external URLs for this playlist.
22
+ # @return [ExternalUrlObject]
23
+ attr_accessor :external_urls
24
+
25
+ # Information about the followers of the playlist.
26
+ # @return [FollowersObject]
27
+ attr_accessor :followers
28
+
29
+ # A link to the Web API endpoint providing full details of the playlist.
30
+ # @return [String]
31
+ attr_accessor :href
32
+
33
+ # The [Spotify ID](/documentation/web-api/concepts/spotify-uris-ids) for the
34
+ # playlist.
35
+ # @return [String]
36
+ attr_accessor :id
37
+
38
+ # Images for the playlist. The array may be empty or contain up to three
39
+ # images. The images are returned by size in descending order. See [Working
40
+ # with Playlists](/documentation/web-api/concepts/playlists). _**Note**: If
41
+ # returned, the source URL for the image (`url`) is temporary and will
42
+ # expire in less than a day._
43
+ # @return [Array[ImageObject]]
44
+ attr_accessor :images
45
+
46
+ # The name of the playlist.
47
+ # @return [String]
48
+ attr_accessor :name
49
+
50
+ # The user who owns the playlist
51
+ # @return [PlaylistOwnerObject]
52
+ attr_accessor :owner
53
+
54
+ # The playlist's public/private status: `true` the playlist is public,
55
+ # `false` the playlist is private, `null` the playlist status is not
56
+ # relevant. For more about public/private status, see [Working with
57
+ # Playlists](/documentation/web-api/concepts/playlists)
58
+ # @return [TrueClass | FalseClass]
59
+ attr_accessor :public
60
+
61
+ # The version identifier for the current playlist. Can be supplied in other
62
+ # requests to target a specific playlist version
63
+ # @return [String]
64
+ attr_accessor :snapshot_id
65
+
66
+ # The tracks of the playlist.
67
+ # @return [PagingPlaylistTrackObject]
68
+ attr_accessor :tracks
69
+
70
+ # The object type: "playlist"
71
+ # @return [String]
72
+ attr_accessor :type
73
+
74
+ # The [Spotify URI](/documentation/web-api/concepts/spotify-uris-ids) for
75
+ # the playlist.
76
+ # @return [String]
77
+ attr_accessor :uri
78
+
79
+ # A mapping from model property names to API property names.
80
+ def self.names
81
+ @_hash = {} if @_hash.nil?
82
+ @_hash['collaborative'] = 'collaborative'
83
+ @_hash['description'] = 'description'
84
+ @_hash['external_urls'] = 'external_urls'
85
+ @_hash['followers'] = 'followers'
86
+ @_hash['href'] = 'href'
87
+ @_hash['id'] = 'id'
88
+ @_hash['images'] = 'images'
89
+ @_hash['name'] = 'name'
90
+ @_hash['owner'] = 'owner'
91
+ @_hash['public'] = 'public'
92
+ @_hash['snapshot_id'] = 'snapshot_id'
93
+ @_hash['tracks'] = 'tracks'
94
+ @_hash['type'] = 'type'
95
+ @_hash['uri'] = 'uri'
96
+ @_hash
97
+ end
98
+
99
+ # An array for optional fields
100
+ def self.optionals
101
+ %w[
102
+ collaborative
103
+ description
104
+ external_urls
105
+ followers
106
+ href
107
+ id
108
+ images
109
+ name
110
+ owner
111
+ public
112
+ snapshot_id
113
+ tracks
114
+ type
115
+ uri
116
+ ]
117
+ end
118
+
119
+ # An array for nullable fields
120
+ def self.nullables
121
+ %w[
122
+ description
123
+ ]
124
+ end
125
+
126
+ def initialize(collaborative = SKIP, description = SKIP,
127
+ external_urls = SKIP, followers = SKIP, href = SKIP,
128
+ id = SKIP, images = SKIP, name = SKIP, owner = SKIP,
129
+ public = SKIP, snapshot_id = SKIP, tracks = SKIP,
130
+ type = SKIP, uri = SKIP)
131
+ @collaborative = collaborative unless collaborative == SKIP
132
+ @description = description unless description == SKIP
133
+ @external_urls = external_urls unless external_urls == SKIP
134
+ @followers = followers unless followers == SKIP
135
+ @href = href unless href == SKIP
136
+ @id = id unless id == SKIP
137
+ @images = images unless images == SKIP
138
+ @name = name unless name == SKIP
139
+ @owner = owner unless owner == SKIP
140
+ @public = public unless public == SKIP
141
+ @snapshot_id = snapshot_id unless snapshot_id == SKIP
142
+ @tracks = tracks unless tracks == SKIP
143
+ @type = type unless type == SKIP
144
+ @uri = uri unless uri == SKIP
145
+ end
146
+
147
+ # Creates an instance of the object from a hash.
148
+ def self.from_hash(hash)
149
+ return nil unless hash
150
+
151
+ # Extract variables from the hash.
152
+ collaborative = hash.key?('collaborative') ? hash['collaborative'] : SKIP
153
+ description = hash.key?('description') ? hash['description'] : SKIP
154
+ external_urls = ExternalUrlObject.from_hash(hash['external_urls']) if hash['external_urls']
155
+ followers = FollowersObject.from_hash(hash['followers']) if hash['followers']
156
+ href = hash.key?('href') ? hash['href'] : SKIP
157
+ id = hash.key?('id') ? hash['id'] : SKIP
158
+ # Parameter is an array, so we need to iterate through it
159
+ images = nil
160
+ unless hash['images'].nil?
161
+ images = []
162
+ hash['images'].each do |structure|
163
+ images << (ImageObject.from_hash(structure) if structure)
164
+ end
165
+ end
166
+
167
+ images = SKIP unless hash.key?('images')
168
+ name = hash.key?('name') ? hash['name'] : SKIP
169
+ owner = PlaylistOwnerObject.from_hash(hash['owner']) if hash['owner']
170
+ public = hash.key?('public') ? hash['public'] : SKIP
171
+ snapshot_id = hash.key?('snapshot_id') ? hash['snapshot_id'] : SKIP
172
+ tracks = PagingPlaylistTrackObject.from_hash(hash['tracks']) if hash['tracks']
173
+ type = hash.key?('type') ? hash['type'] : SKIP
174
+ uri = hash.key?('uri') ? hash['uri'] : SKIP
175
+
176
+ # Create object from extracted values.
177
+ PlaylistObject.new(collaborative,
178
+ description,
179
+ external_urls,
180
+ followers,
181
+ href,
182
+ id,
183
+ images,
184
+ name,
185
+ owner,
186
+ public,
187
+ snapshot_id,
188
+ tracks,
189
+ type,
190
+ uri)
191
+ end
192
+ end
193
+ end