Skip to the content.

Teams Bot如何做全球化

Office365在全球有大量的用户,可以说是拥有最多用户的商业SaaS平台。Teams最近在发展迅猛,有1300万日活用户,已经超越了Slack。😄 Microsoft Teams overtakes Slack with 13 million daily users

我在设计Teams LuckyDraw bot的时候就希望我的bot能够被全世界的用户所使用,这个实际上还是一个非常有挑战的事情。抛开各国的法律法规要求(比如欧盟的GDPR,国家领土归属问题)不说,抛开不同宗教文化要求不说,单单多语言,多时区就是十分复杂。

举几个语言的例子:

  • 英语里有单复数,中文和一些语言里就没有。你在设计多语言界面的时候就需要注意
  • 即使是英语,美式英语(en-US),英式英语(en-UK),印度英语(en-IN),有很多区别
  • 大多数语言是从左到右书写,但是有些是从右到左。界面设计特别需要注意

再举几个时区的例子:

  • 有很多土地领域较大的国家,不像中国只有一个时区,同一个国家有几个时区是很正常的事情
  • 有些国家有些区域有夏令时。比如澳大利亚的布里斯班和悉尼,虽然在一个时区,但是悉尼有夏令时,也就是说平时大家时间一样,但是一到夏天,时间就变得不同了
  • 不同国家对于每周第一天是周一还是周日,定义不同
  • Samoa和Tokelau这两个地方没有2011年12月30日这一天,他们直接从29日跳到了31日( 具体原因 )。不知道这种事情会不会再次发生 (看到这里大家是不是和我当时一样,心里一万个。。。。)
  • 日本从2019年5月1日开始新的calendar,为此,Windows等系统,.NET等运行环境,各类时间处理的库都全面升级,打补丁,出新版本

看了上面几个例子,是不是觉得很无语。是不是瞬间觉得那些国际化的SaaS平台有多伟大和复杂。

那我们来看看Teams app/bot如何处理时间问题,一个好消息是Teams已经帮我们处理了很多问题,来看一下Teams发送给bot的请求payload:

{
    "name": "composeExtension/fetchTask",
    "type": "invoke",
    "timestamp": "2019-06-17T14:32:04.956Z",
    "localTimestamp": "2019-06-18T00:32:04.956+10:00",
    "id": "f:1361493733941541435",
    "channelId": "msteams",
    "serviceUrl": "https://smba.trafficmanager.net/apac/",
    "from": {
        "id": "29:1l8B9m9SOOdHTqLDgmXvSrJyHfwd2ihooa7cxgtzJ8QjQ4WFC4mA_8K2Sa7jL-xUh7g4yh8sZIiDOX6vTtoaz6w",
        "name": "Tony Xia",
        "aadObjectId": "56c6599d-9216-4078-a8cf-3f039d36e1fd"
    },
    "conversation": {
        "isGroup": true,
        "conversationType": "channel",
        "tenantId": "aece5000-341d-493a-841d-f67e417f1447",
        "id": "19:bf1cbc367561473db0c3fe762c11b508@thread.skype"
    },
    "recipient": {
        "id": "28:89e9cdd8-f500-4696-a701-7c2323f62a86",
        "name": "TestMsgExt"
    },
    "entities": [
        {
            "locale": "en-US",
            "country": "US",
            "platform": "Windows",
            "type": "clientInfo"
        }
    ],
    "channelData": {
        "channel": {
            "id": "19:bf1cbc367561473db0c3fe762c11b508@thread.skype"
        },
        "team": {
            "id": "19:bf1cbc367561473db0c3fe762c11b508@thread.skype"
        },
        "tenant": {
            "id": "aece5000-341d-493a-841d-f67e417f1447"
        },
        "source": {
            "name": "compose"
        }
    },
    "value": {
        "commandId": "start",
        "commandContext": "compose",
        "context": {
            "theme": "default"
        }
    },
    "locale": "en-US"
}

上面这个payload里有几个关键的值:

  • timestamp:当前的UTC时间
  • localTimestamp:当前用户所在的他/她的本地时间,加号后面的小时数针对UTC时间的offset
  • locale:当前用户所使用的语言

有了这几个参数,实际上就你的bot就知道改如何处理了吧?

不过,在具体的bot设计中,你还需要时刻留意这几点:

  • 一家公司(一个office365的tenant,可能有使用不同语言的人,可能分散在不同国家,在不同时区)
  • 一个Team或者一个频道channel里的用户也可能使用不同语言,分散在不同国家,在不同时区
  • 即使是同一个用户,他可能旅游或者出差到不同时区的不同国家,他可能在手机上的Teams是中文,但是桌面版本使用英文。

所以。。。所以大家要把你的Teams app走向全世界,需要精心设计,全面考虑。Good Luck!

Written on August 4, 2019