1package mts
2
3//Licensed under the Apache License, Version 2.0 (the "License");
4//you may not use this file except in compliance with the License.
5//You may obtain a copy of the License at
6//
7//http://www.apache.org/licenses/LICENSE-2.0
8//
9//Unless required by applicable law or agreed to in writing, software
10//distributed under the License is distributed on an "AS IS" BASIS,
11//WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//See the License for the specific language governing permissions and
13//limitations under the License.
14//
15// Code generated by Alibaba Cloud SDK Code Generator.
16// Changes may cause incorrect behavior and will be lost if the code is regenerated.
17
18import (
19	"github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
20	"github.com/aliyun/alibaba-cloud-sdk-go/sdk/responses"
21)
22
23// DecryptKey invokes the mts.DecryptKey API synchronously
24func (client *Client) DecryptKey(request *DecryptKeyRequest) (response *DecryptKeyResponse, err error) {
25	response = CreateDecryptKeyResponse()
26	err = client.DoAction(request, response)
27	return
28}
29
30// DecryptKeyWithChan invokes the mts.DecryptKey API asynchronously
31func (client *Client) DecryptKeyWithChan(request *DecryptKeyRequest) (<-chan *DecryptKeyResponse, <-chan error) {
32	responseChan := make(chan *DecryptKeyResponse, 1)
33	errChan := make(chan error, 1)
34	err := client.AddAsyncTask(func() {
35		defer close(responseChan)
36		defer close(errChan)
37		response, err := client.DecryptKey(request)
38		if err != nil {
39			errChan <- err
40		} else {
41			responseChan <- response
42		}
43	})
44	if err != nil {
45		errChan <- err
46		close(responseChan)
47		close(errChan)
48	}
49	return responseChan, errChan
50}
51
52// DecryptKeyWithCallback invokes the mts.DecryptKey API asynchronously
53func (client *Client) DecryptKeyWithCallback(request *DecryptKeyRequest, callback func(response *DecryptKeyResponse, err error)) <-chan int {
54	result := make(chan int, 1)
55	err := client.AddAsyncTask(func() {
56		var response *DecryptKeyResponse
57		var err error
58		defer close(result)
59		response, err = client.DecryptKey(request)
60		callback(response, err)
61		result <- 1
62	})
63	if err != nil {
64		defer close(result)
65		callback(nil, err)
66		result <- 0
67	}
68	return result
69}
70
71// DecryptKeyRequest is the request struct for api DecryptKey
72type DecryptKeyRequest struct {
73	*requests.RpcRequest
74	ResourceOwnerId      string `position:"Query" name:"ResourceOwnerId"`
75	Rand                 string `position:"Query" name:"Rand"`
76	CiphertextBlob       string `position:"Query" name:"CiphertextBlob"`
77	ResourceOwnerAccount string `position:"Query" name:"ResourceOwnerAccount"`
78	OwnerAccount         string `position:"Query" name:"OwnerAccount"`
79	OwnerId              string `position:"Query" name:"OwnerId"`
80}
81
82// DecryptKeyResponse is the response struct for api DecryptKey
83type DecryptKeyResponse struct {
84	*responses.BaseResponse
85	RequestId string `json:"RequestId" xml:"RequestId"`
86	Plaintext string `json:"Plaintext" xml:"Plaintext"`
87	Rand      string `json:"Rand" xml:"Rand"`
88}
89
90// CreateDecryptKeyRequest creates a request to invoke DecryptKey API
91func CreateDecryptKeyRequest() (request *DecryptKeyRequest) {
92	request = &DecryptKeyRequest{
93		RpcRequest: &requests.RpcRequest{},
94	}
95	request.InitWithApiInfo("Mts", "2014-06-18", "DecryptKey", "mts", "openAPI")
96	request.Method = requests.POST
97	return
98}
99
100// CreateDecryptKeyResponse creates a response to parse from DecryptKey response
101func CreateDecryptKeyResponse() (response *DecryptKeyResponse) {
102	response = &DecryptKeyResponse{
103		BaseResponse: &responses.BaseResponse{},
104	}
105	return
106}
107