gooddata 1.0.0-java

Sign up to get free protection for your applications and to get access to all the features.
Files changed (517) hide show
  1. checksums.yaml +7 -0
  2. data/.document +5 -0
  3. data/.editorconfig +12 -0
  4. data/.flayignore +6 -0
  5. data/.gitignore +38 -0
  6. data/.pronto.yml +3 -0
  7. data/.rspec +5 -0
  8. data/.rubocop.yml +101 -0
  9. data/.travis.yml +9 -0
  10. data/.yardopts +22 -0
  11. data/CHANGELOG.md +272 -0
  12. data/CLI.md +435 -0
  13. data/CONTRIBUTING.md +38 -0
  14. data/DEPENDENCIES.md +880 -0
  15. data/Dockerfile.jruby +17 -0
  16. data/Dockerfile.ruby +19 -0
  17. data/Gemfile +4 -0
  18. data/Guardfile +5 -0
  19. data/LICENSE +22 -0
  20. data/LICENSE.rb +5 -0
  21. data/README.md +78 -0
  22. data/Rakefile +204 -0
  23. data/TODO.md +32 -0
  24. data/authors.sh +4 -0
  25. data/bin/gooddata +7 -0
  26. data/ci.rake +47 -0
  27. data/dependency_decisions.yml +104 -0
  28. data/docker-compose.yml +34 -0
  29. data/gooddata +9 -0
  30. data/gooddata.gemspec +72 -0
  31. data/lib/gooddata.rb +34 -0
  32. data/lib/gooddata/app/app.rb +16 -0
  33. data/lib/gooddata/bricks/base_downloader.rb +86 -0
  34. data/lib/gooddata/bricks/brick.rb +37 -0
  35. data/lib/gooddata/bricks/bricks.rb +17 -0
  36. data/lib/gooddata/bricks/middleware/aws_middleware.rb +41 -0
  37. data/lib/gooddata/bricks/middleware/base_middleware.rb +57 -0
  38. data/lib/gooddata/bricks/middleware/bench_middleware.rb +25 -0
  39. data/lib/gooddata/bricks/middleware/bulk_salesforce_middleware.rb +37 -0
  40. data/lib/gooddata/bricks/middleware/decode_params_middleware.rb +21 -0
  41. data/lib/gooddata/bricks/middleware/dwh_middleware.rb +41 -0
  42. data/lib/gooddata/bricks/middleware/fs_download_middleware.rb +48 -0
  43. data/lib/gooddata/bricks/middleware/fs_upload_middleware.rb +36 -0
  44. data/lib/gooddata/bricks/middleware/gooddata_middleware.rb +112 -0
  45. data/lib/gooddata/bricks/middleware/logger_middleware.rb +33 -0
  46. data/lib/gooddata/bricks/middleware/middleware.rb +12 -0
  47. data/lib/gooddata/bricks/middleware/restforce_middleware.rb +58 -0
  48. data/lib/gooddata/bricks/middleware/stdout_middleware.rb +23 -0
  49. data/lib/gooddata/bricks/middleware/twitter_middleware.rb +29 -0
  50. data/lib/gooddata/bricks/middleware/undot_params_middleware.rb +37 -0
  51. data/lib/gooddata/bricks/pipeline.rb +25 -0
  52. data/lib/gooddata/bricks/utils.rb +18 -0
  53. data/lib/gooddata/cli/cli.rb +27 -0
  54. data/lib/gooddata/cli/commands/auth_cmd.rb +29 -0
  55. data/lib/gooddata/cli/commands/domain_cmd.rb +28 -0
  56. data/lib/gooddata/cli/commands/project_cmd.rb +28 -0
  57. data/lib/gooddata/cli/hooks.rb +56 -0
  58. data/lib/gooddata/cli/shared.rb +66 -0
  59. data/lib/gooddata/cli/terminal.rb +20 -0
  60. data/lib/gooddata/client.rb +67 -0
  61. data/lib/gooddata/commands/api.rb +64 -0
  62. data/lib/gooddata/commands/auth.rb +107 -0
  63. data/lib/gooddata/commands/base.rb +12 -0
  64. data/lib/gooddata/commands/commands.rb +12 -0
  65. data/lib/gooddata/commands/datasets.rb +148 -0
  66. data/lib/gooddata/commands/datawarehouse.rb +20 -0
  67. data/lib/gooddata/commands/domain.rb +40 -0
  68. data/lib/gooddata/commands/process.rb +67 -0
  69. data/lib/gooddata/commands/project.rb +144 -0
  70. data/lib/gooddata/commands/projects.rb +20 -0
  71. data/lib/gooddata/commands/role.rb +36 -0
  72. data/lib/gooddata/commands/runners.rb +47 -0
  73. data/lib/gooddata/commands/scaffold.rb +69 -0
  74. data/lib/gooddata/commands/user.rb +39 -0
  75. data/lib/gooddata/connection.rb +127 -0
  76. data/lib/gooddata/core/core.rb +12 -0
  77. data/lib/gooddata/core/logging.rb +105 -0
  78. data/lib/gooddata/core/nil_logger.rb +32 -0
  79. data/lib/gooddata/core/project.rb +74 -0
  80. data/lib/gooddata/core/rest.rb +149 -0
  81. data/lib/gooddata/core/user.rb +20 -0
  82. data/lib/gooddata/data/data.rb +12 -0
  83. data/lib/gooddata/data/guesser.rb +122 -0
  84. data/lib/gooddata/exceptions/attr_element_not_found.rb +16 -0
  85. data/lib/gooddata/exceptions/command_failed.rb +11 -0
  86. data/lib/gooddata/exceptions/exceptions.rb +12 -0
  87. data/lib/gooddata/exceptions/execution_limit_exceeded.rb +13 -0
  88. data/lib/gooddata/exceptions/export_clone.rb +4 -0
  89. data/lib/gooddata/exceptions/filter_maqlization.rb +16 -0
  90. data/lib/gooddata/exceptions/import_clone.rb +4 -0
  91. data/lib/gooddata/exceptions/malformed_user.rb +15 -0
  92. data/lib/gooddata/exceptions/maql_execution.rb +16 -0
  93. data/lib/gooddata/exceptions/no_project_error.rb +19 -0
  94. data/lib/gooddata/exceptions/object_migration.rb +32 -0
  95. data/lib/gooddata/exceptions/project_not_found.rb +13 -0
  96. data/lib/gooddata/exceptions/segment_not_empty.rb +18 -0
  97. data/lib/gooddata/exceptions/uncomputable_report.rb +13 -0
  98. data/lib/gooddata/exceptions/user_in_different_domain.rb +15 -0
  99. data/lib/gooddata/exceptions/validation_error.rb +16 -0
  100. data/lib/gooddata/extensions/big_decimal.rb +17 -0
  101. data/lib/gooddata/extensions/class.rb +11 -0
  102. data/lib/gooddata/extensions/enumerable.rb +39 -0
  103. data/lib/gooddata/extensions/extensions.rb +10 -0
  104. data/lib/gooddata/extensions/false.rb +23 -0
  105. data/lib/gooddata/extensions/hash.rb +49 -0
  106. data/lib/gooddata/extensions/integer.rb +5 -0
  107. data/lib/gooddata/extensions/nil.rb +19 -0
  108. data/lib/gooddata/extensions/numeric.rb +15 -0
  109. data/lib/gooddata/extensions/object.rb +31 -0
  110. data/lib/gooddata/extensions/string.rb +7 -0
  111. data/lib/gooddata/extensions/symbol.rb +15 -0
  112. data/lib/gooddata/extensions/true.rb +23 -0
  113. data/lib/gooddata/extract.rb +21 -0
  114. data/lib/gooddata/goodzilla/goodzilla.rb +160 -0
  115. data/lib/gooddata/helpers/auth_helpers.rb +75 -0
  116. data/lib/gooddata/helpers/csv_helper.rb +61 -0
  117. data/lib/gooddata/helpers/data_helper.rb +129 -0
  118. data/lib/gooddata/helpers/erb_helper.rb +23 -0
  119. data/lib/gooddata/helpers/global_helpers.rb +266 -0
  120. data/lib/gooddata/helpers/global_helpers_params.rb +292 -0
  121. data/lib/gooddata/helpers/helpers.rb +10 -0
  122. data/lib/gooddata/lcm/actions/actions.rb +12 -0
  123. data/lib/gooddata/lcm/actions/apply_custom_maql.rb +80 -0
  124. data/lib/gooddata/lcm/actions/associate_clients.rb +87 -0
  125. data/lib/gooddata/lcm/actions/base_action.rb +23 -0
  126. data/lib/gooddata/lcm/actions/collect_ca_metrics.rb +53 -0
  127. data/lib/gooddata/lcm/actions/collect_client_projects.rb +78 -0
  128. data/lib/gooddata/lcm/actions/collect_clients.rb +128 -0
  129. data/lib/gooddata/lcm/actions/collect_data_product.rb +57 -0
  130. data/lib/gooddata/lcm/actions/collect_dynamic_schedule_params.rb +62 -0
  131. data/lib/gooddata/lcm/actions/collect_ldm_objects.rb +56 -0
  132. data/lib/gooddata/lcm/actions/collect_meta.rb +88 -0
  133. data/lib/gooddata/lcm/actions/collect_segment_clients.rb +113 -0
  134. data/lib/gooddata/lcm/actions/collect_segments.rb +72 -0
  135. data/lib/gooddata/lcm/actions/collect_tagged_objects.rb +80 -0
  136. data/lib/gooddata/lcm/actions/collect_users_brick_users.rb +46 -0
  137. data/lib/gooddata/lcm/actions/create_segment_masters.rb +160 -0
  138. data/lib/gooddata/lcm/actions/ensure_data_product.rb +53 -0
  139. data/lib/gooddata/lcm/actions/ensure_release_table.rb +53 -0
  140. data/lib/gooddata/lcm/actions/ensure_segments.rb +32 -0
  141. data/lib/gooddata/lcm/actions/ensure_technical_users_domain.rb +70 -0
  142. data/lib/gooddata/lcm/actions/ensure_technical_users_project.rb +83 -0
  143. data/lib/gooddata/lcm/actions/execute_schedules.rb +128 -0
  144. data/lib/gooddata/lcm/actions/hello_world.rb +41 -0
  145. data/lib/gooddata/lcm/actions/import_object_collections.rb +60 -0
  146. data/lib/gooddata/lcm/actions/print_actions.rb +58 -0
  147. data/lib/gooddata/lcm/actions/print_modes.rb +69 -0
  148. data/lib/gooddata/lcm/actions/print_types.rb +52 -0
  149. data/lib/gooddata/lcm/actions/provision_clients.rb +89 -0
  150. data/lib/gooddata/lcm/actions/purge_clients.rb +58 -0
  151. data/lib/gooddata/lcm/actions/rename_existing_client_projects.rb +70 -0
  152. data/lib/gooddata/lcm/actions/segments_filter.rb +50 -0
  153. data/lib/gooddata/lcm/actions/synchronize_attribute_drillpaths.rb +64 -0
  154. data/lib/gooddata/lcm/actions/synchronize_cas.rb +72 -0
  155. data/lib/gooddata/lcm/actions/synchronize_clients.rb +94 -0
  156. data/lib/gooddata/lcm/actions/synchronize_color_palette.rb +67 -0
  157. data/lib/gooddata/lcm/actions/synchronize_etls_in_segment.rb +155 -0
  158. data/lib/gooddata/lcm/actions/synchronize_label_types.rb +64 -0
  159. data/lib/gooddata/lcm/actions/synchronize_ldm.rb +82 -0
  160. data/lib/gooddata/lcm/actions/synchronize_meta.rb +52 -0
  161. data/lib/gooddata/lcm/actions/synchronize_new_segments.rb +61 -0
  162. data/lib/gooddata/lcm/actions/synchronize_processes.rb +66 -0
  163. data/lib/gooddata/lcm/actions/synchronize_schedules.rb +91 -0
  164. data/lib/gooddata/lcm/actions/synchronize_tag_objects.rb +64 -0
  165. data/lib/gooddata/lcm/actions/synchronize_user_filters.rb +210 -0
  166. data/lib/gooddata/lcm/actions/synchronize_user_groups.rb +53 -0
  167. data/lib/gooddata/lcm/actions/synchronize_users.rb +336 -0
  168. data/lib/gooddata/lcm/actions/update_release_table.rb +77 -0
  169. data/lib/gooddata/lcm/data/create_lcm_release.sql.erb +6 -0
  170. data/lib/gooddata/lcm/data/insert_into_lcm_release.sql.erb +11 -0
  171. data/lib/gooddata/lcm/data/select_from_lcm_release.sql.erb +8 -0
  172. data/lib/gooddata/lcm/data/update_lcm_release.sql.erb +7 -0
  173. data/lib/gooddata/lcm/dsl/dsl.rb +50 -0
  174. data/lib/gooddata/lcm/dsl/params_dsl.rb +61 -0
  175. data/lib/gooddata/lcm/dsl/type_dsl.rb +62 -0
  176. data/lib/gooddata/lcm/helpers/check_helper.rb +41 -0
  177. data/lib/gooddata/lcm/helpers/helpers.rb +12 -0
  178. data/lib/gooddata/lcm/helpers/tags_helper.rb +36 -0
  179. data/lib/gooddata/lcm/lcm.rb +325 -0
  180. data/lib/gooddata/lcm/lcm2.rb +400 -0
  181. data/lib/gooddata/lcm/types/base_type.rb +29 -0
  182. data/lib/gooddata/lcm/types/class/ads_client.rb +35 -0
  183. data/lib/gooddata/lcm/types/class/class.rb +21 -0
  184. data/lib/gooddata/lcm/types/class/gd_client.rb +35 -0
  185. data/lib/gooddata/lcm/types/class/types.rb +12 -0
  186. data/lib/gooddata/lcm/types/complex/complex.rb +33 -0
  187. data/lib/gooddata/lcm/types/complex/release_query.rb +35 -0
  188. data/lib/gooddata/lcm/types/complex/segment.rb +40 -0
  189. data/lib/gooddata/lcm/types/complex/synchronization_info.rb +35 -0
  190. data/lib/gooddata/lcm/types/complex/tokens.rb +31 -0
  191. data/lib/gooddata/lcm/types/complex/types.rb +12 -0
  192. data/lib/gooddata/lcm/types/complex/update_preference.rb +38 -0
  193. data/lib/gooddata/lcm/types/complex/users_brick_config.rb +32 -0
  194. data/lib/gooddata/lcm/types/param.rb +16 -0
  195. data/lib/gooddata/lcm/types/scalar/bool.rb +22 -0
  196. data/lib/gooddata/lcm/types/scalar/hash.rb +22 -0
  197. data/lib/gooddata/lcm/types/scalar/integer.rb +22 -0
  198. data/lib/gooddata/lcm/types/scalar/object.rb +22 -0
  199. data/lib/gooddata/lcm/types/scalar/string.rb +22 -0
  200. data/lib/gooddata/lcm/types/scalar/types.rb +12 -0
  201. data/lib/gooddata/lcm/types/special/array.rb +33 -0
  202. data/lib/gooddata/lcm/types/special/enum.rb +15 -0
  203. data/lib/gooddata/lcm/types/special/types.rb +12 -0
  204. data/lib/gooddata/lcm/types/types.rb +12 -0
  205. data/lib/gooddata/lcm/user_bricks_helper.rb +32 -0
  206. data/lib/gooddata/mixins/author.rb +26 -0
  207. data/lib/gooddata/mixins/content_getter.rb +15 -0
  208. data/lib/gooddata/mixins/content_property_reader.rb +17 -0
  209. data/lib/gooddata/mixins/content_property_writer.rb +17 -0
  210. data/lib/gooddata/mixins/contributor.rb +20 -0
  211. data/lib/gooddata/mixins/data_getter.rb +15 -0
  212. data/lib/gooddata/mixins/data_property_reader.rb +19 -0
  213. data/lib/gooddata/mixins/data_property_writer.rb +19 -0
  214. data/lib/gooddata/mixins/inspector.rb +53 -0
  215. data/lib/gooddata/mixins/is_attribute.rb +17 -0
  216. data/lib/gooddata/mixins/is_dimension.rb +17 -0
  217. data/lib/gooddata/mixins/is_fact.rb +17 -0
  218. data/lib/gooddata/mixins/is_folder.rb +11 -0
  219. data/lib/gooddata/mixins/is_label.rb +19 -0
  220. data/lib/gooddata/mixins/links.rb +15 -0
  221. data/lib/gooddata/mixins/md_finders.rb +79 -0
  222. data/lib/gooddata/mixins/md_grantees.rb +42 -0
  223. data/lib/gooddata/mixins/md_id_to_uri.rb +39 -0
  224. data/lib/gooddata/mixins/md_json.rb +15 -0
  225. data/lib/gooddata/mixins/md_lock.rb +87 -0
  226. data/lib/gooddata/mixins/md_object_id.rb +15 -0
  227. data/lib/gooddata/mixins/md_object_indexer.rb +74 -0
  228. data/lib/gooddata/mixins/md_object_query.rb +134 -0
  229. data/lib/gooddata/mixins/md_relations.rb +43 -0
  230. data/lib/gooddata/mixins/meta_getter.rb +17 -0
  231. data/lib/gooddata/mixins/meta_property_reader.rb +19 -0
  232. data/lib/gooddata/mixins/meta_property_writer.rb +19 -0
  233. data/lib/gooddata/mixins/mixins.rb +19 -0
  234. data/lib/gooddata/mixins/not_attribute.rb +17 -0
  235. data/lib/gooddata/mixins/not_exportable.rb +15 -0
  236. data/lib/gooddata/mixins/not_fact.rb +17 -0
  237. data/lib/gooddata/mixins/not_group.rb +17 -0
  238. data/lib/gooddata/mixins/not_label.rb +19 -0
  239. data/lib/gooddata/mixins/not_metric.rb +19 -0
  240. data/lib/gooddata/mixins/obj_id.rb +15 -0
  241. data/lib/gooddata/mixins/rest_getters.rb +17 -0
  242. data/lib/gooddata/mixins/rest_resource.rb +47 -0
  243. data/lib/gooddata/mixins/root_key_getter.rb +15 -0
  244. data/lib/gooddata/mixins/root_key_setter.rb +15 -0
  245. data/lib/gooddata/mixins/timestamps.rb +19 -0
  246. data/lib/gooddata/mixins/to_json.rb +11 -0
  247. data/lib/gooddata/mixins/uri_getter.rb +9 -0
  248. data/lib/gooddata/models/ads_output_stage.rb +85 -0
  249. data/lib/gooddata/models/automated_data_distribution.rb +36 -0
  250. data/lib/gooddata/models/blueprint/anchor_field.rb +65 -0
  251. data/lib/gooddata/models/blueprint/attribute_field.rb +45 -0
  252. data/lib/gooddata/models/blueprint/blueprint.rb +11 -0
  253. data/lib/gooddata/models/blueprint/blueprint_field.rb +70 -0
  254. data/lib/gooddata/models/blueprint/dashboard_builder.rb +30 -0
  255. data/lib/gooddata/models/blueprint/dataset_blueprint.rb +455 -0
  256. data/lib/gooddata/models/blueprint/date_dimension.rb +20 -0
  257. data/lib/gooddata/models/blueprint/fact_field.rb +20 -0
  258. data/lib/gooddata/models/blueprint/label_field.rb +47 -0
  259. data/lib/gooddata/models/blueprint/project_blueprint.rb +791 -0
  260. data/lib/gooddata/models/blueprint/project_builder.rb +103 -0
  261. data/lib/gooddata/models/blueprint/reference_field.rb +43 -0
  262. data/lib/gooddata/models/blueprint/schema_blueprint.rb +160 -0
  263. data/lib/gooddata/models/blueprint/schema_builder.rb +89 -0
  264. data/lib/gooddata/models/blueprint/to_manifest.rb +185 -0
  265. data/lib/gooddata/models/blueprint/to_wire.rb +173 -0
  266. data/lib/gooddata/models/channel_configuration.rb +112 -0
  267. data/lib/gooddata/models/client.rb +236 -0
  268. data/lib/gooddata/models/client_synchronization_result.rb +31 -0
  269. data/lib/gooddata/models/client_synchronization_result_details.rb +41 -0
  270. data/lib/gooddata/models/data_product.rb +149 -0
  271. data/lib/gooddata/models/datawarehouse.rb +114 -0
  272. data/lib/gooddata/models/domain.rb +505 -0
  273. data/lib/gooddata/models/execution.rb +115 -0
  274. data/lib/gooddata/models/execution_detail.rb +81 -0
  275. data/lib/gooddata/models/from_wire.rb +173 -0
  276. data/lib/gooddata/models/invitation.rb +75 -0
  277. data/lib/gooddata/models/links.rb +50 -0
  278. data/lib/gooddata/models/membership.rb +441 -0
  279. data/lib/gooddata/models/metadata.rb +324 -0
  280. data/lib/gooddata/models/metadata/attribute.rb +155 -0
  281. data/lib/gooddata/models/metadata/dashboard.rb +120 -0
  282. data/lib/gooddata/models/metadata/dashboard/dashboard_item.rb +76 -0
  283. data/lib/gooddata/models/metadata/dashboard/filter_apply_item.rb +37 -0
  284. data/lib/gooddata/models/metadata/dashboard/filter_item.rb +64 -0
  285. data/lib/gooddata/models/metadata/dashboard/geo_chart_item.rb +56 -0
  286. data/lib/gooddata/models/metadata/dashboard/headline_item.rb +56 -0
  287. data/lib/gooddata/models/metadata/dashboard/iframe_item.rb +46 -0
  288. data/lib/gooddata/models/metadata/dashboard/report_item.rb +92 -0
  289. data/lib/gooddata/models/metadata/dashboard/text_item.rb +55 -0
  290. data/lib/gooddata/models/metadata/dashboard_tab.rb +141 -0
  291. data/lib/gooddata/models/metadata/dataset.rb +67 -0
  292. data/lib/gooddata/models/metadata/dimension.rb +57 -0
  293. data/lib/gooddata/models/metadata/fact.rb +51 -0
  294. data/lib/gooddata/models/metadata/folder.rb +49 -0
  295. data/lib/gooddata/models/metadata/label.rb +128 -0
  296. data/lib/gooddata/models/metadata/metadata.rb +12 -0
  297. data/lib/gooddata/models/metadata/metric.rb +206 -0
  298. data/lib/gooddata/models/metadata/report.rb +268 -0
  299. data/lib/gooddata/models/metadata/report_definition.rb +272 -0
  300. data/lib/gooddata/models/metadata/scheduled_mail.rb +277 -0
  301. data/lib/gooddata/models/metadata/scheduled_mail/dashboard_attachment.rb +62 -0
  302. data/lib/gooddata/models/metadata/scheduled_mail/report_attachment.rb +64 -0
  303. data/lib/gooddata/models/metadata/variable.rb +96 -0
  304. data/lib/gooddata/models/model.rb +293 -0
  305. data/lib/gooddata/models/models.rb +12 -0
  306. data/lib/gooddata/models/module_constants.rb +31 -0
  307. data/lib/gooddata/models/notification_rule.rb +113 -0
  308. data/lib/gooddata/models/process.rb +371 -0
  309. data/lib/gooddata/models/profile.rb +451 -0
  310. data/lib/gooddata/models/project.rb +2030 -0
  311. data/lib/gooddata/models/project_creator.rb +209 -0
  312. data/lib/gooddata/models/project_log_formatter.rb +204 -0
  313. data/lib/gooddata/models/project_metadata.rb +67 -0
  314. data/lib/gooddata/models/project_role.rb +79 -0
  315. data/lib/gooddata/models/report_data_result.rb +270 -0
  316. data/lib/gooddata/models/schedule.rb +538 -0
  317. data/lib/gooddata/models/segment.rb +274 -0
  318. data/lib/gooddata/models/style_setting.rb +62 -0
  319. data/lib/gooddata/models/subscription.rb +188 -0
  320. data/lib/gooddata/models/tab_builder.rb +27 -0
  321. data/lib/gooddata/models/user_filters/mandatory_user_filter.rb +76 -0
  322. data/lib/gooddata/models/user_filters/user_filter.rb +101 -0
  323. data/lib/gooddata/models/user_filters/user_filter_builder.rb +553 -0
  324. data/lib/gooddata/models/user_filters/user_filters.rb +13 -0
  325. data/lib/gooddata/models/user_filters/variable_user_filter.rb +33 -0
  326. data/lib/gooddata/models/user_group.rb +250 -0
  327. data/lib/gooddata/rest/README.md +37 -0
  328. data/lib/gooddata/rest/client.rb +396 -0
  329. data/lib/gooddata/rest/connection.rb +776 -0
  330. data/lib/gooddata/rest/object.rb +69 -0
  331. data/lib/gooddata/rest/object_factory.rb +51 -0
  332. data/lib/gooddata/rest/resource.rb +27 -0
  333. data/lib/gooddata/rest/rest.rb +24 -0
  334. data/lib/gooddata/version.rb +23 -0
  335. data/lib/templates/bricks/brick.rb.erb +7 -0
  336. data/lib/templates/bricks/main.rb.erb +5 -0
  337. data/lib/templates/project/Goodfile.erb +4 -0
  338. data/lib/templates/project/data/commits.csv +4 -0
  339. data/lib/templates/project/data/devs.csv +4 -0
  340. data/lib/templates/project/data/repos.csv +3 -0
  341. data/lib/templates/project/model/model.rb.erb +20 -0
  342. data/spec/.rubocop.yml +16 -0
  343. data/spec/bricks/bricks_spec.rb +110 -0
  344. data/spec/bricks/default-config.json +8 -0
  345. data/spec/data/.gooddata +4 -0
  346. data/spec/data/blueprints/additional_dataset_module.json +32 -0
  347. data/spec/data/blueprints/attribute_sort_order_blueprint.json +72 -0
  348. data/spec/data/blueprints/big_blueprint_not_pruned.json +2079 -0
  349. data/spec/data/blueprints/invalid_blueprint.json +103 -0
  350. data/spec/data/blueprints/m_n_model.json +104 -0
  351. data/spec/data/blueprints/model_module.json +25 -0
  352. data/spec/data/blueprints/test_blueprint.json +39 -0
  353. data/spec/data/blueprints/test_project_model_spec.json +106 -0
  354. data/spec/data/cc/data/source/commits.csv +4 -0
  355. data/spec/data/cc/data/source/devs.csv +4 -0
  356. data/spec/data/cc/data/source/repos.csv +3 -0
  357. data/spec/data/cc/devel.prm +0 -0
  358. data/spec/data/cc/graph/graph.grf +11 -0
  359. data/spec/data/cc/workspace.prm +19 -0
  360. data/spec/data/column_based_permissions.csv +7 -0
  361. data/spec/data/column_based_permissions2.csv +6 -0
  362. data/spec/data/dynamic_schedule_params_table.csv +7 -0
  363. data/spec/data/gd_gse_data_blueprint.json +1371 -0
  364. data/spec/data/gd_gse_data_manifest.json +1424 -0
  365. data/spec/data/gd_gse_data_model.json +1772 -0
  366. data/spec/data/gooddata_version_process/gooddata_version.rb +9 -0
  367. data/spec/data/gooddata_version_process/gooddata_version.zip +0 -0
  368. data/spec/data/hello_world_process/hello_world.rb +9 -0
  369. data/spec/data/hello_world_process/hello_world.zip +0 -0
  370. data/spec/data/line_based_permissions.csv +3 -0
  371. data/spec/data/manifests/test_blueprint.json +32 -0
  372. data/spec/data/manifests/test_project.json +107 -0
  373. data/spec/data/reports/left_attr_report.json +108 -0
  374. data/spec/data/reports/metric_only_one_line.json +83 -0
  375. data/spec/data/reports/report_1.json +197 -0
  376. data/spec/data/reports/top_attr_report.json +108 -0
  377. data/spec/data/ruby_params_process/ruby_params.rb +9 -0
  378. data/spec/data/ruby_process/deep_files/deep_stuff.txt +1 -0
  379. data/spec/data/ruby_process/process.rb +8 -0
  380. data/spec/data/ruby_process/stuff.txt +1 -0
  381. data/spec/data/superfluous_titles_view.json +81 -0
  382. data/spec/data/test-ci-data.csv +2 -0
  383. data/spec/data/users.csv +12 -0
  384. data/spec/data/wire_models/attribute_sort_by_model.json +73 -0
  385. data/spec/data/wire_models/model_view.json +1775 -0
  386. data/spec/data/wire_models/nu_model.json +3046 -0
  387. data/spec/data/wire_models/test_blueprint.json +66 -0
  388. data/spec/data/wire_test_project.json +150 -0
  389. data/spec/data/workspace_table.csv +3 -0
  390. data/spec/environment/default.rb +43 -0
  391. data/spec/environment/development.rb +32 -0
  392. data/spec/environment/environment.rb +38 -0
  393. data/spec/environment/production.rb +27 -0
  394. data/spec/environment/staging.rb +33 -0
  395. data/spec/environment/testing.rb +32 -0
  396. data/spec/helpers/blueprint_helper.rb +27 -0
  397. data/spec/helpers/cli_helper.rb +38 -0
  398. data/spec/helpers/connection_helper.rb +43 -0
  399. data/spec/helpers/crypto_helper.rb +19 -0
  400. data/spec/helpers/csv_helper.rb +20 -0
  401. data/spec/helpers/process_helper.rb +35 -0
  402. data/spec/helpers/project_helper.rb +74 -0
  403. data/spec/helpers/schedule_helper.rb +33 -0
  404. data/spec/helpers/spec_helper.rb +17 -0
  405. data/spec/integration/ads_output_stage_spec.rb +45 -0
  406. data/spec/integration/blueprint_updates_spec.rb +107 -0
  407. data/spec/integration/blueprint_with_ca_spec.rb +56 -0
  408. data/spec/integration/blueprint_with_grain_spec.rb +74 -0
  409. data/spec/integration/channel_configuration_spec.rb +67 -0
  410. data/spec/integration/clients_spec.rb +164 -0
  411. data/spec/integration/command_datawarehouse_spec.rb +45 -0
  412. data/spec/integration/command_projects_spec.rb +32 -0
  413. data/spec/integration/commands/command_projects_spec.rb +22 -0
  414. data/spec/integration/core/connection_spec.rb +56 -0
  415. data/spec/integration/core/logging_spec.rb +130 -0
  416. data/spec/integration/core/project_spec.rb +54 -0
  417. data/spec/integration/create_from_template_spec.rb +29 -0
  418. data/spec/integration/create_project_spec.rb +27 -0
  419. data/spec/integration/date_dim_switch_spec.rb +150 -0
  420. data/spec/integration/deprecated_load_spec.rb +60 -0
  421. data/spec/integration/full_process_schedule_spec.rb +367 -0
  422. data/spec/integration/full_project_spec.rb +592 -0
  423. data/spec/integration/helpers_spec.rb +16 -0
  424. data/spec/integration/lcm_spec.rb +54 -0
  425. data/spec/integration/mixins/id_to_uri_spec.rb +44 -0
  426. data/spec/integration/models/data_product_spec.rb +71 -0
  427. data/spec/integration/models/domain_spec.rb +162 -0
  428. data/spec/integration/models/invitation_spec.rb +17 -0
  429. data/spec/integration/models/membership_spec.rb +127 -0
  430. data/spec/integration/models/metadata/report_spec.rb +54 -0
  431. data/spec/integration/models/params_spec.rb +118 -0
  432. data/spec/integration/models/profile_spec.rb +210 -0
  433. data/spec/integration/models/project_role_spec.rb +94 -0
  434. data/spec/integration/models/project_spec.rb +225 -0
  435. data/spec/integration/models/schedule_spec.rb +485 -0
  436. data/spec/integration/models/unit_project_spec.rb +130 -0
  437. data/spec/integration/over_to_user_filters_spec.rb +98 -0
  438. data/spec/integration/partial_md_export_import_spec.rb +41 -0
  439. data/spec/integration/project_spec.rb +381 -0
  440. data/spec/integration/rest_spec.rb +214 -0
  441. data/spec/integration/schedule_spec.rb +613 -0
  442. data/spec/integration/segments_spec.rb +100 -0
  443. data/spec/integration/subscription_spec.rb +88 -0
  444. data/spec/integration/urn_date_dim_spec.rb +53 -0
  445. data/spec/integration/user_filters_spec.rb +306 -0
  446. data/spec/integration/user_group_spec.rb +147 -0
  447. data/spec/integration/variables_spec.rb +189 -0
  448. data/spec/logging_in_logging_out_spec.rb +91 -0
  449. data/spec/spec_helper.rb +66 -0
  450. data/spec/unit/actions/associate_clients_spec.rb +47 -0
  451. data/spec/unit/actions/collect_client_projects_spec.rb +47 -0
  452. data/spec/unit/actions/collect_clients_spec.rb +65 -0
  453. data/spec/unit/actions/collect_data_product_spec.rb +56 -0
  454. data/spec/unit/actions/collect_dynamic_schedule_params_spec.rb +56 -0
  455. data/spec/unit/actions/collect_meta_spec.rb +88 -0
  456. data/spec/unit/actions/collect_segment_clients_spec.rb +81 -0
  457. data/spec/unit/actions/collect_tagged_objects_spec.rb +126 -0
  458. data/spec/unit/actions/collect_users_brick_users_spec.rb +36 -0
  459. data/spec/unit/actions/create_segment_masters_spec.rb +64 -0
  460. data/spec/unit/actions/ensure_data_product_spec.rb +38 -0
  461. data/spec/unit/actions/ensure_technical_users_domain_spec.rb +51 -0
  462. data/spec/unit/actions/ensure_technical_users_project_spec.rb +72 -0
  463. data/spec/unit/actions/execute_schedules_spec.rb +94 -0
  464. data/spec/unit/actions/provision_clients_spec.rb +45 -0
  465. data/spec/unit/actions/purge_clients_spec.rb +47 -0
  466. data/spec/unit/actions/rename_existing_client_projects_spec.rb +54 -0
  467. data/spec/unit/actions/segments_filter_spec.rb +46 -0
  468. data/spec/unit/actions/shared_examples_for_user_actions.rb +26 -0
  469. data/spec/unit/actions/synchronize_cas_spec.rb +58 -0
  470. data/spec/unit/actions/synchronize_etls_in_segment_spec.rb +212 -0
  471. data/spec/unit/actions/synchronize_ldm_spec.rb +57 -0
  472. data/spec/unit/actions/synchronize_user_filters_spec.rb +146 -0
  473. data/spec/unit/actions/synchronize_user_groups_spec.rb +49 -0
  474. data/spec/unit/actions/synchronize_users_spec.rb +134 -0
  475. data/spec/unit/bricks/bricks_spec.rb +34 -0
  476. data/spec/unit/bricks/middleware/aws_middelware_spec.rb +98 -0
  477. data/spec/unit/bricks/middleware/bench_middleware_spec.rb +15 -0
  478. data/spec/unit/bricks/middleware/bulk_salesforce_middleware_spec.rb +15 -0
  479. data/spec/unit/bricks/middleware/gooddata_middleware_spec.rb +15 -0
  480. data/spec/unit/bricks/middleware/logger_middleware_spec.rb +30 -0
  481. data/spec/unit/bricks/middleware/restforce_middleware_spec.rb +15 -0
  482. data/spec/unit/bricks/middleware/stdout_middleware_spec.rb +15 -0
  483. data/spec/unit/bricks/middleware/twitter_middleware_spec.rb +15 -0
  484. data/spec/unit/cli/cli_spec.rb +17 -0
  485. data/spec/unit/cli/commands/cmd_auth_spec.rb +17 -0
  486. data/spec/unit/core/nil_logger_spec.rb +13 -0
  487. data/spec/unit/extensions/hash_spec.rb +22 -0
  488. data/spec/unit/godzilla/goodzilla_spec.rb +74 -0
  489. data/spec/unit/helpers/csv_helper_spec.rb +22 -0
  490. data/spec/unit/helpers/data_helper_spec.rb +67 -0
  491. data/spec/unit/helpers/global_helpers_spec.rb +264 -0
  492. data/spec/unit/helpers_spec.rb +254 -0
  493. data/spec/unit/lcm/user_bricks_helper_spec.rb +58 -0
  494. data/spec/unit/models/blueprint/attribute_sort_by_spec.rb +20 -0
  495. data/spec/unit/models/blueprint/attributes_spec.rb +28 -0
  496. data/spec/unit/models/blueprint/dataset_spec.rb +120 -0
  497. data/spec/unit/models/blueprint/labels_spec.rb +43 -0
  498. data/spec/unit/models/blueprint/project_blueprint_spec.rb +642 -0
  499. data/spec/unit/models/blueprint/reference_spec.rb +28 -0
  500. data/spec/unit/models/blueprint/schema_builder_spec.rb +36 -0
  501. data/spec/unit/models/blueprint/to_wire_spec.rb +195 -0
  502. data/spec/unit/models/execution_spec.rb +109 -0
  503. data/spec/unit/models/from_wire_spec.rb +301 -0
  504. data/spec/unit/models/metadata_spec.rb +140 -0
  505. data/spec/unit/models/metric_spec.rb +129 -0
  506. data/spec/unit/models/model_spec.rb +77 -0
  507. data/spec/unit/models/project_creator_spec.rb +90 -0
  508. data/spec/unit/models/project_spec.rb +94 -0
  509. data/spec/unit/models/report_result_data_spec.rb +194 -0
  510. data/spec/unit/models/to_manifest_spec.rb +136 -0
  511. data/spec/unit/models/user_filters/user_filter_builder_spec.rb +110 -0
  512. data/spec/unit/models/user_filters_spec.rb +95 -0
  513. data/spec/unit/models/variable_spec.rb +280 -0
  514. data/spec/unit/rest/polling_spec.rb +101 -0
  515. data/spec/unit/rest/resource_spec.rb +10 -0
  516. data/yard-server.sh +3 -0
  517. metadata +1207 -0
@@ -0,0 +1,336 @@
1
+ # encoding: UTF-8
2
+ #
3
+ # Copyright (c) 2010-2017 GoodData Corporation. All rights reserved.
4
+ # This source code is licensed under the BSD-style license found in the
5
+ # LICENSE file in the root directory of this source tree.
6
+
7
+ require_relative 'base_action'
8
+ require_relative '../user_bricks_helper'
9
+
10
+ module GoodData
11
+ module LCM2
12
+ class SynchronizeUsers < BaseAction
13
+ DESCRIPTION = 'Synchronizes Users Between Projects'
14
+
15
+ PARAMS = define_params(self) do
16
+ description 'Client Used For Connecting To GD'
17
+ param :gdc_gd_client, instance_of(Type::GdClientType), required: true
18
+
19
+ description 'Input Source'
20
+ param :input_source, instance_of(Type::HashType), required: true
21
+
22
+ description 'Synchronization Mode (e.g. sync_one_project_based_on_pid)'
23
+ param :sync_mode, instance_of(Type::StringType), required: false, default: 'sync_domain_and_project'
24
+
25
+ description 'Column That Contains Target Project IDs'
26
+ param :multiple_projects_column, instance_of(Type::StringType), required: false
27
+
28
+ # gdc_project/gdc_project_id, required: true
29
+ # organization/domain, required: true
30
+ end
31
+
32
+ class << self
33
+ MODES = %w(
34
+ add_to_organization
35
+ sync_project
36
+ sync_domain_and_project
37
+ sync_multiple_projects_based_on_pid
38
+ sync_one_project_based_on_pid
39
+ sync_one_project_based_on_custom_id
40
+ sync_multiple_projects_based_on_custom_id
41
+ sync_domain_client_workspaces
42
+ )
43
+
44
+ def version
45
+ '0.0.1'
46
+ end
47
+
48
+ def call(params)
49
+ client = params.gdc_gd_client
50
+ domain_name = params.organization || params.domain
51
+ project = client.projects(params.gdc_project) || client.projects(params.gdc_project_id)
52
+ data_source = GoodData::Helpers::DataSource.new(params.input_source)
53
+ data_product = params.data_product
54
+ mode = params.sync_mode
55
+ unless mode.nil? || MODES.include?(mode)
56
+ fail "The parameter \"sync_mode\" has to have one of the values #{MODES.map(&:to_s).join(', ')} or has to be empty."
57
+ end
58
+
59
+ whitelists = Set.new(params.whitelists || []) + Set.new((params.regexp_whitelists || []).map { |r| /#{r}/ }) + Set.new([client.user.login])
60
+
61
+ [domain_name, data_source].each do |param|
62
+ fail param + ' is required in the block parameters.' unless param
63
+ end
64
+
65
+ domain = client.domain(domain_name)
66
+
67
+ ignore_failures = GoodData::Helpers.to_boolean(params.ignore_failures)
68
+ remove_users_from_project = GoodData::Helpers.to_boolean(params.remove_users_from_project)
69
+ do_not_touch_users_that_are_not_mentioned = GoodData::Helpers.to_boolean(params.do_not_touch_users_that_are_not_mentioned)
70
+ create_non_existing_user_groups = GoodData::Helpers.to_boolean(params.create_non_existing_user_groups || true)
71
+
72
+ new_users = load_data(params, data_source).compact
73
+
74
+ # There are several scenarios we want to provide with this brick
75
+ # 1) Sync only domain
76
+ # 2) Sync both domain and project
77
+ # 3) Sync multiple projects. Sync them by using one file. The file has to
78
+ # contain additional column that contains the PID of the project so the
79
+ # process can partition the users correctly. The column is configurable
80
+ # 4) Sync one project the users are filtered based on a column in the data
81
+ # that should contain pid of the project
82
+ # 5) Sync one project. The users are filtered form a given file based on the
83
+ # value in the file. The value is compared against the value
84
+ # GOODOT_CUSTOM_PROJECT_ID that is saved in project metadata. This is
85
+ # aiming at solving the problem that the customer cannot give us the
86
+ # value of a project id in the data since he does not know it upfront
87
+ # and we cannot influence its value.
88
+ results = case mode
89
+ when 'add_to_organization'
90
+ domain.create_users(new_users.uniq { |u| u[:login] || u[:email] })
91
+ when 'sync_project'
92
+ project.import_users(new_users,
93
+ domain: domain,
94
+ whitelists: whitelists,
95
+ ignore_failures: ignore_failures,
96
+ remove_users_from_project: remove_users_from_project,
97
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
98
+ create_non_existing_user_groups: create_non_existing_user_groups)
99
+ when 'sync_multiple_projects_based_on_pid'
100
+ new_users.group_by { |u| u[:pid] }.flat_map do |project_id, users|
101
+ begin
102
+ project = client.projects(project_id)
103
+ fail "You (user executing the script - #{client.user.login}) is not admin in project \"#{project_id}\"." unless project.am_i_admin?
104
+ project.import_users(users,
105
+ domain: domain,
106
+ whitelists: whitelists,
107
+ ignore_failures: ignore_failures,
108
+ remove_users_from_project: remove_users_from_project,
109
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
110
+ create_non_existing_user_groups: create_non_existing_user_groups)
111
+ rescue RestClient::ResourceNotFound
112
+ fail "Project \"#{project_id}\" was not found. Please check your project ids in the source file"
113
+ rescue RestClient::Gone
114
+ fail "Seems like you (user executing the script - #{client.user.login}) do not have access to project \"#{project_id}\""
115
+ rescue RestClient::Forbidden
116
+ fail "User #{client.user.login} is not enabled within project \"#{project_id}\""
117
+ end
118
+ end
119
+ when 'sync_one_project_based_on_pid'
120
+ filtered_users = new_users.select { |u| u[:pid] == project.pid }
121
+ project.import_users(filtered_users,
122
+ domain: domain,
123
+ whitelists: whitelists,
124
+ ignore_failures: ignore_failures,
125
+ remove_users_from_project: remove_users_from_project,
126
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
127
+ create_non_existing_user_groups: create_non_existing_user_groups)
128
+ when 'sync_one_project_based_on_custom_id'
129
+ filter_value = UserBricksHelper.resolve_client_id(domain, project, data_product)
130
+
131
+ filtered_users = new_users.select do |u|
132
+ fail "Column for determining the project assignement is empty for \"#{u[:login]}\"" if u[:pid].blank?
133
+ client_id = u[:pid].to_s
134
+ client_id == filter_value
135
+ end
136
+
137
+ if filtered_users.empty?
138
+ params.gdc_logger.warn(
139
+ "Project \"#{project.pid}\" does not match " \
140
+ "any client ids in input source (both " \
141
+ "GOODOT_CUSTOM_PROJECT_ID and SEGMENT/CLIENT). " \
142
+ "We are unable to get the value to filter users."
143
+ )
144
+ end
145
+
146
+ puts "Project #{project.pid} will receive #{filtered_users.count} from #{new_users.count} users"
147
+ project.import_users(filtered_users,
148
+ domain: domain,
149
+ whitelists: whitelists,
150
+ ignore_failures: ignore_failures,
151
+ remove_users_from_project: remove_users_from_project,
152
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
153
+ create_non_existing_user_groups: create_non_existing_user_groups)
154
+ when 'sync_multiple_projects_based_on_custom_id'
155
+ new_users.group_by { |u| u[:pid] }.flat_map do |client_id, users|
156
+ fail "Client id cannot be empty" if client_id.blank?
157
+ begin
158
+ project = domain.clients(client_id, data_product).project
159
+ rescue RestClient::BadRequest => e
160
+ raise e unless /does not exist in data product/ =~ e.response
161
+ fail "The client \"#{client_id}\" does not exist in data product \"#{data_product.data_product_id}\""
162
+ end
163
+ fail "Client #{client_id} does not have project." unless project
164
+ puts "Project #{project.pid} of client #{client_id} will receive #{users.count} users"
165
+ project.import_users(users,
166
+ domain: domain,
167
+ whitelists: whitelists,
168
+ ignore_failures: ignore_failures,
169
+ remove_users_from_project: remove_users_from_project,
170
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
171
+ create_non_existing_user_groups: create_non_existing_user_groups)
172
+ end
173
+ when 'sync_domain_client_workspaces'
174
+ domain_clients = domain.clients(:all, data_product)
175
+ if params.segments
176
+ segment_uris = params.segments.map(&:uri)
177
+ domain_clients = domain_clients.select { |c| segment_uris.include?(c.segment_uri) }
178
+ end
179
+ working_client_ids = []
180
+ res = []
181
+ res += new_users.group_by { |u| u[:pid] }.flat_map do |client_id, users|
182
+ fail "Client id cannot be empty" if client_id.blank?
183
+ c = domain.clients(client_id, data_product)
184
+ if params.segments && !segment_uris.include?(c.segment_uri)
185
+ puts "Client #{client_id} is outside segments_filter #{params.segments}"
186
+ next
187
+ end
188
+ project = c.project
189
+ fail "Client #{client_id} does not have project." unless project
190
+ working_client_ids << client_id.to_s
191
+ puts "Project #{project.pid} of client #{client_id} will receive #{users.count} users"
192
+ project.import_users(users,
193
+ domain: domain,
194
+ whitelists: whitelists,
195
+ ignore_failures: ignore_failures,
196
+ remove_users_from_project: remove_users_from_project,
197
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
198
+ create_non_existing_user_groups: create_non_existing_user_groups)
199
+ end
200
+
201
+ params.gdc_logger.debug("Working client ids are: #{working_client_ids.join(', ')}")
202
+
203
+ unless do_not_touch_users_that_are_not_mentioned
204
+ domain_clients.each do |c|
205
+ next if working_client_ids.include?(c.client_id.to_s)
206
+ begin
207
+ project = c.project
208
+ rescue => e
209
+ puts "Error when accessing project of client #{c.client_id}. Error: #{e}"
210
+ next
211
+ end
212
+ unless project
213
+ puts "Client #{c.client_id} has no project."
214
+ next
215
+ end
216
+ if project.deleted?
217
+ puts "Project #{project.pid} of client #{c.client_id} is deleted."
218
+ next
219
+ end
220
+ puts "Synchronizing all users in project #{project.pid} of client #{c.client_id}"
221
+ res += project.import_users([],
222
+ domain: domain,
223
+ whitelists: whitelists,
224
+ ignore_failures: ignore_failures,
225
+ remove_users_from_project: remove_users_from_project,
226
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
227
+ create_non_existing_user_groups: create_non_existing_user_groups)
228
+ end
229
+ end
230
+
231
+ res
232
+ when 'sync_domain_and_project'
233
+ domain.create_users(new_users, ignore_failures: ignore_failures)
234
+ project.import_users(new_users,
235
+ domain: domain,
236
+ whitelists: whitelists,
237
+ ignore_failures: ignore_failures,
238
+ remove_users_from_project: remove_users_from_project,
239
+ do_not_touch_users_that_are_not_mentioned: do_not_touch_users_that_are_not_mentioned,
240
+ create_non_existing_user_groups: create_non_existing_user_groups)
241
+ end
242
+
243
+ results.compact!
244
+ counts = results.group_by { |r| r[:type] }.map { |g, r| [g, r.count] }
245
+ counts.each do |category, count|
246
+ puts "There were #{count} events of type #{category}"
247
+ end
248
+ errors = results.select { |r| r[:type] == :error || r[:type] == :failed }
249
+ return if errors.empty?
250
+
251
+ puts 'Printing 10 first errors'
252
+ puts '========================'
253
+ pp errors.take(10)
254
+ fail 'There was an error syncing users'
255
+ end
256
+
257
+ def load_data(params, data_source)
258
+ first_name_column = params.first_name_column || 'first_name'
259
+ last_name_column = params.last_name_column || 'last_name'
260
+ login_column = params.login_column || 'login'
261
+ password_column = params.password_column || 'password'
262
+ email_column = params.email_column || 'email'
263
+ role_column = params.role_column || 'role'
264
+ sso_provider_column = params.sso_provider_column || 'sso_provider'
265
+ authentication_modes_column = params.authentication_modes_column || 'authentication_modes'
266
+ user_groups_column = params.user_groups_column || 'user_groups'
267
+ language_column = params.language_column || 'language'
268
+ company_column = params.company_column || 'company'
269
+ position_column = params.position_column || 'position'
270
+ country_column = params.country_column || 'country'
271
+ phone_column = params.phone_column || 'phone'
272
+ ip_whitelist_column = params.ip_whitelist_column || 'ip_whitelist'
273
+ mode = params.sync_mode
274
+
275
+ sso_provider = params.sso_provider
276
+ authentication_modes = params.authentication_modes || []
277
+
278
+ multiple_projects_column = params.multiple_projects_column
279
+ unless multiple_projects_column
280
+ client_modes = %w(sync_domain_client_workspaces sync_one_project_based_on_custom_id sync_multiple_projects_based_on_custom_id)
281
+ multiple_projects_column = if client_modes.include?(mode)
282
+ 'client_id'
283
+ else
284
+ 'project_id'
285
+ end
286
+ end
287
+
288
+ dwh = params.ads_client
289
+ if dwh
290
+ data = dwh.execute_select(params.input_source.query)
291
+ else
292
+ tmp = File.open(data_source.realize(params), 'r:UTF-8')
293
+ data = CSV.read(tmp, headers: true)
294
+ end
295
+
296
+ data.map do |row|
297
+ params.gdc_logger.debug("Processing row: #{row}")
298
+
299
+ modes = if authentication_modes.empty?
300
+ row[authentication_modes_column] || row[authentication_modes_column.to_sym] || []
301
+ else
302
+ authentication_modes
303
+ end
304
+
305
+ modes = modes.split(',').map(&:strip).map { |x| x.to_s.upcase } unless modes.is_a? Array
306
+
307
+ user_group = row[user_groups_column] || row[user_groups_column.to_sym]
308
+ user_group = user_group.split(',').map(&:strip) if user_group
309
+
310
+ ip_whitelist = row[ip_whitelist_column] || row[ip_whitelist_column.to_sym]
311
+ ip_whitelist = ip_whitelist.split(',').map(&:strip) if ip_whitelist
312
+
313
+ {
314
+ :first_name => row[first_name_column] || row[first_name_column.to_sym],
315
+ :last_name => row[last_name_column] || row[last_name_column.to_sym],
316
+ :login => row[login_column] || row[login_column.to_sym],
317
+ :password => row[password_column] || row[password_column.to_sym],
318
+ :email => row[email_column] || row[login_column] || row[email_column.to_sym] || row[login_column.to_sym],
319
+ :role => row[role_column] || row[role_column.to_sym],
320
+ :sso_provider => sso_provider || row[sso_provider_column] || row[sso_provider_column.to_sym],
321
+ :authentication_modes => modes,
322
+ :user_group => user_group,
323
+ :pid => multiple_projects_column.nil? ? nil : (row[multiple_projects_column] || row[multiple_projects_column.to_sym]),
324
+ :language => row[language_column] || row[language_column.to_sym],
325
+ :company => row[company_column] || row[company_column.to_sym],
326
+ :position => row[position_column] || row[position_column.to_sym],
327
+ :country => row[country_column] || row[country_column.to_sym],
328
+ :phone => row[phone_column] || row[phone_column.to_sym],
329
+ :ip_whitelist => ip_whitelist
330
+ }
331
+ end
332
+ end
333
+ end
334
+ end
335
+ end
336
+ end
@@ -0,0 +1,77 @@
1
+ # encoding: UTF-8
2
+ #
3
+ # Copyright (c) 2010-2017 GoodData Corporation. All rights reserved.
4
+ # This source code is licensed under the BSD-style license found in the
5
+ # LICENSE file in the root directory of this source tree.
6
+
7
+ require_relative 'base_action'
8
+
9
+ module GoodData
10
+ module LCM2
11
+ class UpdateReleaseTable < BaseAction
12
+ DESCRIPTION = 'Update Release Table'
13
+
14
+ PARAMS = define_params(self) do
15
+ description 'ADS Client'
16
+ param :ads_client, instance_of(Type::AdsClientType), required: true
17
+ end
18
+
19
+ DEFAULT_TABLE_NAME = 'LCM_RELEASE'
20
+
21
+ class << self
22
+ def call(params)
23
+ client = params.gdc_gd_client
24
+
25
+ domain_name = params.organization || params.domain
26
+ client.domain(domain_name) || fail("Invalid domain name specified - #{domain_name}")
27
+
28
+ params.segments.map do |segment_in|
29
+ segment_id = segment_in.segment_id
30
+
31
+ placeholders = {
32
+ segment_id: segment_in[:segment_id],
33
+ master_project_id: segment_in[:master_pid],
34
+ version: segment_in[:version],
35
+ timestamp: segment_in[:timestamp],
36
+ table_name: params.release_table_name || DEFAULT_TABLE_NAME
37
+ }
38
+
39
+ update_release_table(params, placeholders)
40
+
41
+ {
42
+ segment: segment_id,
43
+ master_pid: segment_in[:master_pid],
44
+ version: segment_in[:version],
45
+ timestamp: segment_in[:timestamp]
46
+ }
47
+ end
48
+ end
49
+
50
+ def replace_placeholders(text, placeholders)
51
+ result = text.dup
52
+ placeholders.each do |k, v|
53
+ result.gsub!("\#{#{k}}", v.to_s)
54
+ end
55
+ result
56
+ end
57
+
58
+ def update_release_table(params, placeholders)
59
+ query = if placeholders[:version] > 1
60
+ path = File.expand_path('../../data/update_lcm_release.sql.erb', __FILE__)
61
+ default_query = GoodData::Helpers::ErbHelper.template_file(path, placeholders)
62
+
63
+ temp_query = (params.query && params.query[:update]) || default_query
64
+ replace_placeholders(temp_query, placeholders)
65
+ else
66
+ path = File.expand_path('../../data/insert_into_lcm_release.sql.erb', __FILE__)
67
+ default_query = GoodData::Helpers::ErbHelper.template_file(path, placeholders)
68
+ temp_query = (params.query && params.query.insert) || default_query
69
+ replace_placeholders(temp_query, placeholders)
70
+ end
71
+
72
+ params.ads_client.execute(query)
73
+ end
74
+ end
75
+ end
76
+ end
77
+ end
@@ -0,0 +1,6 @@
1
+ CREATE TABLE IF NOT EXISTS "<%= table_name || 'LCM_RELEASE' %>" (
2
+ segment_id VARCHAR(255) NOT NULL,
3
+ master_project_id VARCHAR(255) NOT NULL,
4
+ version INTEGER NOT NULL,
5
+ maql_ddl VARCHAR(65000)
6
+ );
@@ -0,0 +1,11 @@
1
+ INSERT INTO "<%= table_name || 'LCM_RELEASE' %>"
2
+ (
3
+ segment_id,
4
+ master_project_id,
5
+ version
6
+ )
7
+ VALUES (
8
+ '<%= segment_id %>',
9
+ '<%= master_project_id %>',
10
+ <%= version %>
11
+ );
@@ -0,0 +1,8 @@
1
+ SELECT
2
+ segment_id,
3
+ master_project_id,
4
+ version
5
+ FROM "<%= table_name || 'LCM_RELEASE' %>"
6
+ WHERE
7
+ segment_id = '<%= segment_id %>'
8
+ ;
@@ -0,0 +1,7 @@
1
+ UPDATE "<%= table_name || 'LCM_RELEASE' %>"
2
+ SET
3
+ master_project_id = '<%= master_project_id %>',
4
+ version = <%= version %>
5
+ WHERE
6
+ segment_id = '<%= segment_id %>'
7
+ ;