carbon_ruby_sdk 0.2.41 → 0.2.43

Sign up to get free protection for your applications and to get access to all the features.
Files changed (76) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +2 -2
  3. data/README.md +273 -3
  4. data/lib/carbon_ruby_sdk/api/data_sources_api.rb +196 -0
  5. data/lib/carbon_ruby_sdk/api/files_api.rb +4 -4
  6. data/lib/carbon_ruby_sdk/api/integrations_api.rb +48 -16
  7. data/lib/carbon_ruby_sdk/api/users_api.rb +71 -0
  8. data/lib/carbon_ruby_sdk/api/white_label_api.rb +393 -0
  9. data/lib/carbon_ruby_sdk/models/add_data_source_tags_input.rb +234 -0
  10. data/lib/carbon_ruby_sdk/models/azure_blob_auth_request.rb +14 -4
  11. data/lib/carbon_ruby_sdk/models/cold_storage_props.rb +1 -1
  12. data/lib/carbon_ruby_sdk/models/credentials.rb +244 -0
  13. data/lib/carbon_ruby_sdk/models/delete_white_label_request.rb +222 -0
  14. data/lib/carbon_ruby_sdk/models/external_source_item.rb +11 -1
  15. data/lib/carbon_ruby_sdk/models/fresh_desk_connect_request.rb +15 -5
  16. data/lib/carbon_ruby_sdk/models/gitbook_connect_request.rb +15 -5
  17. data/lib/carbon_ruby_sdk/models/github_connect_request.rb +14 -4
  18. data/lib/carbon_ruby_sdk/models/google_drive_credentials.rb +254 -0
  19. data/lib/carbon_ruby_sdk/models/google_drive_white_label_input.rb +230 -0
  20. data/lib/carbon_ruby_sdk/models/guru_connect_request.rb +15 -5
  21. data/lib/carbon_ruby_sdk/models/list_white_label_request.rb +246 -0
  22. data/lib/carbon_ruby_sdk/models/o_auth_url_request.rb +15 -5
  23. data/lib/carbon_ruby_sdk/models/one_drive_sharepoint_credentials.rb +264 -0
  24. data/lib/carbon_ruby_sdk/models/one_drive_sharepoint_white_label_input.rb +234 -0
  25. data/lib/carbon_ruby_sdk/models/one_drive_sharepoint_white_label_input_data_source_type.rb +36 -0
  26. data/lib/carbon_ruby_sdk/models/organization_user_data_source_api.rb +15 -1
  27. data/lib/carbon_ruby_sdk/models/organization_user_data_source_filters.rb +12 -1
  28. data/lib/carbon_ruby_sdk/models/remove_data_source_tags_input.rb +242 -0
  29. data/lib/carbon_ruby_sdk/models/rss_feed_input.rb +15 -5
  30. data/lib/carbon_ruby_sdk/models/s3_auth_request.rb +15 -5
  31. data/lib/carbon_ruby_sdk/models/sync_options.rb +15 -5
  32. data/lib/carbon_ruby_sdk/models/user_response.rb +18 -4
  33. data/lib/carbon_ruby_sdk/models/white_label_create_request_inner.rb +255 -0
  34. data/lib/carbon_ruby_sdk/models/white_label_filters.rb +230 -0
  35. data/lib/carbon_ruby_sdk/models/white_label_input.rb +234 -0
  36. data/lib/carbon_ruby_sdk/models/white_label_input_data_source_type.rb +48 -0
  37. data/lib/carbon_ruby_sdk/models/white_label_order_by_columns.rb +36 -0
  38. data/lib/carbon_ruby_sdk/models/white_label_update_request.rb +255 -0
  39. data/lib/carbon_ruby_sdk/models/white_labeling_response.rb +18 -4
  40. data/lib/carbon_ruby_sdk/version.rb +1 -1
  41. data/lib/carbon_ruby_sdk.rb +19 -0
  42. data/spec/api/data_sources_api_spec.rb +22 -0
  43. data/spec/api/files_api_spec.rb +1 -1
  44. data/spec/api/users_api_spec.rb +10 -0
  45. data/spec/api/white_label_api_spec.rb +73 -0
  46. data/spec/models/add_data_source_tags_input_spec.rb +34 -0
  47. data/spec/models/azure_blob_auth_request_spec.rb +6 -0
  48. data/spec/models/credentials_spec.rb +40 -0
  49. data/spec/models/delete_white_label_request_spec.rb +28 -0
  50. data/spec/models/external_source_item_spec.rb +6 -0
  51. data/spec/models/fresh_desk_connect_request_spec.rb +6 -0
  52. data/spec/models/gitbook_connect_request_spec.rb +6 -0
  53. data/spec/models/github_connect_request_spec.rb +6 -0
  54. data/spec/models/google_drive_credentials_spec.rb +46 -0
  55. data/spec/models/google_drive_white_label_input_spec.rb +34 -0
  56. data/spec/models/guru_connect_request_spec.rb +6 -0
  57. data/spec/models/list_white_label_request_spec.rb +46 -0
  58. data/spec/models/o_auth_url_request_spec.rb +6 -0
  59. data/spec/models/one_drive_sharepoint_credentials_spec.rb +52 -0
  60. data/spec/models/one_drive_sharepoint_white_label_input_data_source_type_spec.rb +22 -0
  61. data/spec/models/one_drive_sharepoint_white_label_input_spec.rb +34 -0
  62. data/spec/models/organization_user_data_source_api_spec.rb +6 -0
  63. data/spec/models/organization_user_data_source_filters_spec.rb +6 -0
  64. data/spec/models/remove_data_source_tags_input_spec.rb +40 -0
  65. data/spec/models/rss_feed_input_spec.rb +6 -0
  66. data/spec/models/s3_auth_request_spec.rb +6 -0
  67. data/spec/models/sync_options_spec.rb +6 -0
  68. data/spec/models/user_response_spec.rb +6 -0
  69. data/spec/models/white_label_create_request_inner_spec.rb +34 -0
  70. data/spec/models/white_label_filters_spec.rb +34 -0
  71. data/spec/models/white_label_input_data_source_type_spec.rb +22 -0
  72. data/spec/models/white_label_input_spec.rb +34 -0
  73. data/spec/models/white_label_order_by_columns_spec.rb +22 -0
  74. data/spec/models/white_label_update_request_spec.rb +34 -0
  75. data/spec/models/white_labeling_response_spec.rb +6 -0
  76. metadata +53 -2
@@ -1378,7 +1378,7 @@ module Carbon
1378
1378
  # @param media_type [FileContentTypesNullable] The media type of the file. If not provided, it will be inferred from the file extension.
1379
1379
  # @param split_rows [Boolean] Whether to split tabular rows into chunks. Currently only valid for CSV, TSV, and XLSX files.
1380
1380
  # @param enable_cold_storage [Boolean] Enable cold storage for the file. If set to true, the file will be moved to cold storage after a certain period of inactivity. Default is false.
1381
- # @param hot_storage_time_to_live [Integer] Time in seconds after which the file will be moved to cold storage.
1381
+ # @param hot_storage_time_to_live [Integer] Time in days after which the file will be moved to cold storage. Must be one of [1, 3, 7, 14, 30].
1382
1382
  # @param generate_chunks_only [Boolean] If this flag is enabled, the file will be chunked and stored with Carbon, but no embeddings will be generated. This overrides the skip_embedding_generation flag.
1383
1383
  # @param store_file_only [Boolean] If this flag is enabled, the file will be stored with Carbon, but no processing will be done.
1384
1384
  # @param body [BodyCreateUploadFileUploadfilePost]
@@ -1455,7 +1455,7 @@ module Carbon
1455
1455
  # @param media_type [FileContentTypesNullable] The media type of the file. If not provided, it will be inferred from the file extension.
1456
1456
  # @param split_rows [Boolean] Whether to split tabular rows into chunks. Currently only valid for CSV, TSV, and XLSX files.
1457
1457
  # @param enable_cold_storage [Boolean] Enable cold storage for the file. If set to true, the file will be moved to cold storage after a certain period of inactivity. Default is false.
1458
- # @param hot_storage_time_to_live [Integer] Time in seconds after which the file will be moved to cold storage.
1458
+ # @param hot_storage_time_to_live [Integer] Time in days after which the file will be moved to cold storage. Must be one of [1, 3, 7, 14, 30].
1459
1459
  # @param generate_chunks_only [Boolean] If this flag is enabled, the file will be chunked and stored with Carbon, but no embeddings will be generated. This overrides the skip_embedding_generation flag.
1460
1460
  # @param store_file_only [Boolean] If this flag is enabled, the file will be stored with Carbon, but no processing will be done.
1461
1461
  # @param body [BodyCreateUploadFileUploadfilePost]
@@ -1507,7 +1507,7 @@ module Carbon
1507
1507
  # @option opts [FileContentTypesNullable] :media_type The media type of the file. If not provided, it will be inferred from the file extension.
1508
1508
  # @option opts [Boolean] :split_rows Whether to split tabular rows into chunks. Currently only valid for CSV, TSV, and XLSX files. (default to false)
1509
1509
  # @option opts [Boolean] :enable_cold_storage Enable cold storage for the file. If set to true, the file will be moved to cold storage after a certain period of inactivity. Default is false. (default to false)
1510
- # @option opts [Integer] :hot_storage_time_to_live Time in seconds after which the file will be moved to cold storage.
1510
+ # @option opts [Integer] :hot_storage_time_to_live Time in days after which the file will be moved to cold storage. Must be one of [1, 3, 7, 14, 30].
1511
1511
  # @option opts [Boolean] :generate_chunks_only If this flag is enabled, the file will be chunked and stored with Carbon, but no embeddings will be generated. This overrides the skip_embedding_generation flag. (default to false)
1512
1512
  # @option opts [Boolean] :store_file_only If this flag is enabled, the file will be stored with Carbon, but no processing will be done. (default to false)
1513
1513
  # @return [UserFile]
@@ -1537,7 +1537,7 @@ module Carbon
1537
1537
  # @option opts [FileContentTypesNullable] :media_type The media type of the file. If not provided, it will be inferred from the file extension.
1538
1538
  # @option opts [Boolean] :split_rows Whether to split tabular rows into chunks. Currently only valid for CSV, TSV, and XLSX files. (default to false)
1539
1539
  # @option opts [Boolean] :enable_cold_storage Enable cold storage for the file. If set to true, the file will be moved to cold storage after a certain period of inactivity. Default is false. (default to false)
1540
- # @option opts [Integer] :hot_storage_time_to_live Time in seconds after which the file will be moved to cold storage.
1540
+ # @option opts [Integer] :hot_storage_time_to_live Time in days after which the file will be moved to cold storage. Must be one of [1, 3, 7, 14, 30].
1541
1541
  # @option opts [Boolean] :generate_chunks_only If this flag is enabled, the file will be chunked and stored with Carbon, but no embeddings will be generated. This overrides the skip_embedding_generation flag. (default to false)
1542
1542
  # @option opts [Boolean] :store_file_only If this flag is enabled, the file will be stored with Carbon, but no processing will be done. (default to false)
1543
1543
  # @return [APIResponse] data is UserFile, status code, headers and response
@@ -225,9 +225,10 @@ module Carbon
225
225
  # @param request_id [String]
226
226
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
227
227
  # @param file_sync_config [FileSyncConfigNullable]
228
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
228
229
  # @param body [FreshDeskConnectRequest]
229
230
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
230
- def connect_freshdesk(domain:, api_key:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, extra: {})
231
+ def connect_freshdesk(domain:, api_key:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, data_source_tags: SENTINEL, extra: {})
231
232
  _body = {}
232
233
  _body[:tags] = tags if tags != SENTINEL
233
234
  _body[:domain] = domain if domain != SENTINEL
@@ -242,6 +243,7 @@ module Carbon
242
243
  _body[:request_id] = request_id if request_id != SENTINEL
243
244
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
244
245
  _body[:file_sync_config] = file_sync_config if file_sync_config != SENTINEL
246
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
245
247
  fresh_desk_connect_request = _body
246
248
  api_response = connect_freshdesk_with_http_info_impl(fresh_desk_connect_request, extra)
247
249
  api_response.data
@@ -268,9 +270,10 @@ module Carbon
268
270
  # @param request_id [String]
269
271
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
270
272
  # @param file_sync_config [FileSyncConfigNullable]
273
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
271
274
  # @param body [FreshDeskConnectRequest]
272
275
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
273
- def connect_freshdesk_with_http_info(domain:, api_key:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, extra: {})
276
+ def connect_freshdesk_with_http_info(domain:, api_key:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, data_source_tags: SENTINEL, extra: {})
274
277
  _body = {}
275
278
  _body[:tags] = tags if tags != SENTINEL
276
279
  _body[:domain] = domain if domain != SENTINEL
@@ -285,6 +288,7 @@ module Carbon
285
288
  _body[:request_id] = request_id if request_id != SENTINEL
286
289
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
287
290
  _body[:file_sync_config] = file_sync_config if file_sync_config != SENTINEL
291
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
288
292
  fresh_desk_connect_request = _body
289
293
  connect_freshdesk_with_http_info_impl(fresh_desk_connect_request, extra)
290
294
  end
@@ -378,9 +382,10 @@ module Carbon
378
382
  # @param request_id [String]
379
383
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
380
384
  # @param file_sync_config [FileSyncConfigNullable]
385
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
381
386
  # @param body [GitbookConnectRequest]
382
387
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
383
- def connect_gitbook(organization:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, extra: {})
388
+ def connect_gitbook(organization:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, data_source_tags: SENTINEL, extra: {})
384
389
  _body = {}
385
390
  _body[:tags] = tags if tags != SENTINEL
386
391
  _body[:organization] = organization if organization != SENTINEL
@@ -395,6 +400,7 @@ module Carbon
395
400
  _body[:request_id] = request_id if request_id != SENTINEL
396
401
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
397
402
  _body[:file_sync_config] = file_sync_config if file_sync_config != SENTINEL
403
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
398
404
  gitbook_connect_request = _body
399
405
  api_response = connect_gitbook_with_http_info_impl(gitbook_connect_request, extra)
400
406
  api_response.data
@@ -420,9 +426,10 @@ module Carbon
420
426
  # @param request_id [String]
421
427
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
422
428
  # @param file_sync_config [FileSyncConfigNullable]
429
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
423
430
  # @param body [GitbookConnectRequest]
424
431
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
425
- def connect_gitbook_with_http_info(organization:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, extra: {})
432
+ def connect_gitbook_with_http_info(organization:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, data_source_tags: SENTINEL, extra: {})
426
433
  _body = {}
427
434
  _body[:tags] = tags if tags != SENTINEL
428
435
  _body[:organization] = organization if organization != SENTINEL
@@ -437,6 +444,7 @@ module Carbon
437
444
  _body[:request_id] = request_id if request_id != SENTINEL
438
445
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
439
446
  _body[:file_sync_config] = file_sync_config if file_sync_config != SENTINEL
447
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
440
448
  gitbook_connect_request = _body
441
449
  connect_gitbook_with_http_info_impl(gitbook_connect_request, extra)
442
450
  end
@@ -528,9 +536,10 @@ module Carbon
528
536
  # @param request_id [String]
529
537
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
530
538
  # @param file_sync_config [FileSyncConfigNullable]
539
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
531
540
  # @param body [GuruConnectRequest]
532
541
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
533
- def connect_guru(username:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, extra: {})
542
+ def connect_guru(username:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, data_source_tags: SENTINEL, extra: {})
534
543
  _body = {}
535
544
  _body[:tags] = tags if tags != SENTINEL
536
545
  _body[:username] = username if username != SENTINEL
@@ -545,6 +554,7 @@ module Carbon
545
554
  _body[:request_id] = request_id if request_id != SENTINEL
546
555
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
547
556
  _body[:file_sync_config] = file_sync_config if file_sync_config != SENTINEL
557
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
548
558
  guru_connect_request = _body
549
559
  api_response = connect_guru_with_http_info_impl(guru_connect_request, extra)
550
560
  api_response.data
@@ -568,9 +578,10 @@ module Carbon
568
578
  # @param request_id [String]
569
579
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
570
580
  # @param file_sync_config [FileSyncConfigNullable]
581
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
571
582
  # @param body [GuruConnectRequest]
572
583
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
573
- def connect_guru_with_http_info(username:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, extra: {})
584
+ def connect_guru_with_http_info(username:, access_token:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, sync_files_on_connection: true, request_id: SENTINEL, sync_source_items: true, file_sync_config: SENTINEL, data_source_tags: SENTINEL, extra: {})
574
585
  _body = {}
575
586
  _body[:tags] = tags if tags != SENTINEL
576
587
  _body[:username] = username if username != SENTINEL
@@ -585,6 +596,7 @@ module Carbon
585
596
  _body[:request_id] = request_id if request_id != SENTINEL
586
597
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
587
598
  _body[:file_sync_config] = file_sync_config if file_sync_config != SENTINEL
599
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
588
600
  guru_connect_request = _body
589
601
  connect_guru_with_http_info_impl(guru_connect_request, extra)
590
602
  end
@@ -675,14 +687,16 @@ module Carbon
675
687
  # @param access_key_secret [String]
676
688
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
677
689
  # @param endpoint_url [String] You can specify a Digital Ocean endpoint URL to connect a Digital Ocean Space through this endpoint. The URL should be of format <region>.digitaloceanspaces.com. It's not required for S3 buckets.
690
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
678
691
  # @param body [S3AuthRequest]
679
692
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
680
- def create_aws_iam_user(access_key:, access_key_secret:, sync_source_items: true, endpoint_url: SENTINEL, extra: {})
693
+ def create_aws_iam_user(access_key:, access_key_secret:, sync_source_items: true, endpoint_url: SENTINEL, data_source_tags: SENTINEL, extra: {})
681
694
  _body = {}
682
695
  _body[:access_key] = access_key if access_key != SENTINEL
683
696
  _body[:access_key_secret] = access_key_secret if access_key_secret != SENTINEL
684
697
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
685
698
  _body[:endpoint_url] = endpoint_url if endpoint_url != SENTINEL
699
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
686
700
  s3_auth_request = _body
687
701
  api_response = create_aws_iam_user_with_http_info_impl(s3_auth_request, extra)
688
702
  api_response.data
@@ -705,14 +719,16 @@ module Carbon
705
719
  # @param access_key_secret [String]
706
720
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
707
721
  # @param endpoint_url [String] You can specify a Digital Ocean endpoint URL to connect a Digital Ocean Space through this endpoint. The URL should be of format <region>.digitaloceanspaces.com. It's not required for S3 buckets.
722
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
708
723
  # @param body [S3AuthRequest]
709
724
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
710
- def create_aws_iam_user_with_http_info(access_key:, access_key_secret:, sync_source_items: true, endpoint_url: SENTINEL, extra: {})
725
+ def create_aws_iam_user_with_http_info(access_key:, access_key_secret:, sync_source_items: true, endpoint_url: SENTINEL, data_source_tags: SENTINEL, extra: {})
711
726
  _body = {}
712
727
  _body[:access_key] = access_key if access_key != SENTINEL
713
728
  _body[:access_key_secret] = access_key_secret if access_key_secret != SENTINEL
714
729
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
715
730
  _body[:endpoint_url] = endpoint_url if endpoint_url != SENTINEL
731
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
716
732
  s3_auth_request = _body
717
733
  create_aws_iam_user_with_http_info_impl(s3_auth_request, extra)
718
734
  end
@@ -822,9 +838,10 @@ module Carbon
822
838
  # @param automatically_open_file_picker [Boolean] Automatically open source file picker after the OAuth flow is complete. This flag is currently supported by BOX, DROPBOX, GOOGLE_DRIVE, ONEDRIVE, SHAREPOINT. It will be ignored for other data sources.
823
839
  # @param gong_account_email [String] If you are connecting a Gong account, you need to input the email of the account you wish to connect. This email will be used to identify your carbon data source.
824
840
  # @param servicenow_credentials [ServiceNowCredentialsNullable]
841
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
825
842
  # @param body [OAuthURLRequest]
826
843
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
827
- def get_oauth_url(service:, tags: SENTINEL, scope: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', zendesk_subdomain: SENTINEL, microsoft_tenant: SENTINEL, sharepoint_site_name: SENTINEL, confluence_subdomain: SENTINEL, generate_sparse_vectors: false, prepend_filename_to_chunks: false, max_items_per_chunk: SENTINEL, salesforce_domain: SENTINEL, sync_files_on_connection: true, set_page_as_boundary: false, data_source_id: SENTINEL, connecting_new_account: false, request_id: SENTINEL, use_ocr: false, parse_pdf_tables_with_ocr: false, enable_file_picker: true, sync_source_items: true, incremental_sync: false, file_sync_config: SENTINEL, automatically_open_file_picker: SENTINEL, gong_account_email: SENTINEL, servicenow_credentials: SENTINEL, extra: {})
844
+ def get_oauth_url(service:, tags: SENTINEL, scope: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', zendesk_subdomain: SENTINEL, microsoft_tenant: SENTINEL, sharepoint_site_name: SENTINEL, confluence_subdomain: SENTINEL, generate_sparse_vectors: false, prepend_filename_to_chunks: false, max_items_per_chunk: SENTINEL, salesforce_domain: SENTINEL, sync_files_on_connection: true, set_page_as_boundary: false, data_source_id: SENTINEL, connecting_new_account: false, request_id: SENTINEL, use_ocr: false, parse_pdf_tables_with_ocr: false, enable_file_picker: true, sync_source_items: true, incremental_sync: false, file_sync_config: SENTINEL, automatically_open_file_picker: SENTINEL, gong_account_email: SENTINEL, servicenow_credentials: SENTINEL, data_source_tags: SENTINEL, extra: {})
828
845
  _body = {}
829
846
  _body[:tags] = tags if tags != SENTINEL
830
847
  _body[:scope] = scope if scope != SENTINEL
@@ -855,6 +872,7 @@ module Carbon
855
872
  _body[:automatically_open_file_picker] = automatically_open_file_picker if automatically_open_file_picker != SENTINEL
856
873
  _body[:gong_account_email] = gong_account_email if gong_account_email != SENTINEL
857
874
  _body[:servicenow_credentials] = servicenow_credentials if servicenow_credentials != SENTINEL
875
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
858
876
  o_auth_url_request = _body
859
877
  api_response = get_oauth_url_with_http_info_impl(o_auth_url_request, extra)
860
878
  api_response.data
@@ -896,9 +914,10 @@ module Carbon
896
914
  # @param automatically_open_file_picker [Boolean] Automatically open source file picker after the OAuth flow is complete. This flag is currently supported by BOX, DROPBOX, GOOGLE_DRIVE, ONEDRIVE, SHAREPOINT. It will be ignored for other data sources.
897
915
  # @param gong_account_email [String] If you are connecting a Gong account, you need to input the email of the account you wish to connect. This email will be used to identify your carbon data source.
898
916
  # @param servicenow_credentials [ServiceNowCredentialsNullable]
917
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
899
918
  # @param body [OAuthURLRequest]
900
919
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
901
- def get_oauth_url_with_http_info(service:, tags: SENTINEL, scope: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', zendesk_subdomain: SENTINEL, microsoft_tenant: SENTINEL, sharepoint_site_name: SENTINEL, confluence_subdomain: SENTINEL, generate_sparse_vectors: false, prepend_filename_to_chunks: false, max_items_per_chunk: SENTINEL, salesforce_domain: SENTINEL, sync_files_on_connection: true, set_page_as_boundary: false, data_source_id: SENTINEL, connecting_new_account: false, request_id: SENTINEL, use_ocr: false, parse_pdf_tables_with_ocr: false, enable_file_picker: true, sync_source_items: true, incremental_sync: false, file_sync_config: SENTINEL, automatically_open_file_picker: SENTINEL, gong_account_email: SENTINEL, servicenow_credentials: SENTINEL, extra: {})
920
+ def get_oauth_url_with_http_info(service:, tags: SENTINEL, scope: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', zendesk_subdomain: SENTINEL, microsoft_tenant: SENTINEL, sharepoint_site_name: SENTINEL, confluence_subdomain: SENTINEL, generate_sparse_vectors: false, prepend_filename_to_chunks: false, max_items_per_chunk: SENTINEL, salesforce_domain: SENTINEL, sync_files_on_connection: true, set_page_as_boundary: false, data_source_id: SENTINEL, connecting_new_account: false, request_id: SENTINEL, use_ocr: false, parse_pdf_tables_with_ocr: false, enable_file_picker: true, sync_source_items: true, incremental_sync: false, file_sync_config: SENTINEL, automatically_open_file_picker: SENTINEL, gong_account_email: SENTINEL, servicenow_credentials: SENTINEL, data_source_tags: SENTINEL, extra: {})
902
921
  _body = {}
903
922
  _body[:tags] = tags if tags != SENTINEL
904
923
  _body[:scope] = scope if scope != SENTINEL
@@ -929,6 +948,7 @@ module Carbon
929
948
  _body[:automatically_open_file_picker] = automatically_open_file_picker if automatically_open_file_picker != SENTINEL
930
949
  _body[:gong_account_email] = gong_account_email if gong_account_email != SENTINEL
931
950
  _body[:servicenow_credentials] = servicenow_credentials if servicenow_credentials != SENTINEL
951
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
932
952
  o_auth_url_request = _body
933
953
  get_oauth_url_with_http_info_impl(o_auth_url_request, extra)
934
954
  end
@@ -1975,13 +1995,15 @@ module Carbon
1975
1995
  # @param account_name [String]
1976
1996
  # @param account_key [String]
1977
1997
  # @param sync_source_items [Boolean]
1998
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
1978
1999
  # @param body [AzureBlobAuthRequest]
1979
2000
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
1980
- def sync_azure_blob_storage(account_name:, account_key:, sync_source_items: true, extra: {})
2001
+ def sync_azure_blob_storage(account_name:, account_key:, sync_source_items: true, data_source_tags: SENTINEL, extra: {})
1981
2002
  _body = {}
1982
2003
  _body[:account_name] = account_name if account_name != SENTINEL
1983
2004
  _body[:account_key] = account_key if account_key != SENTINEL
1984
2005
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
2006
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
1985
2007
  azure_blob_auth_request = _body
1986
2008
  api_response = sync_azure_blob_storage_with_http_info_impl(azure_blob_auth_request, extra)
1987
2009
  api_response.data
@@ -2011,13 +2033,15 @@ module Carbon
2011
2033
  # @param account_name [String]
2012
2034
  # @param account_key [String]
2013
2035
  # @param sync_source_items [Boolean]
2036
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
2014
2037
  # @param body [AzureBlobAuthRequest]
2015
2038
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
2016
- def sync_azure_blob_storage_with_http_info(account_name:, account_key:, sync_source_items: true, extra: {})
2039
+ def sync_azure_blob_storage_with_http_info(account_name:, account_key:, sync_source_items: true, data_source_tags: SENTINEL, extra: {})
2017
2040
  _body = {}
2018
2041
  _body[:account_name] = account_name if account_name != SENTINEL
2019
2042
  _body[:account_key] = account_key if account_key != SENTINEL
2020
2043
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
2044
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
2021
2045
  azure_blob_auth_request = _body
2022
2046
  sync_azure_blob_storage_with_http_info_impl(azure_blob_auth_request, extra)
2023
2047
  end
@@ -2524,13 +2548,15 @@ module Carbon
2524
2548
  # @param username [String]
2525
2549
  # @param access_token [String]
2526
2550
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
2551
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
2527
2552
  # @param body [GithubConnectRequest]
2528
2553
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
2529
- def sync_git_hub(username:, access_token:, sync_source_items: false, extra: {})
2554
+ def sync_git_hub(username:, access_token:, sync_source_items: false, data_source_tags: SENTINEL, extra: {})
2530
2555
  _body = {}
2531
2556
  _body[:username] = username if username != SENTINEL
2532
2557
  _body[:access_token] = access_token if access_token != SENTINEL
2533
2558
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
2559
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
2534
2560
  github_connect_request = _body
2535
2561
  api_response = sync_git_hub_with_http_info_impl(github_connect_request, extra)
2536
2562
  api_response.data
@@ -2545,13 +2571,15 @@ module Carbon
2545
2571
  # @param username [String]
2546
2572
  # @param access_token [String]
2547
2573
  # @param sync_source_items [Boolean] Enabling this flag will fetch all available content from the source to be listed via list items endpoint
2574
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
2548
2575
  # @param body [GithubConnectRequest]
2549
2576
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
2550
- def sync_git_hub_with_http_info(username:, access_token:, sync_source_items: false, extra: {})
2577
+ def sync_git_hub_with_http_info(username:, access_token:, sync_source_items: false, data_source_tags: SENTINEL, extra: {})
2551
2578
  _body = {}
2552
2579
  _body[:username] = username if username != SENTINEL
2553
2580
  _body[:access_token] = access_token if access_token != SENTINEL
2554
2581
  _body[:sync_source_items] = sync_source_items if sync_source_items != SENTINEL
2582
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
2555
2583
  github_connect_request = _body
2556
2584
  sync_git_hub_with_http_info_impl(github_connect_request, extra)
2557
2585
  end
@@ -3404,9 +3432,10 @@ module Carbon
3404
3432
  # @param generate_sparse_vectors [Boolean]
3405
3433
  # @param prepend_filename_to_chunks [Boolean]
3406
3434
  # @param request_id [String]
3435
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
3407
3436
  # @param body [RSSFeedInput]
3408
3437
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
3409
- def sync_rss_feed(url:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, request_id: SENTINEL, extra: {})
3438
+ def sync_rss_feed(url:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, request_id: SENTINEL, data_source_tags: SENTINEL, extra: {})
3410
3439
  _body = {}
3411
3440
  _body[:tags] = tags if tags != SENTINEL
3412
3441
  _body[:url] = url if url != SENTINEL
@@ -3417,6 +3446,7 @@ module Carbon
3417
3446
  _body[:generate_sparse_vectors] = generate_sparse_vectors if generate_sparse_vectors != SENTINEL
3418
3447
  _body[:prepend_filename_to_chunks] = prepend_filename_to_chunks if prepend_filename_to_chunks != SENTINEL
3419
3448
  _body[:request_id] = request_id if request_id != SENTINEL
3449
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
3420
3450
  rss_feed_input = _body
3421
3451
  api_response = sync_rss_feed_with_http_info_impl(rss_feed_input, extra)
3422
3452
  api_response.data
@@ -3433,9 +3463,10 @@ module Carbon
3433
3463
  # @param generate_sparse_vectors [Boolean]
3434
3464
  # @param prepend_filename_to_chunks [Boolean]
3435
3465
  # @param request_id [String]
3466
+ # @param data_source_tags [Object] Tags to be associated with the data source. If the data source already has tags set, then an upsert will be performed.
3436
3467
  # @param body [RSSFeedInput]
3437
3468
  # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
3438
- def sync_rss_feed_with_http_info(url:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, request_id: SENTINEL, extra: {})
3469
+ def sync_rss_feed_with_http_info(url:, tags: SENTINEL, chunk_size: 1500, chunk_overlap: 20, skip_embedding_generation: false, embedding_model: 'OPENAI', generate_sparse_vectors: false, prepend_filename_to_chunks: false, request_id: SENTINEL, data_source_tags: SENTINEL, extra: {})
3439
3470
  _body = {}
3440
3471
  _body[:tags] = tags if tags != SENTINEL
3441
3472
  _body[:url] = url if url != SENTINEL
@@ -3446,6 +3477,7 @@ module Carbon
3446
3477
  _body[:generate_sparse_vectors] = generate_sparse_vectors if generate_sparse_vectors != SENTINEL
3447
3478
  _body[:prepend_filename_to_chunks] = prepend_filename_to_chunks if prepend_filename_to_chunks != SENTINEL
3448
3479
  _body[:request_id] = request_id if request_id != SENTINEL
3480
+ _body[:data_source_tags] = data_source_tags if data_source_tags != SENTINEL
3449
3481
  rss_feed_input = _body
3450
3482
  sync_rss_feed_with_http_info_impl(rss_feed_input, extra)
3451
3483
  end
@@ -524,6 +524,77 @@ module Carbon
524
524
  end
525
525
  APIResponse::new(data, status_code, headers, response)
526
526
  end
527
+
528
+
529
+ # Me Endpoint
530
+ #
531
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
532
+ def who_am_i(extra: {})
533
+ api_response = who_am_i_with_http_info_impl(extra)
534
+ api_response.data
535
+ end
536
+
537
+ # Me Endpoint
538
+ #
539
+ # @param [Hash] extra additional parameters to pass along through :header_params, :query_params, or parameter name
540
+ def who_am_i_with_http_info(extra: {})
541
+ who_am_i_with_http_info_impl(extra)
542
+ end
543
+
544
+ # Me Endpoint
545
+ # @param [Hash] opts the optional parameters
546
+ # @return [UserResponse]
547
+ private def who_am_i_impl(opts = {})
548
+ data, _status_code, _headers = who_am_i_with_http_info(opts)
549
+ data
550
+ end
551
+
552
+ # Me Endpoint
553
+ # @param [Hash] opts the optional parameters
554
+ # @return [APIResponse] data is UserResponse, status code, headers and response
555
+ private def who_am_i_with_http_info_impl(opts = {})
556
+ if @api_client.config.debugging
557
+ @api_client.config.logger.debug 'Calling API: UsersApi.who_am_i ...'
558
+ end
559
+ # resource path
560
+ local_var_path = '/whoami'
561
+
562
+ # query parameters
563
+ query_params = opts[:query_params] || {}
564
+
565
+ # header parameters
566
+ header_params = opts[:header_params] || {}
567
+ # HTTP header 'Accept' (if needed)
568
+ header_params['Accept'] = @api_client.select_header_accept(['application/json'])
569
+
570
+ # form parameters
571
+ form_params = opts[:form_params] || {}
572
+
573
+ # http body (model)
574
+ post_body = opts[:debug_body]
575
+
576
+ # return_type
577
+ return_type = opts[:debug_return_type] || 'UserResponse'
578
+
579
+ # auth_names
580
+ auth_names = opts[:debug_auth_names] || ['accessToken', 'apiKey', 'customerId']
581
+
582
+ new_options = opts.merge(
583
+ :operation => :"UsersApi.who_am_i",
584
+ :header_params => header_params,
585
+ :query_params => query_params,
586
+ :form_params => form_params,
587
+ :body => post_body,
588
+ :auth_names => auth_names,
589
+ :return_type => return_type
590
+ )
591
+
592
+ data, status_code, headers, response = @api_client.call_api(:GET, local_var_path, new_options)
593
+ if @api_client.config.debugging
594
+ @api_client.config.logger.debug "API called: UsersApi#who_am_i\nData: #{data.inspect}\nStatus code: #{status_code}\nHeaders: #{headers}"
595
+ end
596
+ APIResponse::new(data, status_code, headers, response)
597
+ end
527
598
  end
528
599
 
529
600
  # top-level client access to avoid having the user to insantiate their own API instances