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