protected override void BeginProcessing() { try { var loadbalancerApi = new LoadBalancerApi(Utilities.Configuration); var newProps = new LoadbalancerProperties { Dhcp = Dhcp }; if (!string.IsNullOrEmpty(Ip)) { newProps.Ip = Ip; } if (!string.IsNullOrEmpty(Name)) { newProps.Name = Name; } var resp = loadbalancerApi.PartialUpdate(DataCenterId, LoadbalancerId, newProps); WriteObject(resp); } catch (Exception ex) { WriteError(new ErrorRecord(ex, "", ErrorCategory.NotSpecified, null)); } }
protected override void BeginProcessing() { try { var loadbalancerApi = new LoadBalancerApi(Utilities.Configuration); var newProps = new LoadbalancerProperties { Name = this.Name, Dhcp = this.Dhcp }; if (!string.IsNullOrEmpty(this.Ip)) { newProps.Ip = this.Ip; } var loadbalancer = loadbalancerApi.Create(DataCenterId, new Loadbalancer { Properties = newProps }); WriteObject(loadbalancer); } catch (Exception ex) { WriteError(new ErrorRecord(ex, "", ErrorCategory.NotSpecified, null)); } }
/// <summary> /// Partially modify a Loadbalancer You can use update attributes of a resource /// </summary> /// <param name="datacenterId"></param> /// <param name="loadbalancerId"></param> /// <param name="loadbalancer">Modified Loadbalancer</param> /// <param name="body"></param> /// <param name="parameter">Controls whether response is pretty-printed (with indentation and new lines)</param> /// <param name="depth">Controls the details depth of response objects. \nEg. GET /datacenters/[ID]\n - depth=0: only direct properties are included. Children (servers etc.) are not included\n - depth=1: direct properties and children references are included\n - depth=2: direct properties and children properties are included\n - depth=3: direct properties and children properties and children's children are included\n - depth=... and so on</param> /// <returns>Task of ApiResponse (Loadbalancer)</returns> public async System.Threading.Tasks.Task<ApiResponse<Loadbalancer>> PartialUpdateAsyncWithHttpInfo(string datacenterId, string loadbalancerId, LoadbalancerProperties loadbalancer, Body2 body = null, bool? parameter = null, int? depth = null) { // verify the required parameter 'datacenterId' is set if (datacenterId == null) throw new ApiException(400, "Missing required parameter 'datacenterId' when calling PartialUpdate"); // verify the required parameter 'loadbalancerId' is set if (loadbalancerId == null) throw new ApiException(400, "Missing required parameter 'loadbalancerId' when calling PartialUpdate"); // verify the required parameter 'loadbalancer' is set if (loadbalancer == null) throw new ApiException(400, "Missing required parameter 'loadbalancer' when calling PartialUpdate"); var path_ = "/datacenters/{datacenterId}/loadbalancers/{loadbalancerId}"; var pathParams = new Dictionary<String, String>(); var queryParams = new Dictionary<String, String>(); var headerParams = new Dictionary<String, String>(); var formParams = new Dictionary<String, String>(); var fileParams = new Dictionary<String, FileParameter>(); Object postBody = null; // to determine the Content-Type header String[] httpContentTypes = new String[] { "application/vnd.profitbricks.partial-properties+json", "application/json" }; String httpContentType = Configuration.ApiClient.SelectHeaderContentType(httpContentTypes); // to determine the Accept header String[] httpHeaderAccepts = new String[] { "application/vnd.profitbricks.resource+json" }; String httpHeaderAccept = Configuration.ApiClient.SelectHeaderAccept(httpHeaderAccepts); if (httpHeaderAccept != null) headerParams.Add("Accept", httpHeaderAccept); // set "format" to json by default // e.g. /pet/{petId}.{format} becomes /pet/{petId}.json pathParams.Add("format", "json"); if (datacenterId != null) pathParams.Add("datacenterId", Configuration.ApiClient.ParameterToString(datacenterId)); // path parameter if (loadbalancerId != null) pathParams.Add("loadbalancerId", Configuration.ApiClient.ParameterToString(loadbalancerId)); // path parameter if (parameter != null) queryParams.Add("parameter", Configuration.ApiClient.ParameterToString(parameter)); // query parameter if (depth != null) queryParams.Add("depth", Configuration.ApiClient.ParameterToString(depth)); // query parameter postBody = Configuration.ApiClient.Serialize(loadbalancer); // http body (model) parameter // authentication (basicAuth) required // http basic authentication required if (!String.IsNullOrEmpty(Configuration.Username) || !String.IsNullOrEmpty(Configuration.Password)) { headerParams["Authorization"] = "Basic " + ApiClient.Base64Encode(Configuration.Username + ":" + Configuration.Password); } // make the HTTP request IRestResponse response = (IRestResponse)await Configuration.ApiClient.CallApiAsync(path_, Method.PATCH, queryParams, postBody, headerParams, formParams, fileParams, pathParams, httpContentType); int statusCode = (int)response.StatusCode; if (statusCode >= 400) throw new ApiException(statusCode, "Error calling PartialUpdate: " + response.Content, response.Content); else if (statusCode == 0) throw new ApiException(statusCode, "Error calling PartialUpdate: " + response.ErrorMessage, response.ErrorMessage); return new ApiResponse<Loadbalancer>(statusCode, response.Headers.ToDictionary(x => x.Name, x => x.Value.ToString()), (Loadbalancer)Configuration.ApiClient.Deserialize(response, typeof(Loadbalancer))); }
/// <summary> /// Partially modify a Loadbalancer You can use update attributes of a resource /// </summary> /// <param name="datacenterId"></param> /// <param name="loadbalancerId"></param> /// <param name="loadbalancer">Modified Loadbalancer</param> /// <param name="body"></param> /// <param name="parameter">Controls whether response is pretty-printed (with indentation and new lines)</param> /// <param name="depth">Controls the details depth of response objects. \nEg. GET /datacenters/[ID]\n - depth=0: only direct properties are included. Children (servers etc.) are not included\n - depth=1: direct properties and children references are included\n - depth=2: direct properties and children properties are included\n - depth=3: direct properties and children properties and children's children are included\n - depth=... and so on</param> /// <returns>Task of Loadbalancer</returns> public async System.Threading.Tasks.Task<Loadbalancer> PartialUpdateAsync(string datacenterId, string loadbalancerId, LoadbalancerProperties loadbalancer, Body2 body = null, bool? parameter = null, int? depth = null) { ApiResponse<Loadbalancer> response = await PartialUpdateAsyncWithHttpInfo(datacenterId, loadbalancerId, loadbalancer, body, parameter, depth); return response.Data; }
/// <summary> /// Partially modify a Loadbalancer You can use update attributes of a resource /// </summary> /// <param name="datacenterId"></param> /// <param name="loadbalancerId"></param> /// <param name="loadbalancer">Modified Loadbalancer</param> /// <param name="body"></param> /// <param name="parameter">Controls whether response is pretty-printed (with indentation and new lines)</param> /// <param name="depth">Controls the details depth of response objects. \nEg. GET /datacenters/[ID]\n - depth=0: only direct properties are included. Children (servers etc.) are not included\n - depth=1: direct properties and children references are included\n - depth=2: direct properties and children properties are included\n - depth=3: direct properties and children properties and children's children are included\n - depth=... and so on</param> /// <returns>Loadbalancer</returns> public Loadbalancer PartialUpdate(string datacenterId, string loadbalancerId, LoadbalancerProperties loadbalancer, Body2 body = null, bool? parameter = null, int? depth = null) { ApiResponse<Loadbalancer> response = PartialUpdateWithHttpInfo(datacenterId, loadbalancerId, loadbalancer, body, parameter, depth); return response.Data; }