0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-06 20:40:08 -05:00
logto/packages/connector-aliyun-sms
Wang Sijie 8db355287c
refactor(connector): apply new design (#1817)
* feat(core,connector-core): add connector core (#1803)

* feat(core,connector-core): add connector core

* fix: create connector function

* refactor(connector): change connectors dependency from connector-types to connector-core (#1812)

* refactor(connector,core): change the connectors dependency from connector-types to connector-core

* refactor(core): do not need to test validator for specific connector implementation

* refactor(connector): remove unnecessary code snippets

* refactor(connector): keep UT placeholder for passwordless connectors

Co-authored-by: wangsijie <wangsijie@silverhand.io>

* fix(core): fix IT description and undestructure error (#1818)

fix(connector): fix connector routes and IT typos

* fix(connector): remove @logto/connector-types as it will not be used anymore (#1819)

fix(connector): remove @logto/connector-types as it will not be used anymore

* chore(connector): rename db in logto connector (#1821)

chore(connector): rename LogtoConnector db to dbEntry

Co-authored-by: Darcy Ye <darcyye@silverhand.io>
2022-08-26 16:25:08 +08:00
..
docs docs(connector-aliyun-sms): add readme.md (en-US) (#1236) 2022-06-27 07:42:50 +00:00
src refactor(connector): apply new design (#1817) 2022-08-26 16:25:08 +08:00
CHANGELOG.md release: v1.0.0-beta.5 2022-08-19 13:49:33 +00:00
jest.config.ts refactor: simplify jest.config.ts (#1741) 2022-08-05 18:43:32 +08:00
logo.svg feat(core,connectors): update Aliyun logo and add logo_dark to Apple, Github (#1194) 2022-06-23 11:12:29 +08:00
package.json refactor(connector): apply new design (#1817) 2022-08-26 16:25:08 +08:00
README.md docs(connector): refine readme of connector-aliyun-sms (#1554) 2022-07-15 07:43:55 +00:00
tsconfig.base.json feat(core): wrap aliyun short message service connector (#670) 2022-04-28 14:48:18 +08:00
tsconfig.build.json feat(core): wrap aliyun short message service connector (#670) 2022-04-28 14:48:18 +08:00
tsconfig.json chore(connectors): remove unused jest-matcher-specific-error in connector packages (#1024) 2022-06-02 12:03:11 +08:00
tsconfig.test.json test: allow JS in tests (#903) 2022-05-20 13:02:36 +08:00

Aliyun short message service connector

The official Logto connector for Aliyun short message service.

阿里云短信服务 Logto 官方连接器 中文文档

Table of contents

Get started

Aliyun is a primary cloud service provider in Asia, offering many cloud services, including SMS (short message service). Aliyun SMS Connector is a plugin provided by the Logto team to call the Aliyun SMS service, with the help of which Logto end-users can register and sign in to their Logto account via SMS verification code (or in other words, passcode).

Set up a short message service in Aliyun SMS Console

💡 Tip

You can skip some sections if you have already finished.

Create an Aliyun account

Go to the Aliyun website and register your Aliyun account if you don't have one.

Enable and Configure Aliyun Short Message Service

  1. Sign-in with your Aliyun account at the Aliyun website and go to the SMS service console page.
  2. Click the "Open for free" (免费开通) button on the top left of the SMS service page and begin the configuration process.
  3. Read and agree to the "SMS service activation Agreement" (短信服务开通条款) and click "Subscribe to a service" (开通服务) to move on.
  4. You are now on the SMS service console page, go to either "Mainland China" (国内消息) or "Outside Mainland China" (国际/港澳台消息) button on the sidebar per your use case.
  5. Add signature and template following the guidelines, and provide the materials or information required for review.
    • Remember to select "Verification Code Message" (验证码) as "Scenario" (适用场景) when filling out the signature application and also "Verification Code Message" (验证码) for "Type" (模板类型) when applying for a template review because we are using these signatures and templates to send passcode. Currently, we do not support sending SMS messages other than verification-code-related text messages.
    • Also, use {{code}} as a placeholder where you want to place your digital passcode in template contents.
  6. After submitting your SMS signature and template application, you need to wait for it to take effect. At this point, we can go back to the SMS service console page and send a test SMS. If your signatures and templates are ready for use, you can try them directly; if they are not taking effect yet, Aliyun also provides test templates.
    • You may need to recharge a small amount of money before sending test messages.
    • You may also be asked to bind a test phone number before sending test messages. For more details, go to "Quick Start" (快速学习) tab from the sidebar of the SMS service console page.

Compose the connector JSON

  1. From the SMS service console page, hover on your avatar in the top right corner and go to "AccessKey Management" (AccessKey 管理), and click "Create AccessKey" (创建 AccessKey). You will get an "AccessKey ID" and "AccessKey Secret" pair after finishing security verification. Please keep them properly.
  2. Go to the "Mainland China" (国内消息) or "Outside Mainland China" (国际/港澳台消息) tab you just visited, you can find "Signature" (签名名称) and "Template Code" (模板 CODE) easily.
    • If you want to use the test-only signature and template, go to the "Quick Start" (快速学习) tab instead, and you will find them below "Signature & Templates (For Test Only)".
  3. Fill out the Aliyun SMS Connector settings:
    • Fill out the accessKeyId and accessKeySecret fields with access key pairs you've got from step 1.
    • Fill out the signName field with "Signature" (签名名称) which is mentioned in step 2. All templates will share this signature name.
    • You can add multiple SMS connector templates for different cases. Here is an example of adding a single template:
      • Fill the templateCode field, which is how you can control SMS context, with "Template Code" (模板 CODE) from step 2.
      • Fill out usageType field with either Register, SignIn or Test for different use cases. (usageType is a Logto property to identify the proper use case.)

Here is an example of Aliyun SMS connector config JSON.

{
    "accessKeyId": "<your-access-key-id>",
    "accessKeySecret": "<your-access-key-secret>",
    "signName": "<Aliyun>",
    "templates": [
        {
            "templateCode": "<SMS_123456>",
            "usageType": "Register"
        },
        {
            "templateCode": "<SMS_234567>",
            "usageType": "SignIn"
        },
        {
            "templateCode": "<SMS_345678>",
            "usageType": "Test"
        },
    ]
}

Test Aliyun SMS connector

You can type in a phone number and click on "Send" to see whether the settings can work before "Save and Done".

That's it. Don't forget to Enable connector in sign-in experience.

Config types

Name Type
accessKeyId string
accessKeySecret string
signName string
templates Template[]
Template Properties Type Enum values
templateCode string N/A
usageType enum string 'Register' | 'SignIn' | 'Test'

References

阿里云短信连接器

阿里云是亚洲地区一个重要的云服务厂商,提供了包括短信服务在内的诸多云服务。

本连接器是 Logto 官方提供的阿里云短信连接器,帮助终端用户通过短信验证码进行登录注册。

在阿里云短信服务控制台中配置一个短信服务

💡 Tip

你可以跳过已经完成的部分。

创建阿里云账号

前往 阿里云 并完成账号注册。

启用并配置阿里云短信服务

  1. 用刚刚在 阿里云 注册额账号登录并前往 短信服务控制台
  2. 点按短信服务页面左上角的「免费开通」按钮并开始配置的流程。
  3. 阅读并同意「短信服务开通条款」和「开通服务」以继续。
  4. 你现在处于「短信服务控制台概览」,根据你的用户场景,点击侧边栏中的「国内消息」或者「国际/港澳台消息」。
  5. 跟随指引添加签名和模板,并提供相应的材料和信息以便审核:
    • 注意:添加 签名 时要在「适用场景」栏选择「验证码」,添加 模板 时「模板类型」也要选择「验证码」,因为我们的使用这些签名和模板就是用来发送验证码的。目前我们暂不支持除了发送验证码之外别的类型的文字短信。
    • 请同时注意要在模板的内容中加上 {{code}} 的占位符,在发送短信是会被随机生成的验证码所替代。
  6. 提交了短信签名和模板的申请之后,需要等待它们生效。这时候我们可以回到 短信服务控制台概览 发送测试短信。如果你的签名和模板都已经通过审核,你可以直接使用它们测试;如果它们还没有通过审核,阿里云也提供了测试模板供使用。
    • 在发送测试短信之前,可能你需要对账户进行小额的充值。
    • 测试时也需要提前绑定测试使用的手机号码以成功收到测试短信。点击 短信服务控制台概览 侧边栏上的「快速学习」标签页以了解更多。

编写连接器的 JSON

  1. 前往 短信服务控制台概览将鼠标悬停在页面右上角的头像处进入「AccessKey 管理」并点按「创建 AccessKey」。完成了安全验证之后你会得到一对「AccessKey ID」和「AccessKey Secret」请妥善保管他们。
  2. 前往你之前访问过的「国内消息」或「国际/港澳台消息」标签页,可以很快找到「签名名称」和「模板 CODE」。
    • 如果你想使用测试专用的签名模板, 则前往「快速开始」标签页,你就能在「测试专用签名模版」下方找到它们。
  3. 完成阿里云短信服务连接器的设置:
    • 用你在步骤 1 中拿到的一对「AccessKey ID」和「AccessKey Secret」来分别填入 accessKeyIdaccessKeySecret
    • 用你在步骤 2 中拿到的「签名名称」填入 signName 栏。所有的模板都会共用这个签名。
    • 你可以添加多个短信服务模板以应对不同的用户场景。这里展示填写单个模板的例子:
      • templateCode 栏是你可以用来控制所发送短信内容的属性。它们的值从步骤 2 中的「模板 CODE」获取。
      • usageType 栏填写 RegisterSignIn 或者 Test 其中之一以分别对应 注册登录测试 的不同场景。(usageType 是 Logto 的属性,用来确定使用场景。)

这是一个阿里云短信服务连接器 JSON 配置的样例。

{
    "accessKeyId": "<your-access-key-id>",
    "accessKeySecret": "<your-access-key-secret>",
    "signName": "<Aliyun>",
    "templates": [
        {
            "templateCode": "<SMS_123456>",
            "usageType": "Register"
        },
        {
            "templateCode": "<SMS_234567>",
            "usageType": "SignIn"
        },
        {
            "templateCode": "<SMS_345678>",
            "usageType": "Test"
        },
    ]
}

测试阿里云短信连接器

你可以在「保存并完成」之前输入一个手机号码并点按「发送」来测试配置是否可以正常工作。

大功告成!快去 启用短信或邮件验证码登录 吧。

配置类型

名称 类型
accessKeyId string
accessKeySecret string
signName string
templates Template[]
模板属性 类型 枚举值
templateCode string N/A
usageType enum string 'Register' | 'SignIn' | 'Test'

参考