java - 搜索请求 View 插件实现类

标签 java eclipse jira jira-plugin

我已将请求更新为当前状态。
我只留下了 1 个错误,而且我不知道如何解决它。
首先这是我的代码:

package com.example.plugins.tutorial;

import com.atlassian.jira.issue.Issue;
import com.atlassian.jira.issue.IssueFactory;
import com.atlassian.jira.issue.search.SearchException;
import com.atlassian.jira.issue.search.SearchProviderFactory;
import com.atlassian.jira.issue.search.SearchRequest;
import com.atlassian.jira.issue.views.util.IssueWriterHitCollector;
import com.atlassian.jira.plugin.searchrequestview.AbstractSearchRequestView;
import com.atlassian.jira.plugin.searchrequestview.SearchRequestParams;
import com.atlassian.jira.security.JiraAuthenticationContext;
import com.atlassian.jira.util.JiraVelocityUtils;
import com.atlassian.sal.api.search.SearchProvider;
import com.atlassian.jira.issue.search.providers.LuceneSearchProvider;

import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Collector;

import java.io.IOException;
import java.io.Writer;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;


public class TestSearch extends AbstractSearchRequestView
{
    private final JiraAuthenticationContext authenticationContext;
    private final SearchProviderFactory searchProviderFactory;
    private final IssueFactory issueFactory;
    private final SearchProvider searchProvider;

    public TestSearch(JiraAuthenticationContext authenticationContext, SearchProviderFactory searchProviderFactory,
        IssueFactory issueFactory, SearchProvider searchProvider)
{
    this.authenticationContext = authenticationContext;
    this.searchProviderFactory = searchProviderFactory;
    this.issueFactory = issueFactory;
    this.searchProvider = searchProvider;
}

public void writeSearchResults(final SearchRequest searchRequest, final SearchRequestParams searchRequestParams, final Writer writer)
{
    final Map defaultParams = JiraVelocityUtils.getDefaultVelocityParams(authenticationContext);

    //Need to put the filtername into the velocity context.  This may be null if this is an anoymous filter.
    final Map headerParams = new HashMap(defaultParams);
    headerParams.put("filtername", searchRequest.getName());
    try
    {
        //First we need to write the header
        writer.write(descriptor.getHtml("header", headerParams));

        //now lets write the search results.  This basically iterates over each issue in the search results and writes
        //it to the writer using the format defined by this plugin.  To ensure that this doesn't result in huge
        //memory consumption only one issue should be loaded into memory at a time.  This can be guaranteed by using a
        //Hitcollector.
        final IndexSearcher searcher = searchProviderFactory.getSearcher(SearchProviderFactory.ISSUE_INDEX);
        final Map issueParams = new HashMap(defaultParams);
        //This hit collector is responsible for writing out each issue as it is encountered in the search results.
        //It will be called for each search result by the underlying Lucene search code.
        final Collector hitCollector = new IssueWriterHitCollector(searcher, writer, issueFactory)
        {
            protected void writeIssue(Issue issue, Writer writer) throws IOException
            {
                //put the current issue into the velocity context and render the single issue view
                issueParams.put("issue", issue);
                writer.write(descriptor.getHtml("singleissue", issueParams));
            }
        };
        //now run the search that's defined in the issue navigator and pass in the hitcollector from above which will
        //write out each issue in the format specified in this plugin.
        searchProvider.searchAndSort(searchRequest.getQuery(), authenticationContext.getLoggedInUser(), hitCollector, searchRequestParams.getPagerFilter());

        //finally lets write the footer.
        writer.write(descriptor.getHtml("footer", Collections.emptyMap()));
    }
    catch (IOException e)
    {
        throw new RuntimeException(e);
    }
    catch (SearchException e)
    {
        throw new RuntimeException(e);
    }
}
}

我的问题是 searchAndSort 不起作用

searchProvider.searchAndSort(searchRequest.getQuery(), authenticationContext.getLoggedInUser(), hitCollector, searchRequestParams.getPagerFilter());

Eclipse 向我显示错误“The method searchAndSort is undefined for the Type SearchProvider”。

相同的问题和具有相同错误的第二个示例:

@Override
public void writeSearchResults(final SearchRequest searchRequest,final SearchRequestParams searchRequestParams,final Writer writer) throws SearchException 
{
    final Map defaultParams = JiraVelocityUtils.getDefaultVelocityParams(authenticationContext);
    final Map headerParams = new HashMap(defaultParams);
    headerParams.put("filtername", searchRequest.getName());
    headerParams.put("user", authenticationContext.getLoggedInUser());
    try 
    {
        //Header
        writer.write(descriptor.getHtml("header", headerParams));
        //Body
        final IndexSearcher searcher = searchProviderFactory.getSearcher(SearchProviderFactory.ISSUE_INDEX);        
        final Map issueParams = new HashMap(defaultParams);
        final Collector hitCollector = new IssueWriterHitCollector(searcher, writer, issueFactory) 
        {
            protected void writeIssue(Issue issue, Writer writer) throws IOException 
            {
                //put the current issue into the velocity context and render the single issue view
                issueParams.put("issue", issue);
                writer.write(descriptor.getHtml("body", issueParams));
            }
        };
        searchProvider.searchAndSort(searchRequest.getQuery(), authenticationContext.getLoggedInUser(), hitCollector, searchRequestParams.getPagerFilter());
        //Footer
        writer.write(descriptor.getHtml("footer", MapBuilder.build("user", authenticationContext.getLoggedInUser())));
    }
    catch (IOException e) 
    {
        throw new RuntimeException(e);
    }
    catch (SearchException e) 
    {
        throw new RuntimeException(e);
    }
}

与 searchAndSort 相同的问题...

如果有人能提供帮助,那就太好了。

最佳答案

我已经解决了这个问题,我导入了错误的 SearchProvider,现在它可以工作了。 对于其他有同样问题并想要创建一个搜索请求 View 插件并以 html 形式返回问题的人,您可以使用我的代码:

package com.example.plugins.tutorial;

import com.atlassian.jira.util.collect.MapBuilder;
import com.atlassian.jira.issue.Issue;
import com.atlassian.jira.issue.IssueFactory;
import com.atlassian.jira.issue.search.SearchException;
import com.atlassian.jira.issue.search.SearchProviderFactory;
import com.atlassian.jira.issue.search.SearchRequest;
import com.atlassian.jira.issue.views.util.IssueWriterHitCollector;
import com.atlassian.jira.plugin.searchrequestview.AbstractSearchRequestView;
import com.atlassian.jira.plugin.searchrequestview.SearchRequestParams;
import com.atlassian.jira.security.JiraAuthenticationContext;
import com.atlassian.jira.util.JiraVelocityUtils;
import com.atlassian.jira.issue.search.SearchProvider;

import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Collector;

import java.io.IOException;
import java.io.Writer;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

public class NextTestSearch extends AbstractSearchRequestView {

private final JiraAuthenticationContext authenticationContext;
private final SearchProviderFactory searchProviderFactory;
private final IssueFactory issueFactory;
private final SearchProvider searchProvider;

public NextTestSearch(JiraAuthenticationContext authenticationContext, SearchProviderFactory searchProviderFactory,
        IssueFactory issueFactory, SearchProvider searchProvider)
{
    this.authenticationContext = authenticationContext;
    this.searchProviderFactory = searchProviderFactory;
    this.issueFactory = issueFactory;
    this.searchProvider = searchProvider;
}

@Override
public void writeSearchResults(final SearchRequest searchRequest,final SearchRequestParams searchRequestParams,final Writer writer) throws SearchException 
{
    final Map defaultParams = JiraVelocityUtils.getDefaultVelocityParams(authenticationContext);
    final Map headerParams = new HashMap(defaultParams);
    headerParams.put("filtername", searchRequest.getName());
    headerParams.put("user", authenticationContext.getLoggedInUser());
    try 
    {
        //Header
        writer.write(descriptor.getHtml("header", headerParams));
        //Body
        final IndexSearcher searcher = searchProviderFactory.getSearcher(SearchProviderFactory.ISSUE_INDEX);        
        final Map issueParams = new HashMap(defaultParams);
        final Collector hitCollector = new IssueWriterHitCollector(searcher, writer, issueFactory) 
        {
            protected void writeIssue(Issue issue, Writer writer) throws IOException 
            {
                //put the current issue into the velocity context and render the single issue view
                issueParams.put("issue", issue);
                writer.write(descriptor.getHtml("body", issueParams));
            }
        };
        searchProvider.searchAndSort(searchRequest.getQuery(), authenticationContext.getLoggedInUser(), hitCollector, searchRequestParams.getPagerFilter());
        //Footer
        writer.write(descriptor.getHtml("footer", MapBuilder.build("user", authenticationContext.getLoggedInUser())));
    }
    catch (IOException e) 
    {
        throw new RuntimeException(e);
    }
    catch (SearchException e) 
    {
        throw new RuntimeException(e);
    }
}
}

该插件所需的其余部分应该可以使用 Officele 教程 This is the Link有教程,但 java 源代码已弃用。

关于java - 搜索请求 View 插件实现类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33628598/

相关文章:

java - Ant - 带通配符的 Pathelement 仅适用于 Javac fork 模式

java - iBatis SqlMapClient 和线程安全

java - 单元测试多线程API

Java Stream Api - 在 Map<String, Double> 上操作的好方法?

rest - 从 REST API 获取 Jira 问题的分支

centos - Jira 服务器迁移恢复附件

java - Servlet Listners 和加载外部 Jars 性能

适用于 Eclipse 的安卓 Nexus 7 DPI

java - 找不到带有 ADT 插件的 Eclipse 的 Android SDK

tomcat - 没有任何内容写入日志文件(atlassian jira)