【发布时间】:2019-03-30 11:07:26
【问题描述】:
我正在为第三方来源 Siteimprove 构建一个 Google Data Studio 连接器。 Siteimprove 有一个需要Basic Access Authentication 的api。
我已经在我的谷歌应用脚本中为username and token(我也尝试过用户名和密码)设置了身份验证,所有必需的功能都基于文档
-edit-按要求提供这些功能的完整代码
/**
* Returns the Auth Type of this connector.
* @return {object} The Auth type.
*/
function getAuthType() {
var cc = DataStudioApp.createCommunityConnector();
return cc.newAuthTypeResponse()
.setAuthType(cc.AuthType.USER_TOKEN)
.setHelpUrl('http://developer.siteimprove.com/v1/get-access/')
.build();
}
/**
* Resets the auth service.
*/
function resetAuth() {
var user_tokenProperties = PropertiesService.getUserProperties();
user_tokenProperties.deleteProperty('dscc.username');
user_tokenProperties.deleteProperty('dscc.password');
}
/**
* Returns true if the auth service has access.
* @return {boolean} True if the auth service has access.
*/
function isAuthValid() {
var userProperties = PropertiesService.getUserProperties();
var userName = userProperties.getProperty('dscc.username');
var token = userProperties.getProperty('dscc.token');
// This assumes you have a validateCredentials function that
// can validate if the userName and token are correct.
return validateCredentials(userName, token);
}
/**
* Sets the credentials.
* @param {Request} request The set credentials request.
* @return {object} An object with an errorCode.
*/
function setCredentials(request) {
var creds = request.userToken;
var username = creds.username;
var token = creds.token;
// Optional
// Check if the provided username and token are valid through a
// call to your service. You would have to have a `checkForValidCreds`
// function defined for this to work.
var validCreds = validateCredentials(username, token);
if (!validCreds) {
return {
errorCode: 'INVALID_CREDENTIALS'
};
}
var userProperties = PropertiesService.getUserProperties();
userProperties.setProperty('dscc.username', username);
userProperties.setProperty('dscc.token', token);
return {
errorCode: 'NONE'
};
}
function validateCredentials(userName,token){
var headers = {
"Authorization" : "Basic " + Utilities.base64Encode(userName + ':' + token)
};
var params = {
"method":"GET",
"headers":headers
};
var response = UrlFetchApp.fetch("https://api.siteimprove.com/v2/", params);
return response;
console.log(response);
}
还有清单文件
{
"dataStudio": {
"name": "Connector for Siteimprove",
"company": "<company name>",
"logoUrl": "<company logo url>",
"addonUrl": "",
"supportUrl": "",
"description": "This connector can be used to show basic data from Siteimprove"
}
}
当我运行脚本时,我会收到输入凭据的提示,但这是连接谷歌帐户 的提示
但我需要一种方法来为第三方服务提供凭据。 如果我使用我的 google 帐户,我会从 Siteimprove API 收到 401 响应,因此这似乎可以按预期工作。
我将如何获得提示为第三方服务提供凭据的任何线索?
【问题讨论】:
-
我没有连接器配置页面? “编辑”菜单中没有“连接器”项。
-
是的,这正是我正在做的。这将显示这个window。当我点击“授权”时,我会从原来的帖子中弹出窗口。
-
你需要显示所有4个函数代码和清单文件。
-
在原帖中查看我的编辑
标签: google-apps-script google-data-studio