protected override void BeginProcessing() { try { var newProps = new SnapshotProperties(); if (!string.IsNullOrEmpty(this.Name)) { newProps.Name = this.Name; } if (!string.IsNullOrEmpty(this.LicenceType)) { newProps.LicenceType = this.LicenceType; } if (!string.IsNullOrEmpty(this.LicenceType)) { newProps.LicenceType = this.LicenceType; } newProps.CpuHotPlug = CpuHotPlug; newProps.CpuHotUnplug = CpuHotUnplug; newProps.DiscScsiHotPlug = DiscScsiHotPlug; newProps.DiscScsiHotUnplug = DiscScsiHotUnplug; newProps.DiscVirtioHotPlug = DiscVirtioHotPlug; newProps.DiscVirtioHotUnplug = DiscVirtioHotUnplug; var snapshotApi = new SnapshotApi(Utilities.Configuration); var resp = snapshotApi.Update(SnapshotId, new Snapshot { Properties = newProps }); WriteObject(resp); } catch (Exception ex) { WriteError(new ErrorRecord(ex, "", ErrorCategory.NotSpecified, null)); } }
/// <summary> /// Partially modify a Snapshot You can use update attributes of a resource /// </summary> /// <param name="snapshotId"></param> /// <param name="snapshot">Modified Snapshot</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 (Snapshot)</returns> public async System.Threading.Tasks.Task<ApiResponse<Snapshot>> PartialUpdateAsyncWithHttpInfo(string snapshotId, SnapshotProperties snapshot, bool? parameter = null, int? depth = null) { // verify the required parameter 'snapshotId' is set if (snapshotId == null) throw new ApiException(400, "Missing required parameter 'snapshotId' when calling PartialUpdate"); // verify the required parameter 'snapshot' is set if (snapshot == null) throw new ApiException(400, "Missing required parameter 'snapshot' when calling PartialUpdate"); var path_ = "/snapshots/{snapshotId}"; 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 (snapshotId != null) pathParams.Add("snapshotId", Configuration.ApiClient.ParameterToString(snapshotId)); // 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(snapshot); // 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<Snapshot>(statusCode, response.Headers.ToDictionary(x => x.Name, x => x.Value.ToString()), (Snapshot)Configuration.ApiClient.Deserialize(response, typeof(Snapshot))); }
/// <summary> /// Partially modify a Snapshot You can use update attributes of a resource /// </summary> /// <param name="snapshotId"></param> /// <param name="snapshot">Modified Snapshot</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 Snapshot</returns> public async System.Threading.Tasks.Task<Snapshot> PartialUpdateAsync(string snapshotId, SnapshotProperties snapshot, bool? parameter = null, int? depth = null) { ApiResponse<Snapshot> response = await PartialUpdateAsyncWithHttpInfo(snapshotId, snapshot, parameter, depth); return response.Data; }
/// <summary> /// Partially modify a Snapshot You can use update attributes of a resource /// </summary> /// <param name="snapshotId"></param> /// <param name="snapshot">Modified Snapshot</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>Snapshot</returns> public Snapshot PartialUpdate(string snapshotId, SnapshotProperties snapshot, bool? parameter = null, int? depth = null) { ApiResponse<Snapshot> response = PartialUpdateWithHttpInfo(snapshotId, snapshot, parameter, depth); return response.Data; }