launchdarkly_api 3.2.0 → 3.5.0

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.
Files changed (252) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +178 -168
  3. data/docs/AccessTokensApi.md +333 -0
  4. data/docs/AuditLogApi.md +4 -4
  5. data/docs/ClientSideAvailability.md +9 -0
  6. data/docs/FeatureFlag.md +3 -2
  7. data/docs/FeatureFlagBody.md +1 -0
  8. data/docs/FeatureFlagsApi.md +2 -2
  9. data/docs/Project.md +1 -0
  10. data/docs/ProjectBody.md +1 -0
  11. data/docs/StreamUsageSeries.md +2 -2
  12. data/docs/Token.md +22 -0
  13. data/docs/TokenBody.md +13 -0
  14. data/docs/Tokens.md +9 -0
  15. data/docs/UserSegment.md +1 -1
  16. data/docs/UserTargetingExpirationForFlag.md +1 -1
  17. data/docs/UserTargetingExpirationForSegment.md +1 -1
  18. data/docs/UsersApi.md +2 -2
  19. data/docs/Variation.md +1 -0
  20. data/launchdarkly_api.gemspec +1 -1
  21. data/lib/launchdarkly_api.rb +6 -1
  22. data/lib/launchdarkly_api/api/access_tokens_api.rb +340 -0
  23. data/lib/launchdarkly_api/api/audit_log_api.rb +5 -5
  24. data/lib/launchdarkly_api/api/custom_roles_api.rb +1 -1
  25. data/lib/launchdarkly_api/api/customer_metrics_api.rb +1 -1
  26. data/lib/launchdarkly_api/api/data_export_destinations_api.rb +1 -1
  27. data/lib/launchdarkly_api/api/environments_api.rb +1 -1
  28. data/lib/launchdarkly_api/api/feature_flags_api.rb +3 -3
  29. data/lib/launchdarkly_api/api/projects_api.rb +1 -1
  30. data/lib/launchdarkly_api/api/root_api.rb +1 -1
  31. data/lib/launchdarkly_api/api/team_members_api.rb +1 -1
  32. data/lib/launchdarkly_api/api/user_segments_api.rb +1 -1
  33. data/lib/launchdarkly_api/api/user_settings_api.rb +1 -1
  34. data/lib/launchdarkly_api/api/users_api.rb +3 -3
  35. data/lib/launchdarkly_api/api/webhooks_api.rb +1 -1
  36. data/lib/launchdarkly_api/api_client.rb +1 -1
  37. data/lib/launchdarkly_api/api_error.rb +1 -1
  38. data/lib/launchdarkly_api/configuration.rb +1 -1
  39. data/lib/launchdarkly_api/models/audit_log_entries.rb +1 -1
  40. data/lib/launchdarkly_api/models/audit_log_entry.rb +1 -1
  41. data/lib/launchdarkly_api/models/audit_log_entry_target.rb +1 -1
  42. data/lib/launchdarkly_api/models/clause.rb +1 -1
  43. data/lib/launchdarkly_api/models/client_side_availability.rb +194 -0
  44. data/lib/launchdarkly_api/models/copy_actions.rb +1 -1
  45. data/lib/launchdarkly_api/models/custom_property.rb +1 -1
  46. data/lib/launchdarkly_api/models/custom_property_values.rb +1 -1
  47. data/lib/launchdarkly_api/models/custom_role.rb +1 -1
  48. data/lib/launchdarkly_api/models/custom_role_body.rb +1 -1
  49. data/lib/launchdarkly_api/models/custom_roles.rb +1 -1
  50. data/lib/launchdarkly_api/models/defaults.rb +1 -1
  51. data/lib/launchdarkly_api/models/destination.rb +1 -1
  52. data/lib/launchdarkly_api/models/destination_amazon_kinesis.rb +1 -1
  53. data/lib/launchdarkly_api/models/destination_body.rb +1 -1
  54. data/lib/launchdarkly_api/models/destination_google_pub_sub.rb +1 -1
  55. data/lib/launchdarkly_api/models/destination_m_particle.rb +1 -1
  56. data/lib/launchdarkly_api/models/destination_segment.rb +1 -1
  57. data/lib/launchdarkly_api/models/destinations.rb +1 -1
  58. data/lib/launchdarkly_api/models/environment.rb +1 -1
  59. data/lib/launchdarkly_api/models/environment_post.rb +1 -1
  60. data/lib/launchdarkly_api/models/evaluation_usage_error.rb +1 -1
  61. data/lib/launchdarkly_api/models/events.rb +1 -1
  62. data/lib/launchdarkly_api/models/fallthrough.rb +1 -1
  63. data/lib/launchdarkly_api/models/feature_flag.rb +13 -4
  64. data/lib/launchdarkly_api/models/feature_flag_body.rb +11 -2
  65. data/lib/launchdarkly_api/models/feature_flag_config.rb +1 -1
  66. data/lib/launchdarkly_api/models/feature_flag_copy_body.rb +1 -1
  67. data/lib/launchdarkly_api/models/feature_flag_copy_object.rb +1 -1
  68. data/lib/launchdarkly_api/models/feature_flag_status.rb +1 -1
  69. data/lib/launchdarkly_api/models/feature_flag_status_across_environments.rb +1 -1
  70. data/lib/launchdarkly_api/models/feature_flag_status_for_queried_environment.rb +1 -1
  71. data/lib/launchdarkly_api/models/feature_flag_statuses.rb +1 -1
  72. data/lib/launchdarkly_api/models/feature_flags.rb +1 -1
  73. data/lib/launchdarkly_api/models/flag_list_item.rb +1 -1
  74. data/lib/launchdarkly_api/models/id.rb +1 -1
  75. data/lib/launchdarkly_api/models/link.rb +1 -1
  76. data/lib/launchdarkly_api/models/links.rb +1 -1
  77. data/lib/launchdarkly_api/models/ma_uby_category.rb +1 -1
  78. data/lib/launchdarkly_api/models/mau.rb +1 -1
  79. data/lib/launchdarkly_api/models/mau_metadata.rb +1 -1
  80. data/lib/launchdarkly_api/models/member.rb +1 -1
  81. data/lib/launchdarkly_api/models/members.rb +1 -1
  82. data/lib/launchdarkly_api/models/members_body.rb +1 -1
  83. data/lib/launchdarkly_api/models/patch_comment.rb +1 -1
  84. data/lib/launchdarkly_api/models/patch_operation.rb +1 -1
  85. data/lib/launchdarkly_api/models/policy.rb +1 -1
  86. data/lib/launchdarkly_api/models/prerequisite.rb +1 -1
  87. data/lib/launchdarkly_api/models/project.rb +14 -5
  88. data/lib/launchdarkly_api/models/project_body.rb +14 -5
  89. data/lib/launchdarkly_api/models/projects.rb +1 -1
  90. data/lib/launchdarkly_api/models/role.rb +1 -1
  91. data/lib/launchdarkly_api/models/rollout.rb +1 -1
  92. data/lib/launchdarkly_api/models/rule.rb +1 -1
  93. data/lib/launchdarkly_api/models/semantic_patch_operation.rb +1 -1
  94. data/lib/launchdarkly_api/models/semantic_patch_operation_instructions.rb +1 -1
  95. data/lib/launchdarkly_api/models/site.rb +1 -1
  96. data/lib/launchdarkly_api/models/statement.rb +1 -1
  97. data/lib/launchdarkly_api/models/stream.rb +1 -1
  98. data/lib/launchdarkly_api/models/stream_by_sdk.rb +1 -1
  99. data/lib/launchdarkly_api/models/stream_by_sdk_links.rb +1 -1
  100. data/lib/launchdarkly_api/models/stream_by_sdk_links_metadata.rb +1 -1
  101. data/lib/launchdarkly_api/models/stream_links.rb +1 -1
  102. data/lib/launchdarkly_api/models/stream_sdk_version.rb +1 -1
  103. data/lib/launchdarkly_api/models/stream_sdk_version_data.rb +1 -1
  104. data/lib/launchdarkly_api/models/stream_usage_error.rb +1 -1
  105. data/lib/launchdarkly_api/models/stream_usage_links.rb +1 -1
  106. data/lib/launchdarkly_api/models/stream_usage_metadata.rb +1 -1
  107. data/lib/launchdarkly_api/models/stream_usage_series.rb +3 -3
  108. data/lib/launchdarkly_api/models/streams.rb +1 -1
  109. data/lib/launchdarkly_api/models/target.rb +1 -1
  110. data/lib/launchdarkly_api/models/token.rb +322 -0
  111. data/lib/launchdarkly_api/models/token_body.rb +237 -0
  112. data/lib/launchdarkly_api/models/tokens.rb +194 -0
  113. data/lib/launchdarkly_api/models/usage.rb +1 -1
  114. data/lib/launchdarkly_api/models/usage_error.rb +1 -1
  115. data/lib/launchdarkly_api/models/usage_links.rb +1 -1
  116. data/lib/launchdarkly_api/models/user.rb +1 -1
  117. data/lib/launchdarkly_api/models/user_flag_setting.rb +1 -1
  118. data/lib/launchdarkly_api/models/user_flag_settings.rb +1 -1
  119. data/lib/launchdarkly_api/models/user_record.rb +1 -1
  120. data/lib/launchdarkly_api/models/user_segment.rb +2 -2
  121. data/lib/launchdarkly_api/models/user_segment_body.rb +1 -1
  122. data/lib/launchdarkly_api/models/user_segment_rule.rb +1 -1
  123. data/lib/launchdarkly_api/models/user_segments.rb +1 -1
  124. data/lib/launchdarkly_api/models/user_settings_body.rb +1 -1
  125. data/lib/launchdarkly_api/models/user_targeting_expiration_for_flag.rb +2 -2
  126. data/lib/launchdarkly_api/models/user_targeting_expiration_for_flags.rb +1 -1
  127. data/lib/launchdarkly_api/models/user_targeting_expiration_for_segment.rb +2 -2
  128. data/lib/launchdarkly_api/models/user_targeting_expiration_on_flags_for_user.rb +1 -1
  129. data/lib/launchdarkly_api/models/user_targeting_expiration_resource_id_for_flag.rb +1 -1
  130. data/lib/launchdarkly_api/models/users.rb +1 -1
  131. data/lib/launchdarkly_api/models/variation.rb +11 -2
  132. data/lib/launchdarkly_api/models/webhook.rb +1 -1
  133. data/lib/launchdarkly_api/models/webhook_body.rb +1 -1
  134. data/lib/launchdarkly_api/models/webhooks.rb +1 -1
  135. data/lib/launchdarkly_api/models/weighted_variation.rb +1 -1
  136. data/lib/launchdarkly_api/version.rb +2 -2
  137. data/openapi.yml +278 -14
  138. data/spec/api/access_tokens_api_spec.rb +103 -0
  139. data/spec/api/audit_log_api_spec.rb +3 -3
  140. data/spec/api/custom_roles_api_spec.rb +1 -1
  141. data/spec/api/customer_metrics_api_spec.rb +1 -1
  142. data/spec/api/data_export_destinations_api_spec.rb +1 -1
  143. data/spec/api/environments_api_spec.rb +1 -1
  144. data/spec/api/feature_flags_api_spec.rb +2 -2
  145. data/spec/api/projects_api_spec.rb +1 -1
  146. data/spec/api/root_api_spec.rb +1 -1
  147. data/spec/api/team_members_api_spec.rb +1 -1
  148. data/spec/api/user_segments_api_spec.rb +1 -1
  149. data/spec/api/user_settings_api_spec.rb +1 -1
  150. data/spec/api/users_api_spec.rb +2 -2
  151. data/spec/api/webhooks_api_spec.rb +1 -1
  152. data/spec/api_client_spec.rb +1 -1
  153. data/spec/configuration_spec.rb +1 -1
  154. data/spec/models/audit_log_entries_spec.rb +1 -1
  155. data/spec/models/audit_log_entry_spec.rb +1 -1
  156. data/spec/models/audit_log_entry_target_spec.rb +1 -1
  157. data/spec/models/clause_spec.rb +1 -1
  158. data/spec/models/client_side_availability_spec.rb +47 -0
  159. data/spec/models/copy_actions_spec.rb +1 -1
  160. data/spec/models/custom_property_spec.rb +1 -1
  161. data/spec/models/custom_property_values_spec.rb +1 -1
  162. data/spec/models/custom_role_body_spec.rb +1 -1
  163. data/spec/models/custom_role_spec.rb +1 -1
  164. data/spec/models/custom_roles_spec.rb +1 -1
  165. data/spec/models/defaults_spec.rb +1 -1
  166. data/spec/models/destination_amazon_kinesis_spec.rb +1 -1
  167. data/spec/models/destination_body_spec.rb +1 -1
  168. data/spec/models/destination_google_pub_sub_spec.rb +1 -1
  169. data/spec/models/destination_m_particle_spec.rb +1 -1
  170. data/spec/models/destination_segment_spec.rb +1 -1
  171. data/spec/models/destination_spec.rb +1 -1
  172. data/spec/models/destinations_spec.rb +1 -1
  173. data/spec/models/environment_post_spec.rb +1 -1
  174. data/spec/models/environment_spec.rb +1 -1
  175. data/spec/models/evaluation_usage_error_spec.rb +1 -1
  176. data/spec/models/events_spec.rb +1 -1
  177. data/spec/models/fallthrough_spec.rb +1 -1
  178. data/spec/models/feature_flag_body_spec.rb +7 -1
  179. data/spec/models/feature_flag_config_spec.rb +1 -1
  180. data/spec/models/feature_flag_copy_body_spec.rb +1 -1
  181. data/spec/models/feature_flag_copy_object_spec.rb +1 -1
  182. data/spec/models/feature_flag_spec.rb +7 -1
  183. data/spec/models/feature_flag_status_across_environments_spec.rb +1 -1
  184. data/spec/models/feature_flag_status_for_queried_environment_spec.rb +1 -1
  185. data/spec/models/feature_flag_status_spec.rb +1 -1
  186. data/spec/models/feature_flag_statuses_spec.rb +1 -1
  187. data/spec/models/feature_flags_spec.rb +1 -1
  188. data/spec/models/flag_list_item_spec.rb +1 -1
  189. data/spec/models/id_spec.rb +1 -1
  190. data/spec/models/link_spec.rb +1 -1
  191. data/spec/models/links_spec.rb +1 -1
  192. data/spec/models/ma_uby_category_spec.rb +1 -1
  193. data/spec/models/mau_metadata_spec.rb +1 -1
  194. data/spec/models/mau_spec.rb +1 -1
  195. data/spec/models/member_spec.rb +1 -1
  196. data/spec/models/members_body_spec.rb +1 -1
  197. data/spec/models/members_spec.rb +1 -1
  198. data/spec/models/patch_comment_spec.rb +1 -1
  199. data/spec/models/patch_operation_spec.rb +1 -1
  200. data/spec/models/policy_spec.rb +1 -1
  201. data/spec/models/prerequisite_spec.rb +1 -1
  202. data/spec/models/project_body_spec.rb +7 -1
  203. data/spec/models/project_spec.rb +7 -1
  204. data/spec/models/projects_spec.rb +1 -1
  205. data/spec/models/role_spec.rb +1 -1
  206. data/spec/models/rollout_spec.rb +1 -1
  207. data/spec/models/rule_spec.rb +1 -1
  208. data/spec/models/semantic_patch_operation_instructions_spec.rb +1 -1
  209. data/spec/models/semantic_patch_operation_spec.rb +1 -1
  210. data/spec/models/site_spec.rb +1 -1
  211. data/spec/models/statement_spec.rb +1 -1
  212. data/spec/models/stream_by_sdk_links_metadata_spec.rb +1 -1
  213. data/spec/models/stream_by_sdk_links_spec.rb +1 -1
  214. data/spec/models/stream_by_sdk_spec.rb +1 -1
  215. data/spec/models/stream_links_spec.rb +1 -1
  216. data/spec/models/stream_sdk_version_data_spec.rb +1 -1
  217. data/spec/models/stream_sdk_version_spec.rb +1 -1
  218. data/spec/models/stream_spec.rb +1 -1
  219. data/spec/models/stream_usage_error_spec.rb +1 -1
  220. data/spec/models/stream_usage_links_spec.rb +1 -1
  221. data/spec/models/stream_usage_metadata_spec.rb +1 -1
  222. data/spec/models/stream_usage_series_spec.rb +1 -1
  223. data/spec/models/streams_spec.rb +1 -1
  224. data/spec/models/target_spec.rb +1 -1
  225. data/spec/models/token_body_spec.rb +71 -0
  226. data/spec/models/token_spec.rb +125 -0
  227. data/spec/models/tokens_spec.rb +47 -0
  228. data/spec/models/usage_error_spec.rb +1 -1
  229. data/spec/models/usage_links_spec.rb +1 -1
  230. data/spec/models/usage_spec.rb +1 -1
  231. data/spec/models/user_flag_setting_spec.rb +1 -1
  232. data/spec/models/user_flag_settings_spec.rb +1 -1
  233. data/spec/models/user_record_spec.rb +1 -1
  234. data/spec/models/user_segment_body_spec.rb +1 -1
  235. data/spec/models/user_segment_rule_spec.rb +1 -1
  236. data/spec/models/user_segment_spec.rb +1 -1
  237. data/spec/models/user_segments_spec.rb +1 -1
  238. data/spec/models/user_settings_body_spec.rb +1 -1
  239. data/spec/models/user_spec.rb +1 -1
  240. data/spec/models/user_targeting_expiration_for_flag_spec.rb +1 -1
  241. data/spec/models/user_targeting_expiration_for_flags_spec.rb +1 -1
  242. data/spec/models/user_targeting_expiration_for_segment_spec.rb +1 -1
  243. data/spec/models/user_targeting_expiration_on_flags_for_user_spec.rb +1 -1
  244. data/spec/models/user_targeting_expiration_resource_id_for_flag_spec.rb +1 -1
  245. data/spec/models/users_spec.rb +1 -1
  246. data/spec/models/variation_spec.rb +7 -1
  247. data/spec/models/webhook_body_spec.rb +1 -1
  248. data/spec/models/webhook_spec.rb +1 -1
  249. data/spec/models/webhooks_spec.rb +1 -1
  250. data/spec/models/weighted_variation_spec.rb +1 -1
  251. data/spec/spec_helper.rb +1 -1
  252. metadata +107 -87
@@ -0,0 +1,237 @@
1
+ =begin
2
+ #LaunchDarkly REST API
3
+
4
+ #Build custom integrations with the LaunchDarkly REST API
5
+
6
+ OpenAPI spec version: 3.5.0
7
+ Contact: support@launchdarkly.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 2.4.8
10
+
11
+ =end
12
+
13
+ require 'date'
14
+
15
+ module LaunchDarklyApi
16
+ class TokenBody
17
+ # A human-friendly name for the access token
18
+ attr_accessor :name
19
+
20
+ # The name of a built-in role for the token
21
+ attr_accessor :role
22
+
23
+ # A list of custom role IDs to use as access limits for the access token
24
+ attr_accessor :custom_role_ids
25
+
26
+ attr_accessor :inline_role
27
+
28
+ # Whether the token will be a service token https://docs.launchdarkly.com/home/account-security/api-access-tokens#service-tokens
29
+ attr_accessor :service_token
30
+
31
+ # The default API version for this token
32
+ attr_accessor :default_api_version
33
+
34
+ # Attribute mapping from ruby-style variable name to JSON key.
35
+ def self.attribute_map
36
+ {
37
+ :'name' => :'name',
38
+ :'role' => :'role',
39
+ :'custom_role_ids' => :'customRoleIds',
40
+ :'inline_role' => :'inlineRole',
41
+ :'service_token' => :'serviceToken',
42
+ :'default_api_version' => :'defaultApiVersion'
43
+ }
44
+ end
45
+
46
+ # Attribute type mapping.
47
+ def self.swagger_types
48
+ {
49
+ :'name' => :'String',
50
+ :'role' => :'String',
51
+ :'custom_role_ids' => :'Array<String>',
52
+ :'inline_role' => :'Array<Statement>',
53
+ :'service_token' => :'BOOLEAN',
54
+ :'default_api_version' => :'Integer'
55
+ }
56
+ end
57
+
58
+ # Initializes the object
59
+ # @param [Hash] attributes Model attributes in the form of hash
60
+ def initialize(attributes = {})
61
+ return unless attributes.is_a?(Hash)
62
+
63
+ # convert string to symbol for hash key
64
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
65
+
66
+ if attributes.has_key?(:'name')
67
+ self.name = attributes[:'name']
68
+ end
69
+
70
+ if attributes.has_key?(:'role')
71
+ self.role = attributes[:'role']
72
+ end
73
+
74
+ if attributes.has_key?(:'customRoleIds')
75
+ if (value = attributes[:'customRoleIds']).is_a?(Array)
76
+ self.custom_role_ids = value
77
+ end
78
+ end
79
+
80
+ if attributes.has_key?(:'inlineRole')
81
+ if (value = attributes[:'inlineRole']).is_a?(Array)
82
+ self.inline_role = value
83
+ end
84
+ end
85
+
86
+ if attributes.has_key?(:'serviceToken')
87
+ self.service_token = attributes[:'serviceToken']
88
+ end
89
+
90
+ if attributes.has_key?(:'defaultApiVersion')
91
+ self.default_api_version = attributes[:'defaultApiVersion']
92
+ end
93
+ end
94
+
95
+ # Show invalid properties with the reasons. Usually used together with valid?
96
+ # @return Array for valid properties with the reasons
97
+ def list_invalid_properties
98
+ invalid_properties = Array.new
99
+ invalid_properties
100
+ end
101
+
102
+ # Check to see if the all the properties in the model are valid
103
+ # @return true if the model is valid
104
+ def valid?
105
+ true
106
+ end
107
+
108
+ # Checks equality by comparing each attribute.
109
+ # @param [Object] Object to be compared
110
+ def ==(o)
111
+ return true if self.equal?(o)
112
+ self.class == o.class &&
113
+ name == o.name &&
114
+ role == o.role &&
115
+ custom_role_ids == o.custom_role_ids &&
116
+ inline_role == o.inline_role &&
117
+ service_token == o.service_token &&
118
+ default_api_version == o.default_api_version
119
+ end
120
+
121
+ # @see the `==` method
122
+ # @param [Object] Object to be compared
123
+ def eql?(o)
124
+ self == o
125
+ end
126
+
127
+ # Calculates hash code according to all attributes.
128
+ # @return [Fixnum] Hash code
129
+ def hash
130
+ [name, role, custom_role_ids, inline_role, service_token, default_api_version].hash
131
+ end
132
+
133
+ # Builds the object from hash
134
+ # @param [Hash] attributes Model attributes in the form of hash
135
+ # @return [Object] Returns the model itself
136
+ def build_from_hash(attributes)
137
+ return nil unless attributes.is_a?(Hash)
138
+ self.class.swagger_types.each_pair do |key, type|
139
+ if type =~ /\AArray<(.*)>/i
140
+ # check to ensure the input is an array given that the the attribute
141
+ # is documented as an array but the input is not
142
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
143
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
144
+ end
145
+ elsif !attributes[self.class.attribute_map[key]].nil?
146
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
147
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
148
+ end
149
+
150
+ self
151
+ end
152
+
153
+ # Deserializes the data based on type
154
+ # @param string type Data type
155
+ # @param string value Value to be deserialized
156
+ # @return [Object] Deserialized data
157
+ def _deserialize(type, value)
158
+ case type.to_sym
159
+ when :DateTime
160
+ DateTime.parse(value)
161
+ when :Date
162
+ Date.parse(value)
163
+ when :String
164
+ value.to_s
165
+ when :Integer
166
+ value.to_i
167
+ when :Float
168
+ value.to_f
169
+ when :BOOLEAN
170
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
171
+ true
172
+ else
173
+ false
174
+ end
175
+ when :Object
176
+ # generic object (usually a Hash), return directly
177
+ value
178
+ when /\AArray<(?<inner_type>.+)>\z/
179
+ inner_type = Regexp.last_match[:inner_type]
180
+ value.map { |v| _deserialize(inner_type, v) }
181
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
182
+ k_type = Regexp.last_match[:k_type]
183
+ v_type = Regexp.last_match[:v_type]
184
+ {}.tap do |hash|
185
+ value.each do |k, v|
186
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
187
+ end
188
+ end
189
+ else # model
190
+ temp_model = LaunchDarklyApi.const_get(type).new
191
+ temp_model.build_from_hash(value)
192
+ end
193
+ end
194
+
195
+ # Returns the string representation of the object
196
+ # @return [String] String presentation of the object
197
+ def to_s
198
+ to_hash.to_s
199
+ end
200
+
201
+ # to_body is an alias to to_hash (backward compatibility)
202
+ # @return [Hash] Returns the object in the form of hash
203
+ def to_body
204
+ to_hash
205
+ end
206
+
207
+ # Returns the object in the form of hash
208
+ # @return [Hash] Returns the object in the form of hash
209
+ def to_hash
210
+ hash = {}
211
+ self.class.attribute_map.each_pair do |attr, param|
212
+ value = self.send(attr)
213
+ next if value.nil?
214
+ hash[param] = _to_hash(value)
215
+ end
216
+ hash
217
+ end
218
+
219
+ # Outputs non-array value in the form of hash
220
+ # For object, use to_hash. Otherwise, just return the value
221
+ # @param [Object] value Any valid value
222
+ # @return [Hash] Returns the value in the form of hash
223
+ def _to_hash(value)
224
+ if value.is_a?(Array)
225
+ value.compact.map { |v| _to_hash(v) }
226
+ elsif value.is_a?(Hash)
227
+ {}.tap do |hash|
228
+ value.each { |k, v| hash[k] = _to_hash(v) }
229
+ end
230
+ elsif value.respond_to? :to_hash
231
+ value.to_hash
232
+ else
233
+ value
234
+ end
235
+ end
236
+ end
237
+ end
@@ -0,0 +1,194 @@
1
+ =begin
2
+ #LaunchDarkly REST API
3
+
4
+ #Build custom integrations with the LaunchDarkly REST API
5
+
6
+ OpenAPI spec version: 3.5.0
7
+ Contact: support@launchdarkly.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 2.4.8
10
+
11
+ =end
12
+
13
+ require 'date'
14
+
15
+ module LaunchDarklyApi
16
+ class Tokens
17
+ attr_accessor :_links
18
+
19
+ attr_accessor :items
20
+
21
+ # Attribute mapping from ruby-style variable name to JSON key.
22
+ def self.attribute_map
23
+ {
24
+ :'_links' => :'_links',
25
+ :'items' => :'items'
26
+ }
27
+ end
28
+
29
+ # Attribute type mapping.
30
+ def self.swagger_types
31
+ {
32
+ :'_links' => :'Links',
33
+ :'items' => :'Array<Token>'
34
+ }
35
+ end
36
+
37
+ # Initializes the object
38
+ # @param [Hash] attributes Model attributes in the form of hash
39
+ def initialize(attributes = {})
40
+ return unless attributes.is_a?(Hash)
41
+
42
+ # convert string to symbol for hash key
43
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
44
+
45
+ if attributes.has_key?(:'_links')
46
+ self._links = attributes[:'_links']
47
+ end
48
+
49
+ if attributes.has_key?(:'items')
50
+ if (value = attributes[:'items']).is_a?(Array)
51
+ self.items = value
52
+ end
53
+ end
54
+ end
55
+
56
+ # Show invalid properties with the reasons. Usually used together with valid?
57
+ # @return Array for valid properties with the reasons
58
+ def list_invalid_properties
59
+ invalid_properties = Array.new
60
+ invalid_properties
61
+ end
62
+
63
+ # Check to see if the all the properties in the model are valid
64
+ # @return true if the model is valid
65
+ def valid?
66
+ true
67
+ end
68
+
69
+ # Checks equality by comparing each attribute.
70
+ # @param [Object] Object to be compared
71
+ def ==(o)
72
+ return true if self.equal?(o)
73
+ self.class == o.class &&
74
+ _links == o._links &&
75
+ items == o.items
76
+ end
77
+
78
+ # @see the `==` method
79
+ # @param [Object] Object to be compared
80
+ def eql?(o)
81
+ self == o
82
+ end
83
+
84
+ # Calculates hash code according to all attributes.
85
+ # @return [Fixnum] Hash code
86
+ def hash
87
+ [_links, items].hash
88
+ end
89
+
90
+ # Builds the object from hash
91
+ # @param [Hash] attributes Model attributes in the form of hash
92
+ # @return [Object] Returns the model itself
93
+ def build_from_hash(attributes)
94
+ return nil unless attributes.is_a?(Hash)
95
+ self.class.swagger_types.each_pair do |key, type|
96
+ if type =~ /\AArray<(.*)>/i
97
+ # check to ensure the input is an array given that the the attribute
98
+ # is documented as an array but the input is not
99
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
100
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
101
+ end
102
+ elsif !attributes[self.class.attribute_map[key]].nil?
103
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
104
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
105
+ end
106
+
107
+ self
108
+ end
109
+
110
+ # Deserializes the data based on type
111
+ # @param string type Data type
112
+ # @param string value Value to be deserialized
113
+ # @return [Object] Deserialized data
114
+ def _deserialize(type, value)
115
+ case type.to_sym
116
+ when :DateTime
117
+ DateTime.parse(value)
118
+ when :Date
119
+ Date.parse(value)
120
+ when :String
121
+ value.to_s
122
+ when :Integer
123
+ value.to_i
124
+ when :Float
125
+ value.to_f
126
+ when :BOOLEAN
127
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
128
+ true
129
+ else
130
+ false
131
+ end
132
+ when :Object
133
+ # generic object (usually a Hash), return directly
134
+ value
135
+ when /\AArray<(?<inner_type>.+)>\z/
136
+ inner_type = Regexp.last_match[:inner_type]
137
+ value.map { |v| _deserialize(inner_type, v) }
138
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
139
+ k_type = Regexp.last_match[:k_type]
140
+ v_type = Regexp.last_match[:v_type]
141
+ {}.tap do |hash|
142
+ value.each do |k, v|
143
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
144
+ end
145
+ end
146
+ else # model
147
+ temp_model = LaunchDarklyApi.const_get(type).new
148
+ temp_model.build_from_hash(value)
149
+ end
150
+ end
151
+
152
+ # Returns the string representation of the object
153
+ # @return [String] String presentation of the object
154
+ def to_s
155
+ to_hash.to_s
156
+ end
157
+
158
+ # to_body is an alias to to_hash (backward compatibility)
159
+ # @return [Hash] Returns the object in the form of hash
160
+ def to_body
161
+ to_hash
162
+ end
163
+
164
+ # Returns the object in the form of hash
165
+ # @return [Hash] Returns the object in the form of hash
166
+ def to_hash
167
+ hash = {}
168
+ self.class.attribute_map.each_pair do |attr, param|
169
+ value = self.send(attr)
170
+ next if value.nil?
171
+ hash[param] = _to_hash(value)
172
+ end
173
+ hash
174
+ end
175
+
176
+ # Outputs non-array value in the form of hash
177
+ # For object, use to_hash. Otherwise, just return the value
178
+ # @param [Object] value Any valid value
179
+ # @return [Hash] Returns the value in the form of hash
180
+ def _to_hash(value)
181
+ if value.is_a?(Array)
182
+ value.compact.map { |v| _to_hash(v) }
183
+ elsif value.is_a?(Hash)
184
+ {}.tap do |hash|
185
+ value.each { |k, v| hash[k] = _to_hash(v) }
186
+ end
187
+ elsif value.respond_to? :to_hash
188
+ value.to_hash
189
+ else
190
+ value
191
+ end
192
+ end
193
+ end
194
+ end
@@ -3,7 +3,7 @@
3
3
 
4
4
  #Build custom integrations with the LaunchDarkly REST API
5
5
 
6
- OpenAPI spec version: 3.2.0
6
+ OpenAPI spec version: 3.5.0
7
7
  Contact: support@launchdarkly.com
8
8
  Generated by: https://github.com/swagger-api/swagger-codegen.git
9
9
  Swagger Codegen version: 2.4.8
@@ -3,7 +3,7 @@
3
3
 
4
4
  #Build custom integrations with the LaunchDarkly REST API
5
5
 
6
- OpenAPI spec version: 3.2.0
6
+ OpenAPI spec version: 3.5.0
7
7
  Contact: support@launchdarkly.com
8
8
  Generated by: https://github.com/swagger-api/swagger-codegen.git
9
9
  Swagger Codegen version: 2.4.8