@@ -189,15 +189,34 @@ def update_data_visualization(self, cluster_id: str, data_viz_id: str, config: d
189
189
190
190
def create_vw (self , cluster_id : str , dbc_id : str , vw_type : str , name : str , template : str = None ,
191
191
autoscaling_min_cluster : int = None , autoscaling_max_cluster : int = None ,
192
- common_configs : dict = None , application_configs : dict = None , ldap_groups : list = None ,
193
- enable_sso : bool = None , tags : dict = None ):
192
+ autoscaling_auto_suspend_timeout_seconds : int = None , autoscaling_disable_auto_suspend : bool = None ,
193
+ autoscaling_hive_desired_free_capacity : int = None , autoscaling_hive_scale_wait_time_seconds : int = None ,
194
+ autoscaling_impala_scale_down_delay_seconds : int = None , autoscaling_impala_scale_up_delay_seconds : int = None ,
195
+ autoscaling_pod_config_name : str = None , common_configs : dict = None , application_configs : dict = None ,
196
+ ldap_groups : list = None , enable_sso : bool = None , tags : dict = None ,
197
+ enable_unified_analytics : bool = None , enable_platform_jwt_auth : bool = None ,
198
+ impala_ha_enable_catalog_high_availability : bool = None , impala_ha_enable_shutdown_of_coordinator : bool = None ,
199
+ impala_ha_high_availability_mode : str = None , impala_ha_num_of_active_coordinators : int = None ,
200
+ impala_ha_shutdown_of_coordinator_delay_seconds : int = None
201
+ ):
194
202
195
- if any (x is not None for x in [autoscaling_min_cluster , autoscaling_max_cluster ]):
196
- autoscaling = {}
203
+ if any (x is not None for x in [autoscaling_min_cluster , autoscaling_max_cluster , autoscaling_auto_suspend_timeout_seconds ,
204
+ autoscaling_disable_auto_suspend ,
205
+ autoscaling_hive_desired_free_capacity ,
206
+ autoscaling_hive_scale_wait_time_seconds ,
207
+ autoscaling_impala_scale_down_delay_seconds ,
208
+ autoscaling_impala_scale_up_delay_seconds ,
209
+ autoscaling_pod_config_name ]):
210
+ autoscaling_all = dict (autoSuspendTimeoutSeconds = autoscaling_auto_suspend_timeout_seconds , disableAutoSuspend = autoscaling_disable_auto_suspend , hiveDesiredFreeCapacity = autoscaling_hive_desired_free_capacity ,
211
+ hiveScaleWaitTimeSeconds = autoscaling_hive_scale_wait_time_seconds , impalaScaleDownDelaySeconds = autoscaling_impala_scale_down_delay_seconds , impalaScaleUpDelaySeconds = autoscaling_impala_scale_up_delay_seconds , podConfigName = autoscaling_pod_config_name )
197
212
if autoscaling_min_cluster is not None and autoscaling_min_cluster != 0 :
198
- autoscaling ['minClusters' ] = autoscaling_min_cluster
213
+ autoscaling_all ['minClusters' ] = autoscaling_min_cluster
199
214
if autoscaling_max_cluster is not None and autoscaling_max_cluster != 0 :
200
- autoscaling ['maxClusters' ] = autoscaling_max_cluster
215
+ autoscaling_all ['maxClusters' ] = autoscaling_max_cluster
216
+
217
+ autoscaling = {k : v for k ,
218
+ v in autoscaling_all .items () if v is not None }
219
+
201
220
else :
202
221
autoscaling = None
203
222
@@ -221,10 +240,24 @@ def create_vw(self, cluster_id: str, dbc_id: str, vw_type: str, name: str, templ
221
240
else :
222
241
config = None
223
242
243
+ if any (x is not None for x in [impala_ha_enable_catalog_high_availability , impala_ha_enable_shutdown_of_coordinator , impala_ha_high_availability_mode , impala_ha_num_of_active_coordinators , impala_ha_shutdown_of_coordinator_delay_seconds ]):
244
+
245
+ impala_ha_settings_all = dict (enableCatalogHighAvailability = impala_ha_enable_catalog_high_availability , enableShutdownOfCoordinator = impala_ha_enable_shutdown_of_coordinator ,
246
+ highAvailabilityMode = impala_ha_high_availability_mode , numOfActiveCoordinators = impala_ha_num_of_active_coordinators ,
247
+ shutdownOfCoordinatorDelaySeconds = impala_ha_shutdown_of_coordinator_delay_seconds )
248
+
249
+ impala_ha_settings = {k : v for k ,
250
+ v in impala_ha_settings_all .items () if v is not None }
251
+
252
+ else :
253
+ impala_ha_settings = None
254
+
224
255
return self .sdk .call (
225
256
svc = 'dw' , func = 'create_vw' , ret_field = 'vwId' , clusterId = cluster_id , dbcId = dbc_id ,
226
257
vwType = vw_type , name = name , template = template , autoscaling = autoscaling , config = config ,
227
- tags = tag_list , squelch = [
258
+ tags = tag_list , enableUnifiedAnalytics = enable_unified_analytics ,
259
+ platformJwtAuth = enable_platform_jwt_auth , impalaHaSettings = impala_ha_settings ,
260
+ squelch = [
228
261
Squelch (value = 'PATH_DISABLED' , warning = ENTITLEMENT_DISABLED )
229
262
]
230
263
)
0 commit comments