public object Execute(ExecutorContext context) { var cmdletContext = context as CmdletContext; // create request var request = new Amazon.SimpleSystemsManagement.Model.AddTagsToResourceRequest(); if (cmdletContext.ResourceId != null) { request.ResourceId = cmdletContext.ResourceId; } if (cmdletContext.ResourceType != null) { request.ResourceType = cmdletContext.ResourceType; } if (cmdletContext.Tag != null) { request.Tags = cmdletContext.Tag; } CmdletOutput output; // issue call var client = Client ?? CreateClient(_CurrentCredentials, _RegionEndpoint); try { var response = CallAWSServiceOperation(client, request); object pipelineOutput = null; pipelineOutput = cmdletContext.Select(response, this); output = new CmdletOutput { PipelineOutput = pipelineOutput, ServiceResponse = response }; } catch (Exception e) { output = new CmdletOutput { ErrorResponse = e }; } return(output); }
private Amazon.SimpleSystemsManagement.Model.AddTagsToResourceResponse CallAWSServiceOperation(IAmazonSimpleSystemsManagement client, Amazon.SimpleSystemsManagement.Model.AddTagsToResourceRequest request) { Utils.Common.WriteVerboseEndpointMessage(this, client.Config, "AWS Systems Manager", "AddTagsToResource"); try { #if DESKTOP return(client.AddTagsToResource(request)); #elif CORECLR return(client.AddTagsToResourceAsync(request).GetAwaiter().GetResult()); #else #error "Unknown build edition" #endif } catch (AmazonServiceException exc) { var webException = exc.InnerException as System.Net.WebException; if (webException != null) { throw new Exception(Utils.Common.FormatNameResolutionFailureMessage(client.Config, webException.Message), webException); } throw; } }
/// <summary> /// Adds or overwrites one or more tags for the specified resource. Tags are metadata /// that you assign to your managed instances. Tags enable you to categorize your managed /// instances in different ways, for example, by purpose, owner, or environment. Each /// tag consists of a key and an optional value, both of which you define. For example, /// you could define a set of tags for your account's managed instances that helps you /// track each instance's owner and stack level. For example: Key=Owner and Value=DbAdmin, /// SysAdmin, or Dev. Or Key=Stack and Value=Production, Pre-Production, or Test. Each /// resource can have a maximum of 10 tags. /// /// /// <para> /// We recommend that you devise a set of tag keys that meets your needs for each resource /// type. Using a consistent set of tag keys makes it easier for you to manage your resources. /// You can search and filter the resources based on the tags you add. Tags don't have /// any semantic meaning to Amazon EC2 and are interpreted strictly as a string of characters. /// /// </para> /// /// <para> /// For more information about tags, see <a href="http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html">Tagging /// Your Amazon EC2 Resources</a> in the Amazon EC2 User Guide. /// </para> /// </summary> /// <param name="request">Container for the necessary parameters to execute the AddTagsToResource service method.</param> /// /// <returns>The response from the AddTagsToResource service method, as returned by SimpleSystemsManagement.</returns> /// <exception cref="Amazon.SimpleSystemsManagement.Model.InternalServerErrorException"> /// An error occurred on the server side. /// </exception> /// <exception cref="Amazon.SimpleSystemsManagement.Model.InvalidResourceIdException"> /// The resource ID is not valid. Verify that you entered the correct ID and try again. /// </exception> /// <exception cref="Amazon.SimpleSystemsManagement.Model.InvalidResourceTypeException"> /// The resource type is not valid. If you are attempting to tag an instance, the instance /// must be a registered, managed instance. /// </exception> /// <exception cref="Amazon.SimpleSystemsManagement.Model.TooManyTagsErrorException"> /// The <code>Targets</code> parameter includes too many tags. Remove one or more tags /// and try the command again. /// </exception> public AddTagsToResourceResponse AddTagsToResource(AddTagsToResourceRequest request) { var marshaller = new AddTagsToResourceRequestMarshaller(); var unmarshaller = AddTagsToResourceResponseUnmarshaller.Instance; return Invoke<AddTagsToResourceRequest,AddTagsToResourceResponse>(request, marshaller, unmarshaller); }
/// <summary> /// Initiates the asynchronous execution of the AddTagsToResource operation. /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the AddTagsToResource operation on AmazonSimpleSystemsManagementClient.</param> /// <param name="callback">An AsyncCallback delegate that is invoked when the operation completes.</param> /// <param name="state">A user-defined state object that is passed to the callback procedure. Retrieve this object from within the callback /// procedure using the AsyncState property.</param> /// /// <returns>An IAsyncResult that can be used to poll or wait for results, or both; this value is also needed when invoking EndAddTagsToResource /// operation.</returns> public IAsyncResult BeginAddTagsToResource(AddTagsToResourceRequest request, AsyncCallback callback, object state) { var marshaller = new AddTagsToResourceRequestMarshaller(); var unmarshaller = AddTagsToResourceResponseUnmarshaller.Instance; return BeginInvoke<AddTagsToResourceRequest>(request, marshaller, unmarshaller, callback, state); }
/// <summary> /// Initiates the asynchronous execution of the AddTagsToResource operation. /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the AddTagsToResource operation.</param> /// <param name="cancellationToken"> /// A cancellation token that can be used by other objects or threads to receive notice of cancellation. /// </param> /// <returns>The task object representing the asynchronous operation.</returns> public Task<AddTagsToResourceResponse> AddTagsToResourceAsync(AddTagsToResourceRequest request, System.Threading.CancellationToken cancellationToken = default(CancellationToken)) { var marshaller = new AddTagsToResourceRequestMarshaller(); var unmarshaller = AddTagsToResourceResponseUnmarshaller.Instance; return InvokeAsync<AddTagsToResourceRequest,AddTagsToResourceResponse>(request, marshaller, unmarshaller, cancellationToken); }