合并REST API请求而不是管理员以401错误结束

时间:2015-12-22 11:05:11

标签: javascript ajax jira confluence confluence-rest-api

我正在开发汇流蓝图,用户可以在jira项目中进行选择,并将其用于特定的jira问题报告。

两个实例彼此正确连接,我得到结果,但前提是我以管理员身份登录。与普通用户我得到这个:

<status>
   <status-code>401</status-code>
   <message>This resource requires WebSudo.</message>
</status>

不幸的是,我必须使用javascript从jira服务器获取信息作为ajax post请求,这是我的代码:

function pickDate(e, state) {
    AJS.$('#spLebenStart').datePicker({
        overrideBrowserDefault: true
    });

    getJiraUrl();
}

function getJiraUrl(){
    var appUrl = AJS.contextPath() + "/rest/applinks/1.0/applicationlink/type/jira";

    $.ajax({
        type: 'GET',
        url: appUrl,
        data: {
            key: "value"
        }, 
        dataType: "xml",
        success: function (xml){
            jiraID = $(xml).find("id").text();
        },
        complete: function(){
            getJiraProjects(jiraID);
        },
        error: function() {
            alert("ERROR @ getJiraUrl");
        }
    });
}

function getJiraProjects(applicationId){
    var restUrl = AJS.contextPath() + "/rest/applinks/1.0/entities/"+applicationId+"?os_authType=any";

    $.ajax({
        type: 'GET',
        url: restUrl,
        data: {
            key: "value"
        },
        dataType: "xml",
        success: function (xml){
            jiraProjectKeys = [];
            $(xml).find("entity").each(function(){
                jiraProjectKeys.push({id: $(this).attr("key"), text: $(this).attr("name")});
            });
        },
        crossDomain: true,
        xhrFields: {
            withCredentials: true
        },
        error: function() {
            alert("ERROR @ getJiraProjects");
        },
        complete: function(){
            AJS.$('#spSelect').auiSelect2({
                placeholder: 'Projekt auswählen...',
                data:jiraProjectKeys,
                multiple: false
            });
        }
    });
}

我试图在ajax中使用基本身份验证的登录信息,但它没有帮助。当然我可以在代码中硬编码id,但如果它被改变了怎么办?它不是最好的解决方案。我怎样才能管理网络问题?

谢谢你,祝你圣诞快乐,新年快乐。

1 个答案:

答案 0 :(得分:1)

我是新来的(作为贡献者)所以请原谅我的新手。

看起来访问/rest/applinks/1.0/applicationlink/type/jira确实需要管理员权限。但是有一个未记录的(AFAIK)解决方法,这就是我的工作方式。

有一个名为Confluence JIRA Plugin的Atlassian插件。它与Confluence捆绑在一起(因此它应该在您的安装中可用)。它为您提供了一些允许JIRA集成的很酷的功能(例如JIRA和JIRA Chart宏)。为了提供集成,它还为Confluence REST API添加了一些有用的端点(不需要管理员访问权限):

  1. /rest/jiraanywhere/1.0/servers/rest/jira-integration/1.0/servers列出已关联的JIRA服务器(包含applink ID)
  2. /jira-integration/1.0/servers/{INSERT APPLINK ID HERE}/projects列出登录用户可用的JIRA项目
  3. 现在,根据您的要求,我点击1.获取applink ID然后2.获取项目列表。希望它适用于您的产品版本。

    BONUS - JIRA代理

    另一个不错的终点是/plugins/servlet/applinks/proxy。它允许将简单的REST请求转发到链接的JIRA实例。例如,/plugins/servlet/applinks/proxy?appId={INSERT APPLINK ID HERE}&path=%2Frest%2Fapi%2F2%2Fsearch将调用JIRA的issue search REST endpoint并列出用户可用的问题(如在JIRA搜索中)。 “简单请求”是指当前版本仅支持GET和POST HTTP方法(POST限于application/xmlmultipart/form-data内容类型)。 servlet支持query-string和HTTP-header参数。查看plugin's source中servlet的来源以获取更多信息,因为我还没有找到任何在线文档。

    使用此servlet,您也可以通过请求/plugins/servlet/applinks/proxy?appId={INSERT APPLINK ID HERE}&path=%2Frest%2Fapi%2F2%2Fproject

    来获取项目列表

    回购邮件中的Servlets路径为confluence-jira-plugin/src/main/java/com/atlassian/confluence/plugins/jira/AppLinksProxyRequestServlet.java,但大部分重要内容都在其基类confluence-jira-plugin/src/main/java/com/atlassian/confluence/plugins/jira/AbstractProxyServlet.java