我(在此开始)开发一个宏插件,它基于现有插件通过其REST API提供的数据。它们将在Confluence的同一个实例上运行,版本为5.9。
我不能使用插件的Java API,因为它只提供对非常有限数量的类的访问,所以我决定使用Rest。
鉴于用户已经使用Confluence进行了身份验证,有没有办法将我当前的用户凭据从我的插件Java Rest客户端传递给另一个,最好不使用基本身份验证?
到目前为止,我已经尝试过了:
共享访问层 - 这显然用于处理方法Request#addTrustedTokenAuthentication()
,但在SAL 3.0.5中已弃用,
请参阅SAL Documentation (outdated?)和SAL Version Matrix
ApplicationLink - 允许我链接到另一个应用程序,但显然无法链接回同一个Confluence实例
SAL TrustedRequestFactory
- 对此atlassian answer的评论表明可能有一种方法可以使用此方法,但我似乎无法弄清楚(还)。
我也尝试阅读atlassian文档并在atlassian答案here上发布了类似的问题。我并不意味着双重发帖,但不幸的是,在该平台上查看其他问题,很少有人及时得到答复,所以我想我在这里试试运气。
答案 0 :(得分:2)
似乎这不是一个非常常见的问题,但我想我会发布我们最终如何解决这个问题,以防它再次需要:
@Component
public class RestClient {
@ComponentImport
private TrustedTokenFactory tokenFactory;
// [...]
public String doRequest(HttpClient client, String url) throws Exception {
TrustedTokenAuthenticator auth =
new TrustedTokenAuthenticator(tokenFactory);
HttpMethod method = auth.makeMethod(client, url);
try {
// add request headers, etc...
int statusCode = client.executeMethod(method);
// be sure to use response data here, catch exceptions...
} finally {
method.releaseConnection();
}
}
}