# -*- coding: utf8 -*-
# Copyright (c) 2017-2021 THL A29 Limited, a Tencent company. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import json
from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
from tencentcloud.common.abstract_client import AbstractClient
from tencentcloud.sms.v20190711 import models
class SmsClient(AbstractClient):
_apiVersion = '2019-07-11'
_endpoint = 'sms.tencentcloudapi.com'
_service = 'sms'
def AddSmsSign(self, request):
"""本接口 (AddSmsSign) 用于添加短信签名。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>添加短信签名前,请先认真参阅 <a href="https://cloud.tencent.com/document/product/382/39022">腾讯云短信签名审核标准。</a></li><li>个人认证用户不支持使用 API 申请短信签名,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 申请短信签名。</li></ul></blockquote>
:param request: Request instance for AddSmsSign.
:type request: :class:`tencentcloud.sms.v20190711.models.AddSmsSignRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.AddSmsSignResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("AddSmsSign", params, headers=headers)
response = json.loads(body)
model = models.AddSmsSignResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def AddSmsTemplate(self, request):
"""本接口 (AddSmsTemplate) 用于创建短信模板。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>申请短信模板前,请先认真参阅 <a href="https://cloud.tencent.com/document/product/382/39023">腾讯云短信正文模板审核标准。</a></li><li>个人认证用户不支持使用 API 申请短信正文模板,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 申请短信正文模板。</li></ul></blockquote>
:param request: Request instance for AddSmsTemplate.
:type request: :class:`tencentcloud.sms.v20190711.models.AddSmsTemplateRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.AddSmsTemplateResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("AddSmsTemplate", params, headers=headers)
response = json.loads(body)
model = models.AddSmsTemplateResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def CallbackStatusStatistics(self, request):
"""本接口 (CallbackStatusStatistics) 用于统计用户回执的数据。
:param request: Request instance for CallbackStatusStatistics.
:type request: :class:`tencentcloud.sms.v20190711.models.CallbackStatusStatisticsRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.CallbackStatusStatisticsResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("CallbackStatusStatistics", params, headers=headers)
response = json.loads(body)
model = models.CallbackStatusStatisticsResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def DeleteSmsSign(self, request):
"""本接口 (DeleteSmsSign) 用于删除短信签名。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>个人认证用户不支持使用 API 删除短信签名,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 删除短信签名。</li></ul></blockquote>
:param request: Request instance for DeleteSmsSign.
:type request: :class:`tencentcloud.sms.v20190711.models.DeleteSmsSignRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.DeleteSmsSignResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("DeleteSmsSign", params, headers=headers)
response = json.loads(body)
model = models.DeleteSmsSignResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def DeleteSmsTemplate(self, request):
"""本接口 (DeleteSmsTemplate) 用于删除短信模板。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>个人认证用户不支持使用 API 删除短信正文模板,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 删除短信正文模板。</li></ul></blockquote>
:param request: Request instance for DeleteSmsTemplate.
:type request: :class:`tencentcloud.sms.v20190711.models.DeleteSmsTemplateRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.DeleteSmsTemplateResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("DeleteSmsTemplate", params, headers=headers)
response = json.loads(body)
model = models.DeleteSmsTemplateResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def DescribeSmsSignList(self, request):
"""本接口 (DescribeSmsSignList) 用于查询短信签名状态。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>个人认证用户不支持使用 API 查询短信签名,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 查询短信签名。</li></ul></blockquote>
:param request: Request instance for DescribeSmsSignList.
:type request: :class:`tencentcloud.sms.v20190711.models.DescribeSmsSignListRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.DescribeSmsSignListResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("DescribeSmsSignList", params, headers=headers)
response = json.loads(body)
model = models.DescribeSmsSignListResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def DescribeSmsTemplateList(self, request):
"""本接口 (DescribeSmsTemplateList) 用于查询短信模板状态。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>个人认证用户不支持使用 API 查询短信正文模板,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 查询短信正文模板。</li></ul></blockquote>
:param request: Request instance for DescribeSmsTemplateList.
:type request: :class:`tencentcloud.sms.v20190711.models.DescribeSmsTemplateListRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.DescribeSmsTemplateListResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("DescribeSmsTemplateList", params, headers=headers)
response = json.loads(body)
model = models.DescribeSmsTemplateListResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def ModifySmsSign(self, request):
"""本接口 (ModifySmsSign) 用于修改短信签名。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>修改短信签名前,请先认真参阅 <a href="https://cloud.tencent.com/document/product/382/39022">腾讯云短信签名审核标准。</a></li><li>个人认证用户不支持使用 API 修改短信签名,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 修改短信签名。</li><li>修改短信签名,仅当签名为<b>待审核</b>或<b>已拒绝</b>状态时,才能进行修改,<b>已审核通过</b>的签名不支持修改。</li></ul></blockquote>
:param request: Request instance for ModifySmsSign.
:type request: :class:`tencentcloud.sms.v20190711.models.ModifySmsSignRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.ModifySmsSignResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("ModifySmsSign", params, headers=headers)
response = json.loads(body)
model = models.ModifySmsSignResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def ModifySmsTemplate(self, request):
"""本接口 (ModifySmsTemplate) 用于修改短信模板。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>修改短信正文模板前,请先认真参阅 <a href="https://cloud.tencent.com/document/product/382/39023">腾讯云短信正文模板审核标准。</a></li><li>个人认证用户不支持使用 API 修改短信正文模板,请参阅了解 <a href="https://cloud.tencent.com/document/product/378/3629">实名认证基本介绍</a>,如果为个人认证请登录 <a href="https://console.cloud.tencent.com/smsv2">控制台</a> 修改短信正文模板。</li><li>修改短信模板,仅当正文模板为<b>待审核</b>或<b>已拒绝</b>状态时,才能进行修改,<b>已审核通过</b>的正文模板不支持修改。</li></ul></blockquote>
:param request: Request instance for ModifySmsTemplate.
:type request: :class:`tencentcloud.sms.v20190711.models.ModifySmsTemplateRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.ModifySmsTemplateResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("ModifySmsTemplate", params, headers=headers)
response = json.loads(body)
model = models.ModifySmsTemplateResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def PullSmsReplyStatus(self, request):
"""本接口 (PullSmsReplyStatus) 用于拉取短信回复状态。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>此接口需要联系 <a href="https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81">腾讯云短信小助手</a> 开通。</li><li>上行回复也支持 <a href="https://cloud.tencent.com/document/product/382/42907">配置回复回调</a> 的方式获取。</li></ul></blockquote>
:param request: Request instance for PullSmsReplyStatus.
:type request: :class:`tencentcloud.sms.v20190711.models.PullSmsReplyStatusRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.PullSmsReplyStatusResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("PullSmsReplyStatus", params, headers=headers)
response = json.loads(body)
model = models.PullSmsReplyStatusResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def PullSmsReplyStatusByPhoneNumber(self, request):
"""本接口 (PullSmsReplyStatusByPhoneNumber) 用于拉取单个号码短信回复状态。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>上行回复也支持 <a href="https://cloud.tencent.com/document/product/382/42907">配置回复回调</a> 的方式获取。</li></ul></blockquote>
:param request: Request instance for PullSmsReplyStatusByPhoneNumber.
:type request: :class:`tencentcloud.sms.v20190711.models.PullSmsReplyStatusByPhoneNumberRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.PullSmsReplyStatusByPhoneNumberResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("PullSmsReplyStatusByPhoneNumber", params, headers=headers)
response = json.loads(body)
model = models.PullSmsReplyStatusByPhoneNumberResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def PullSmsSendStatus(self, request):
"""本接口 (PullSmsSendStatus) 用于拉取短信下发状态。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>此接口需要联系 <a href="https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81">腾讯云短信小助手</a> 开通。</li><li>下发状态也支持 <a href="https://cloud.tencent.com/document/product/382/37809#.E7.9F.AD.E4.BF.A1.E7.8A.B6.E6.80.81.E5.9B.9E.E8.B0.83.E9.85.8D.E7.BD.AE">配置回调</a> 的方式获取。</li></ul></blockquote>
:param request: Request instance for PullSmsSendStatus.
:type request: :class:`tencentcloud.sms.v20190711.models.PullSmsSendStatusRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.PullSmsSendStatusResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("PullSmsSendStatus", params, headers=headers)
response = json.loads(body)
model = models.PullSmsSendStatusResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def PullSmsSendStatusByPhoneNumber(self, request):
"""本接口 (PullSmsSendStatusByPhoneNumber) 用于拉取单个号码短信下发状态。
<blockquote class="d-mod-explain"><div class="d-mod-title d-explain-title" style="line-height: normal;"><i class="d-icon-explain"></i>说明:</div><p></p><ul><li>下发状态也支持 <a href="https://cloud.tencent.com/document/product/382/37809#.E7.9F.AD.E4.BF.A1.E7.8A.B6.E6.80.81.E5.9B.9E.E8.B0.83.E9.85.8D.E7.BD.AE">配置回调</a> 的方式获取。</li></ul></blockquote>
:param request: Request instance for PullSmsSendStatusByPhoneNumber.
:type request: :class:`tencentcloud.sms.v20190711.models.PullSmsSendStatusByPhoneNumberRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.PullSmsSendStatusByPhoneNumberResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("PullSmsSendStatusByPhoneNumber", params, headers=headers)
response = json.loads(body)
model = models.PullSmsSendStatusByPhoneNumberResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def SendSms(self, request):
"""本接口 (SendSms) 用于发送验证码、通知类短信和营销短信。支持国内短信与国际/港澳台短信。
:param request: Request instance for SendSms.
:type request: :class:`tencentcloud.sms.v20190711.models.SendSmsRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.SendSmsResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("SendSms", params, headers=headers)
response = json.loads(body)
model = models.SendSmsResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def SendStatusStatistics(self, request):
"""本接口 (SendStatusStatistics) 用于统计用户发送短信的数据。
:param request: Request instance for SendStatusStatistics.
:type request: :class:`tencentcloud.sms.v20190711.models.SendStatusStatisticsRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.SendStatusStatisticsResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("SendStatusStatistics", params, headers=headers)
response = json.loads(body)
model = models.SendStatusStatisticsResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))
def SmsPackagesStatistics(self, request):
"""本接口 (SmsPackagesStatistics) 用于统计用户套餐包数据。
:param request: Request instance for SmsPackagesStatistics.
:type request: :class:`tencentcloud.sms.v20190711.models.SmsPackagesStatisticsRequest`
:rtype: :class:`tencentcloud.sms.v20190711.models.SmsPackagesStatisticsResponse`
"""
try:
params = request._serialize()
headers = request.headers
body = self.call("SmsPackagesStatistics", params, headers=headers)
response = json.loads(body)
model = models.SmsPackagesStatisticsResponse()
model._deserialize(response["Response"])
return model
except Exception as e:
if isinstance(e, TencentCloudSDKException):
raise
else:
raise TencentCloudSDKException(type(e).__name__, str(e))