ShortMessage
Features#
SMS plug -in abstract processing authentication process such as mobile phone verification code/Notice and other SMS sending requirements process,In order to facilitate developers to access the SMS services provided by major manufacturers through heavy loading functions
Implementation#
When developing SMS plug -in,Only inherit the SMS plug -in base class and load send_SMS function can,The processing process is as follows:
sequenceDiagram
    participant C as Platform core
    participant B as SMS plugin
    C->>B: Loading plug -in
    B->>C: Register to listen to SMS events
    rect rgb(191, 223, 255)
    C->>B: Send a SEND_SMS)
    B->>C: Corresponding events and send text messages according to your own configuration,Return result(success/fail)
    end
Abstract function#
Foundation definition#
        
arkid.core.extension.sms.SmsExtension            (Extension)
        
#
    Source code in arkid/core/extension/sms.py
          class SmsExtension(Extension):
    TYPE = "sms"
    @property
    def type(self):
        return SmsExtension.TYPE
    def load(self):
        self.listen_event(SEND_SMS, self.event_send_sms)
        super().load()
    def event_send_sms(self,event,**kwargs):
        """ 发送短信时间
        Args:
            event (Event): 事件
        事件数据(event.data)结构说明:
            ``` json
            {
                "config_id": "xxxx", # 必传,插件运行时配置ID
                "mobile": "xxxx", # 必传,电话号码
                "code": "xxxx", # 非必传,验证码
                "areacode": "xxxx", # 非必传,区号
                "username": "xxxx" # 非必传,用户名
                ...
            }
            ```
        Returns:
            发送短信结果
        """
        if event.packages == self.package or self.package in event.packages:
            return self.send_sms(event,**kwargs)
    @abstractmethod   
    def send_sms(self, event:Event, **kwargs):
        """ 发送短信
        Args:
            event (Event): 事件
        """
        pass
event_send_sms(self, event, **kwargs)
#
    发送短信时间
Parameters:
| Name | Type | Description | Default | 
|---|---|---|---|
| event | Event | 事件 | required | 
事件数据(event.data)结构说明:
{
    "config_id": "xxxx", # 必传,插件运行时配置ID
    "mobile": "xxxx", # 必传,电话号码
    "code": "xxxx", # 非必传,验证码
    "areacode": "xxxx", # 非必传,区号
    "username": "xxxx" # 非必传,用户名
    ...
}
Returns:
| Type | Description | 
|---|---|
| 发送短信结果 | 
Source code in arkid/core/extension/sms.py
          def event_send_sms(self,event,**kwargs):
    """ 发送短信时间
    Args:
        event (Event): 事件
    事件数据(event.data)结构说明:
        ``` json
        {
            "config_id": "xxxx", # 必传,插件运行时配置ID
            "mobile": "xxxx", # 必传,电话号码
            "code": "xxxx", # 非必传,验证码
            "areacode": "xxxx", # 非必传,区号
            "username": "xxxx" # 非必传,用户名
            ...
        }
        ```
    Returns:
        发送短信结果
    """
    if event.packages == self.package or self.package in event.packages:
        return self.send_sms(event,**kwargs)
load(self)
#
    
  
send_sms(self, event, **kwargs)
#
    
  Exemplary#
        
extension_root.com_longgui_sms_aliyun.AliyunSMSExtension            (SmsExtension)
        
#
    Source code in extension_root/com_longgui_sms_aliyun/__init__.py
          class AliyunSMSExtension(SmsExtension):
    def load(self):
        self.register_settings_schema(SettingsSchema)
        self.register_config_schema(ConfigSchema)
        super().load()
    def send_sms(self, event, **kwargs):
        tenant = event.tenant
        config_id = event.data.pop("config_id")
        mobile = event.data.pop("mobile")
        template_params = {}
        settings = self.get_settings(tenant)
        settings = SimpleNamespace(**settings.settings)
        config = self.get_config_by_id(config_id).config
        for key in config.get("template_params",["code"]):
            template_params[key] = event.data.get(key,"")
        template_params = json.dumps(template_params)
        config = SimpleNamespace(**config)
        aliyun_config = models.Config(
            # 您的AccessKey ID,
            access_key_id=settings.access_key_id,
            # 您的AccessKey Secret,
            access_key_secret=settings.access_key_secret,
            # 地域ID
            region_id=settings.region_id or None,
            # 访问的域名
            endpoint=settings.endpoint or None,
        )
        client = Client(aliyun_config)
        send_sms_request = dysmsapi_20170525_models.SendSmsRequest(
            phone_numbers=mobile,
            sign_name=config.sign_name,
            template_code=config.template_code,
            template_param=template_params,
            sms_up_extend_code=config.sms_up_extend_code or None,
            out_id=config.out_id or None,
        )
        res = client.send_sms(send_sms_request)
        return res.body.to_map()
load(self)
#
    
  
send_sms(self, event, **kwargs)
#
    发送短信
Parameters:
| Name | Type | Description | Default | 
|---|---|---|---|
| event | Event | 事件 | required | 
Source code in extension_root/com_longgui_sms_aliyun/__init__.py
          def send_sms(self, event, **kwargs):
    tenant = event.tenant
    config_id = event.data.pop("config_id")
    mobile = event.data.pop("mobile")
    template_params = {}
    settings = self.get_settings(tenant)
    settings = SimpleNamespace(**settings.settings)
    config = self.get_config_by_id(config_id).config
    for key in config.get("template_params",["code"]):
        template_params[key] = event.data.get(key,"")
    template_params = json.dumps(template_params)
    config = SimpleNamespace(**config)
    aliyun_config = models.Config(
        # 您的AccessKey ID,
        access_key_id=settings.access_key_id,
        # 您的AccessKey Secret,
        access_key_secret=settings.access_key_secret,
        # 地域ID
        region_id=settings.region_id or None,
        # 访问的域名
        endpoint=settings.endpoint or None,
    )
    client = Client(aliyun_config)
    send_sms_request = dysmsapi_20170525_models.SendSmsRequest(
        phone_numbers=mobile,
        sign_name=config.sign_name,
        template_code=config.template_code,
        template_param=template_params,
        sms_up_extend_code=config.sms_up_extend_code or None,
        out_id=config.out_id or None,
    )
    res = client.send_sms(send_sms_request)
    return res.body.to_map()