#109 add assignee filter to rss feed

2021-11-27

author
Mike Becker <universe@uap-core.de>
date
Sat, 27 Nov 2021 10:44:17 +0100 (2021-11-27)
changeset 239
9365c7fb0240
parent 238
1d48b38ca349
child 240
7303812a4424

#109 add assignee filter to rss feed

setup/postgres/psql_create_tables.sql file | annotate | diff | comparison | revisions
src/main/kotlin/de/uapcore/lightpit/dao/DataAccessObject.kt file | annotate | diff | comparison | revisions
src/main/kotlin/de/uapcore/lightpit/dao/PostgresDataAccessObject.kt file | annotate | diff | comparison | revisions
src/main/kotlin/de/uapcore/lightpit/entities/IssueHistoryEntry.kt file | annotate | diff | comparison | revisions
src/main/kotlin/de/uapcore/lightpit/servlet/FeedServlet.kt file | annotate | diff | comparison | revisions
--- a/setup/postgres/psql_create_tables.sql	Sun Oct 10 15:12:12 2021 +0200
+++ b/setup/postgres/psql_create_tables.sql	Sat Nov 27 10:44:17 2021 +0100
@@ -118,16 +118,17 @@
 
 create table lpit_issue_history_data
 (
-    eventid     integer        not null references lpit_issue_history_event (eventid) on delete cascade,
-    component   text,
-    status      issue_status   not null,
-    category    issue_category not null,
-    subject     text           not null,
-    description text,
-    assignee    text,
-    eta         date,
-    affected    text,
-    resolved    text
+    eventid           integer        not null references lpit_issue_history_event (eventid) on delete cascade,
+    component         text,
+    status            issue_status   not null,
+    category          issue_category not null,
+    subject           text           not null,
+    description       text,
+    assignee_username text,
+    assignee          text,
+    eta               date,
+    affected          text,
+    resolved          text
 );
 
 create table lpit_issue_comment
--- a/src/main/kotlin/de/uapcore/lightpit/dao/DataAccessObject.kt	Sun Oct 10 15:12:12 2021 +0200
+++ b/src/main/kotlin/de/uapcore/lightpit/dao/DataAccessObject.kt	Sat Nov 27 10:44:17 2021 +0100
@@ -82,5 +82,8 @@
     fun insertHistoryEvent(issue: Issue, newId: Int = 0)
     fun insertHistoryEvent(issueComment: IssueComment, newId: Int = 0)
 
+    /**
+     * Lists the issue history of the project with [projectId] for the past [days].
+     */
     fun listIssueHistory(projectId: Int, days: Int): List<IssueHistoryEntry>
 }
--- a/src/main/kotlin/de/uapcore/lightpit/dao/PostgresDataAccessObject.kt	Sun Oct 10 15:12:12 2021 +0200
+++ b/src/main/kotlin/de/uapcore/lightpit/dao/PostgresDataAccessObject.kt	Sat Nov 27 10:44:17 2021 +0100
@@ -604,8 +604,8 @@
             }
         withStatement(
             """
-            insert into lpit_issue_history_data (component, status, category, subject, description, assignee, eta, affected, resolved, eventid)
-            values (?, ?::issue_status, ?::issue_category, ?, ?, ?, ?, ?, ?, ?)
+            insert into lpit_issue_history_data (component, status, category, subject, description, assignee, assignee_username, eta, affected, resolved, eventid)
+            values (?, ?::issue_status, ?::issue_category, ?, ?, ?, ?, ?, ?, ?, ?)
             """.trimIndent()
         ) {
             setStringOrNull(1, issue.component?.name)
@@ -614,10 +614,11 @@
             setString(4, issue.subject)
             setStringOrNull(5, issue.description)
             setStringOrNull(6, issue.assignee?.shortDisplayname)
-            setDateOrNull(7, issue.eta)
-            setStringOrNull(8, issue.affected?.name)
-            setStringOrNull(9, issue.resolved?.name)
-            setInt(10, eventid)
+            setStringOrNull(7, issue.assignee?.username)
+            setDateOrNull(8, issue.eta)
+            setStringOrNull(9, issue.affected?.name)
+            setStringOrNull(10, issue.resolved?.name)
+            setInt(11, eventid)
             executeUpdate()
         }
     }
@@ -725,6 +726,7 @@
                             subject = getString("subject"),
                             description = getString("description") ?: "",
                             assignee = getString("assignee") ?: "",
+                            assigneeUsername = getString("assignee_username") ?: "",
                             eta = getDate("eta"),
                             affected = getString("affected") ?: "",
                             resolved = getString("resolved") ?: ""
--- a/src/main/kotlin/de/uapcore/lightpit/entities/IssueHistoryEntry.kt	Sun Oct 10 15:12:12 2021 +0200
+++ b/src/main/kotlin/de/uapcore/lightpit/entities/IssueHistoryEntry.kt	Sat Nov 27 10:44:17 2021 +0100
@@ -39,6 +39,7 @@
     val subject: String,
     val description: String,
     val assignee: String,
+    val assigneeUsername: String,
     val eta: Date?,
     val affected: String,
     val resolved: String,
--- a/src/main/kotlin/de/uapcore/lightpit/servlet/FeedServlet.kt	Sun Oct 10 15:12:12 2021 +0200
+++ b/src/main/kotlin/de/uapcore/lightpit/servlet/FeedServlet.kt	Sat Nov 27 10:44:17 2021 +0100
@@ -125,10 +125,14 @@
             http.response.sendError(404)
             return
         }
+        val assignees = http.param("assignee")?.split(',')
 
         val days = http.param("days")?.toIntOrNull() ?: 30
 
-        val issueHistory = dao.listIssueHistory(project.id, days)
+        val issuesFromDb = dao.listIssueHistory(project.id, days)
+        val issueHistory = if (assignees == null) issuesFromDb else
+            issuesFromDb.filter { assignees.contains(it.data.assigneeUsername) }
+
         // TODO: add comment history depending on parameter
 
         http.view = IssueFeed(project, generateFeedEntries(issueHistory))

mercurial