質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Redmine

Redmineは、プロジェクトのタスク管理、進捗管理、情報共有が可能な、 オープンソースプロジェクト管理ソフトウェアです。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

2回答

9616閲覧

Redmineのチケットを完了分も含めてCSV出力するJavaプログラムを作成したい

javabigineer

総合スコア87

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Redmine

Redmineは、プロジェクトのタスク管理、進捗管理、情報共有が可能な、 オープンソースプロジェクト管理ソフトウェアです。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

0クリップ

投稿2016/03/23 00:28

編集2016/03/23 01:31

Redmineのチケットをすべて取得するプログラムを作成しましたが、
ステータスが完了のチケットは出力されません。
ステータスが完了のチケットも含めて出力する方法はないでしょうか?

補足:使用しているAPIはtaskadapterです。

以下、現状のソースです。
import com.taskadapter.redmineapi.IssueManager;
import com.taskadapter.redmineapi.RedmineException;
import com.taskadapter.redmineapi.RedmineManager;
import com.taskadapter.redmineapi.RedmineManagerFactory;
import com.taskadapter.redmineapi.bean.CustomField;
import com.taskadapter.redmineapi.bean.Issue;
import com.taskadapter.redmineapi.bean.IssueFactory;
import com.taskadapter.redmineapi.bean.Project;
import com.taskadapter.redmineapi.bean.ProjectFactory;
import com.taskadapter.redmineapi.bean.Tracker;
import com.taskadapter.redmineapi.bean.TrackerFactory;
import com.taskadapter.redmineapi.bean.User;

public List<Issue> getAllIssues(String projectKey) throws RedmineException {
flgChk();

System.out.println("■■■チケットを全件取得します。■■■"); List<Issue> issues = issueMgr.getIssues(projectKey, null); // 第二引数はなくてもよい? System.out.println("チケットの件数 : " + issues.size()); issues.stream().forEach(is -> { System.out.println("【案件番号】" + is.getSubject()); }); return issues; } public Issue getOneIssue(String projectKey, String subject) throws RedmineException { flgChk(); System.out.println("■■■チケットを1件取得します。■■■"); List<Issue> issues = issueMgr.getIssues(projectKey, null); // 第二引数はなくてもよい? // チケットの探索(無かったらnull) Optional<Issue> is = issues.stream().filter(i ->(i.getSubject().equals(subject))).findAny(); if(is.isPresent()){ System.out.println("【題名】" + is.get().getSubject()); return is.get(); } System.out.println("チケットは取得できませんでした。" ); return null; } }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

A-pZ

2016/03/23 00:37

RedmineのAPIを利用するライブラリ(ないしはjarファイル)の情報があると、明確な答えがでるかと思います。
guest

回答2

0

まずはRedmineのAPIについてですが、GET /issues.xmlでオープンな状態のIssueを取得できます。クローズしたものも含めて取得したい場合はGET /issues.xml?status_id=*とする必要があります。
Rest Issues - Redmine

status_id: get issues with the given status id only. Possible values: open, closed, * to get open and closed issues, status id

おそらくはtaskadapter/redmine-java-api: Redmine Java APIを使用されているかと思われるのでこれ前提で。
Issueのリストを取得する場合、getIssues(Map<String, String> parameters)getIssues(String projectKey, Integer queryId, Include... include)を使用します。後者ではstatus_idを指定できなないので、getIssues(Map<String, String> parameters)project_idstatus_idをMapで渡してやることで取得できると思います。

投稿2016/03/23 01:29

sho_cs

総合スコア3541

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

方法としては2点あります。どれを選ぶか?は状況に応じて選ぶ感じです。

1.RedmineAdapterAPI(Java)側での呼び出し方を変える。

2.Redmine側でカスタムクエリを作成して、RedmineAdapaterAPI(Java)に渡す。
カスタムクエリの作成方法はざっくりと。
プロジェクト一覧→全てのチケットを表示→保存でプロジェクトをまたいだカスタムクエリとして保存されます。
プロジェクト一覧→全てのチケットを表示→保存でプロジェクト限定のカスタムクエリとして保存されます。

サンプルソースをのせておきます。
終了、却下でもIssueが取れることを確認済です。

java

1RedmineManager redmineManager = RedmineManagerFactory.createWithApiKey(uri, apiAccessKey); 2IssueManager issueManager = redmineManager.getIssueManager(); 3{ 4 // 呼び出し方法を変える場合。 5 Map<String, String> params = new HashMap<>(); 6 ProjectManager projectManager = redmineManager.getProjectManager(); 7 params.put("project_id", projectManager.getProjectByKey("sandbox").getId().toString()); 8 params.put("status_id", "*"); 9 List<Issue> issues = issueManager.getIssues(params); 10 for (Issue issue : issues) { 11 log.info(issue.getStatusName()); 12 } 13} 14{ 15 // 全てのチケットを表示で保存したカスタムクエリのIDが1の場合。 16 List<Issue> issues = issueManager.getIssues(null, 1); 17 for (Issue issue : issues) { 18 log.info(issue.getStatusName()); 19 } 20} 21{ 22 // プロジェクト選択→チケットで保存したカスタムクエリのIDが2の場合。 23 List<Issue> issues = issueManager.getIssues("sandbox", 2); 24 for (Issue issue : issues) { 25 log.info(issue.getStatusName()); 26 } 27}

動作確認環境

サーバー

Redmine 3.2.0 with sqlite
ruby-2.2.4-x64-mingw32

クライアント

JDK8 u73
eclipse mars2
com.taskadapter:redmine-java-api:2.6.0

参考資料

Redmine REST API
Redmine REST API(非公式日本語、若干古い)

投稿2016/03/23 01:40

umed0025

総合スコア851

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

javabigineer

2016/03/23 02:33

呼び出し方法を変える場合で試してみたところ、最新の25件しか取得できませんでした。全件取得はできないのでしょうか?
umed0025

2016/03/23 03:02 編集

デフォルトのlimit設定が25なので25件取れる感じになります。 とりあえずでよければ、以下のように設定を追加すれば1万件までとれます。 params.put("limit","10000"); 件数が多くて逐次処理を行うような形であれば、「total_count」「offset」「limit」の組み合わせで、分けて取得する感じになると思います。 「com.taskadapter.redmineapi.internal.Transport.getObjectsList(java.lang.Class<T>, java.util.Collection<? extends org.apache.http.NameValuePair>)」あたりが参考になるかと。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問