美洽 2016 版移动应用 SDK 发布小记
继 12 月份 iOS SDK 发布后,16 年第一周 Android SDK 也正式上线,这就意味着面向美洽 2016 版的移动客服 SDK 正式全面发布!希望更多的开发者能利用 SDK 提供的接口,体验美洽 3.0 丰富的功能。
下面是我们新版 SDK 增加的几个重要的功能:
- 绑定开发者的用户系统和美洽顾客系统
- 支持应用内推送聊天消息
- 支持当前顾客离线
- 支持清除 SDK 的缓存
- 支持结束当前对话
- 支持给顾客打标签
- 支持指定分配客服和客服组,以及设定分配规则
- 支持国际化
- 聊天界面支持多种自定义配置
在新版 SDK 开发之前,我们就抱着做优秀产品的态度来打磨这款 SDK。我们深知 SDK 的产品和提供给普通客服用的客服管理工具不一样,SDK 服务的人群是我们可爱的程序员们,「如何让开发者用的爽」成了我们重要的课题。
为了满足程序员们的需求,我们主要做了以下几件事:
- 接口清晰
- 运行稳定
- 界面开源
清晰的接口是 SDK 的美人脸
一款 SDK 给开发者第一印象即是接口了,让开发者能「无障碍」的对接自己的 App 是她的使命。
那么如何能达到「无障碍」的目标呢?
我们觉得首先得保证的是,清晰的命名。我们都知道说明书是没人看的,所以我们尽量让开发者看到接口名字,即能理解接口的意图。同时必须保证命名不会产生歧义。
其次,大部分接口都尽量给开发者一个反馈。人机交互中一个重要的设计即是反馈,我们认为没有反馈的设计是冰冷的。所以我们给大部分接口都添加了反馈,接口调用不论是成功或失败,都能让开发者清晰地了解该接口执行的状态。
最后,不要让接口之间产生依赖。程序员大多都是追求自由的,一套规定顺序的接口调用会让他们抓狂,同时也非常容易引入错误。
稳定是 SDK 的基石
「谁能忍受得了别人的代码导致自己 App 的崩溃?」
我们最不希望看到的就是,由于我们的 SDK 的问题,导致了用户的 App 的异常,甚至崩溃。稳定是我们最需要保证的特性。
为了保证 SDK 的稳定,我们谨慎地使用缓存、设计清晰的数据结构、保证不出现内存泄露、复杂逻辑不影响主线程等等等等。「暂不展开讨论,否则就成了技术博客了,笑。」
我们相信开源的力量
开源是我们新版 SDK 非常重要的改变。
老版 SDK 开放以后,我们几乎每天都会收到一些开发者的留言,很大一部分的问题即是「如何定制客服聊天界面」。由于老版本 SDK 的界面是闭源的,开发者看不到源代码,只能通过 SDK 提供的一些接口完成简单的定制。
后来我们就思考一个问题,「什么是美洽 SDK 的核心竞争力」。我们觉得答案是「让 App 拥有最好的客服功能」。那么如何保证 App 拥有最好的客服功能?除了能完美对接美洽强大的工作台之外,我们觉得还应该有一个「既可以简单使用,也可以完美定制的聊天界面」。
于是我们就重写了聊天界面,并将之开源了出去。
我们还是有一些程序员的尊严的,为了不成为同行的笑柄,我们努力保证代码清晰,添加了大量注释,设计了一套易于定制的代码结构,并和美洽的业务逻辑进行了解耦。
开发者拿到开源界面后,可以很方便地实现自己的显示风格,比如电商类的 App,可以三步实现添加商品链接的显示;再比如社交 App,可以方便实现发送红包的显示等等。
聊天界面开源出去后,让我们很欣喜的一件事情是,一些非美洽用户的开发者也用了该开源项目到自己的 App。这让我们觉得把开源代码和美洽业务解耦是正确的选择。
未来我们 SDK 还会有新的功能、新的产品推出,这些产品的界面我们希望都能开源,甚至在美洽后端开放 API 之后,整个 SDK 均可以开源。
借着开源的力量,让用户看到一个透明和开放的美洽。
传送门:
以上就是美洽 SDK 产品做了、和正在坚持的几件事,如果有哪些地方有不足,欢迎开发者们吐槽。
(题图来自google)
丁南