RingCentral JavaScript SDK Handle Redirect URI 指向本地 JavaScri



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。

如果您有更多问题,请告诉我。

最新更新