RingCentral JavaScript SDK 句柄重定向 URI 指向本地 JavaScript 函数
根据每个文档,他们提供选项
RingCentral.SDK.handleLoginRedirect()
但不知道如何使用它
var SDK = require('ringcentral');
rcsdk = new SDK({
server: SDK.server.sandbox,
appKey: '_app_key',
appSecret: 'app_password',
redirectUri: ''
})
function handleredirectURI(){
//handle redirections
}
我们需要指出我们的handleredirectURI
功能 提前致谢
根据文档。上下文是 3 条腿的 oAuth。这是一个演示:https://github.com/ringcentral/ringcentral-demos-oauth/tree/master/javascript
但是,演示不使用handleredirectURI
方法。这意味着该方法只是一个实用方法,不需要使用它。
对于handleredirectURI
的用法,我稍后会回来更新我的答案。
更新
以下是handleredirectURI
的源代码 https://github.com/ringcentral/ringcentral-js/blob/669b7d06254d3620c5a5f24c94b401aa862be948/src/SDK.js#L115-L124:
您可以看到该方法解析win.location
以获取一些有用的数据并postMessage
回到其打开器。
handleredirectURI
的单元测试:https://github.com/ringcentral/ringcentral-js/blob/669b7d06254d3620c5a5f24c94b401aa862be948/src/SDK-spec.js#L27-L63
更新 2
我再次阅读了handleredirectURI
源代码,单元测试,示例代码,我认为它的用法就像其文档中所写的那样:
弹出设置
当您的应用在第三方网站上呈现为微件时,此设置非常有用。
如果您想简单地在弹出窗口中打开RingCentral登录页面,您可以在应用程序的登录页面中使用以下简写:
var platform = rcsdk.platform();
var loginUrl = platform.loginUrl({implicit: true}); // implicit parameter is optional, default false
platform
.loginWindow({url: loginUrl}) // this method also allows to supply more options to control window position
.then(function (loginOptions){
return platform.login(loginOptions);
})
.then(...)
.catch(...);
在这种情况下,您的着陆页(重定向 URI 指向的页面)需要调用以下代码:
RingCentral.SDK.handleLoginRedirect();
解释:
- 运行第一个代码片段以打开登录弹出窗口。
- 在重定向到页面中,运行第二个代码片段(即一行代码)以完成其他所有操作。
- 之后,授权部分完成,您可以调用其他 API。
如果您有更多问题,请告诉我。