--- title: ScriptsApi --- :::error **The Ruby SDK is deprecated as of 9/16/2020** The Genesys Cloud Ruby SDK (v96.0.0) will be frozen at its current version level. Any new enhancements to our API or bug fixes will not be backported. If you do need to take advantage of new features or bug fixes outside the Genesys Cloud Ruby SDK, you will need to use the Genesys Cloud REST endpoints directly. More information can be found in the [Official Announcement](https://developer.mypurecloud.com/forum/t/announcement-genesys-cloud-ruby-sdk-end-of-life/8850). ::: ## PureCloud::ScriptsApi All URIs are relative to *https://api.mypurecloud.com* Method | Description ------------- | ------------- | ------------- [**get_script**](ScriptsApi.html#get_script) | Get a script [**get_script_page**](ScriptsApi.html#get_script_page) | Get a page [**get_script_pages**](ScriptsApi.html#get_script_pages) | Get the list of pages [**get_scripts**](ScriptsApi.html#get_scripts) | Get the list of scripts [**get_scripts_published**](ScriptsApi.html#get_scripts_published) | Get the published scripts. [**get_scripts_published_script_id**](ScriptsApi.html#get_scripts_published_script_id) | Get the published script. [**get_scripts_published_script_id_page**](ScriptsApi.html#get_scripts_published_script_id_page) | Get the published page. [**get_scripts_published_script_id_pages**](ScriptsApi.html#get_scripts_published_script_id_pages) | Get the list of published pages [**get_scripts_published_script_id_variables**](ScriptsApi.html#get_scripts_published_script_id_variables) | Get the published variables [**get_scripts_upload_status**](ScriptsApi.html#get_scripts_upload_status) | Get the upload status of an imported script [**post_script_export**](ScriptsApi.html#post_script_export) | Export a script via download service. {: class="table table-striped"} ## [**Script**](Script.html) get_script(script_id) Get a script Wraps GET /api/v2/scripts/{scriptId} Requires ANY permissions: * scripter:script:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID begin #Get a script result = api_instance.get_script(script_id) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_script: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | {: class="table table-striped"} ### Return type [**Script**](Script.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**Page**](Page.html) get_script_page(script_id, page_id, opts) Get a page Wraps GET /api/v2/scripts/{scriptId}/pages/{pageId} Requires ANY permissions: * scripter:script:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID page_id = "page_id_example" # String | Page ID opts = { script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get a page result = api_instance.get_script_page(script_id, page_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_script_page: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | **page_id** | **String**| Page ID | | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type [**Page**](Page.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**Array<Page>**](Page.html) get_script_pages(script_id, opts) Get the list of pages Wraps GET /api/v2/scripts/{scriptId}/pages Requires ANY permissions: * scripter:script:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID opts = { script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get the list of pages result = api_instance.get_script_pages(script_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_script_pages: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type [**Array<Page>**](Page.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**ScriptEntityListing**](ScriptEntityListing.html) get_scripts(opts) Get the list of scripts Wraps GET /api/v2/scripts Requires ANY permissions: * scripter:script:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new opts = { page_size: 25, # Integer | Page size page_number: 1, # Integer | Page number expand: "expand_example", # String | Expand name: "name_example", # String | Name filter feature: "feature_example", # String | Feature filter flow_id: "flow_id_example", # String | Secure flow id filter sort_by: "sort_by_example", # String | SortBy sort_order: "sort_order_example", # String | SortOrder script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get the list of scripts result = api_instance.get_scripts(opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_scripts: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **page_size** | **Integer**| Page size | [optional] [default to 25] | **page_number** | **Integer**| Page number | [optional] [default to 1] | **expand** | **String**| Expand | [optional] | **name** | **String**| Name filter | [optional] | **feature** | **String**| Feature filter | [optional] | **flow_id** | **String**| Secure flow id filter | [optional] | **sort_by** | **String**| SortBy | [optional]
**Values**: modifiedDate, createdDate | **sort_order** | **String**| SortOrder | [optional]
**Values**: ascending, descending | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type [**ScriptEntityListing**](ScriptEntityListing.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**ScriptEntityListing**](ScriptEntityListing.html) get_scripts_published(opts) Get the published scripts. Wraps GET /api/v2/scripts/published Requires ANY permissions: * scripter:publishedScript:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new opts = { page_size: 25, # Integer | Page size page_number: 1, # Integer | Page number expand: "expand_example", # String | Expand name: "name_example", # String | Name filter feature: "feature_example", # String | Feature filter flow_id: "flow_id_example", # String | Secure flow id filter script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get the published scripts. result = api_instance.get_scripts_published(opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_scripts_published: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **page_size** | **Integer**| Page size | [optional] [default to 25] | **page_number** | **Integer**| Page number | [optional] [default to 1] | **expand** | **String**| Expand | [optional] | **name** | **String**| Name filter | [optional] | **feature** | **String**| Feature filter | [optional] | **flow_id** | **String**| Secure flow id filter | [optional] | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type [**ScriptEntityListing**](ScriptEntityListing.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**Script**](Script.html) get_scripts_published_script_id(script_id, opts) Get the published script. Wraps GET /api/v2/scripts/published/{scriptId} Requires ANY permissions: * scripter:publishedScript:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID opts = { script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get the published script. result = api_instance.get_scripts_published_script_id(script_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_scripts_published_script_id: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type [**Script**](Script.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**Page**](Page.html) get_scripts_published_script_id_page(script_id, page_id, opts) Get the published page. Wraps GET /api/v2/scripts/published/{scriptId}/pages/{pageId} Requires ANY permissions: * scripter:publishedScript:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID page_id = "page_id_example" # String | Page ID opts = { script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get the published page. result = api_instance.get_scripts_published_script_id_page(script_id, page_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_scripts_published_script_id_page: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | **page_id** | **String**| Page ID | | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type [**Page**](Page.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**Array<Page>**](Page.html) get_scripts_published_script_id_pages(script_id, opts) Get the list of published pages Wraps GET /api/v2/scripts/published/{scriptId}/pages Requires ANY permissions: * scripter:publishedScript:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID opts = { script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get the list of published pages result = api_instance.get_scripts_published_script_id_pages(script_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_scripts_published_script_id_pages: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type [**Array<Page>**](Page.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## Object** get_scripts_published_script_id_variables(script_id, opts) Get the published variables Wraps GET /api/v2/scripts/published/{scriptId}/variables Requires ANY permissions: * scripter:publishedScript:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID opts = { input: "input_example", # String | input output: "output_example", # String | output type: "type_example", # String | type script_data_version: "script_data_version_example" # String | Advanced usage - controls the data version of the script } begin #Get the published variables result = api_instance.get_scripts_published_script_id_variables(script_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_scripts_published_script_id_variables: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | **input** | **String**| input | [optional] | **output** | **String**| output | [optional] | **type** | **String**| type | [optional] | **script_data_version** | **String**| Advanced usage - controls the data version of the script | [optional] | {: class="table table-striped"} ### Return type **Object** ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**ImportScriptStatusResponse**](ImportScriptStatusResponse.html) get_scripts_upload_status(upload_id, opts) Get the upload status of an imported script Wraps GET /api/v2/scripts/uploads/{uploadId}/status Requires ANY permissions: * scripter:script:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new upload_id = "upload_id_example" # String | Upload ID opts = { long_poll: false # BOOLEAN | Enable longPolling endpoint } begin #Get the upload status of an imported script result = api_instance.get_scripts_upload_status(upload_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->get_scripts_upload_status: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **upload_id** | **String**| Upload ID | | **long_poll** | **BOOLEAN**| Enable longPolling endpoint | [optional] [default to false] | {: class="table table-striped"} ### Return type [**ImportScriptStatusResponse**](ImportScriptStatusResponse.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json ## [**ExportScriptResponse**](ExportScriptResponse.html) post_script_export(script_id, opts) Export a script via download service. Wraps POST /api/v2/scripts/{scriptId}/export Requires ANY permissions: * scripter:script:view ### Example ```{"language":"ruby"} # load the gem require 'purecloudplatformclientv2' # setup authorization @secret = ENV['PURECLOUD_SECRET'] @id = ENV['PURECLOUD_CLIENT_ID'] environment = "mypurecloud.com" @authToken = PureCloud.authenticate_with_client_credentials @id, @secret, environment PureCloud.configure do |config| config.access_token = @authToken end api_instance = PureCloud::ScriptsApi.new script_id = "script_id_example" # String | Script ID opts = { body: PureCloud::ExportScriptRequest.new # ExportScriptRequest | } begin #Export a script via download service. result = api_instance.post_script_export(script_id, opts) p result rescue PureCloud::ApiError => e puts "Exception when calling ScriptsApi->post_script_export: #{e}" end ``` ### Parameters Name | Type | Description | Notes ------------- | ------------- | ------------- | ------------- **script_id** | **String**| Script ID | | **body** | [**ExportScriptRequest**](ExportScriptRequest.html)| | [optional] | {: class="table table-striped"} ### Return type [**ExportScriptResponse**](ExportScriptResponse.html) ### HTTP request headers - **Content-Type**: application/json - **Accept**: application/json