src/main/java/de/uapcore/lightpit/dao/IssueDao.java

Sat, 17 Oct 2020 19:56:50 +0200

author
Mike Becker <universe@uap-core.de>
date
Sat, 17 Oct 2020 19:56:50 +0200
changeset 134
f47e82cd6077
parent 128
947d0f6a6a83
child 150
822b7e3d064d
permissions
-rw-r--r--

completes feature: project components

38
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 *
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 * Copyright 2018 Mike Becker. All rights reserved.
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 *
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * Redistribution and use in source and binary forms, with or without
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 * modification, are permitted provided that the following conditions are met:
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 *
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * 1. Redistributions of source code must retain the above copyright
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 * notice, this list of conditions and the following disclaimer.
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 *
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * 2. Redistributions in binary form must reproduce the above copyright
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * notice, this list of conditions and the following disclaimer in the
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 * documentation and/or other materials provided with the distribution.
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 *
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 * POSSIBILITY OF SUCH DAMAGE.
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27 *
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28 */
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 package de.uapcore.lightpit.dao;
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30
134
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
31 import de.uapcore.lightpit.entities.*;
38
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32
59
c759c60507a2 adds version management
Mike Becker <universe@uap-core.de>
parents: 38
diff changeset
33 import java.sql.SQLException;
c759c60507a2 adds version management
Mike Becker <universe@uap-core.de>
parents: 38
diff changeset
34 import java.util.List;
c759c60507a2 adds version management
Mike Becker <universe@uap-core.de>
parents: 38
diff changeset
35
128
947d0f6a6a83 changes the way how to deal with child entities + adds component lead
Mike Becker <universe@uap-core.de>
parents: 124
diff changeset
36 public interface IssueDao extends ChildEntityDao<Issue, Project> {
75
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
37
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
38 /**
134
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
39 * Lists all issues that are related to the specified component and version.
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
40 * If component or version is null, search for issues that are not assigned to any
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
41 * component or version, respectively.
86
0a658e53177c improves issue overview and adds progress information
Mike Becker <universe@uap-core.de>
parents: 75
diff changeset
42 *
134
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
43 * @param project the project
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
44 * @param component the component or null
105
250c5cbb8276 simplifies issues per version view and re-adds edit version button
Mike Becker <universe@uap-core.de>
parents: 86
diff changeset
45 * @param version the version or null
86
0a658e53177c improves issue overview and adds progress information
Mike Becker <universe@uap-core.de>
parents: 75
diff changeset
46 * @return a list of issues
0a658e53177c improves issue overview and adds progress information
Mike Becker <universe@uap-core.de>
parents: 75
diff changeset
47 * @throws SQLException on any kind of SQL error
0a658e53177c improves issue overview and adds progress information
Mike Becker <universe@uap-core.de>
parents: 75
diff changeset
48 */
134
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
49 List<Issue> list(Project project, Component component, Version version) throws SQLException;
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
50
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
51 /**
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
52 * Lists all issues that are related to the specified version.
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
53 * If the version is null, lists issues that are not assigned to any version.
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
54 *
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
55 * @param project the project (mandatory)
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
56 * @param version the version or null
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
57 * @return a list of issues
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
58 * @throws SQLException on any kind of SQL error
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
59 */
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
60 List<Issue> list(Project project, Version version) throws SQLException;
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
61
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
62 /**
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
63 * Lists all issues that are related to the specified component.
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
64 * If the component is null, lists issues that are not assigned to a component.
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
65 *
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
66 * @param project the project (mandatory)
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
67 * @param component the component or null
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
68 * @return a list of issues
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
69 * @throws SQLException on any kind of SQL error
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
70 */
f47e82cd6077 completes feature: project components
Mike Becker <universe@uap-core.de>
parents: 128
diff changeset
71 List<Issue> list(Project project, Component component) throws SQLException;
86
0a658e53177c improves issue overview and adds progress information
Mike Becker <universe@uap-core.de>
parents: 75
diff changeset
72
0a658e53177c improves issue overview and adds progress information
Mike Becker <universe@uap-core.de>
parents: 75
diff changeset
73 /**
124
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
74 * Lists all comments for a specific issue in chronological order.
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
75 *
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
76 * @param issue the issue
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
77 * @return the list of comments
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
78 * @throws SQLException on any kind of SQL error
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
79 */
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
80 List<IssueComment> listComments(Issue issue) throws SQLException;
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
81
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
82 /**
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
83 * Stores the specified comment in database.
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
84 * This is an update-or-insert operation.
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
85 *
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
86 * @param comment the comment to save
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
87 * @throws SQLException on any kind of SQL error
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
88 */
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
89 void saveComment(IssueComment comment) throws SQLException;
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
90
ed2e7aef2a3e adds issue comments
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
91 /**
75
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
92 * Saves an instances to the database.
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
93 * Implementations of this DAO must guarantee that the generated ID is stored in the instance.
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
94 *
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
95 * @param instance the instance to insert
128
947d0f6a6a83 changes the way how to deal with child entities + adds component lead
Mike Becker <universe@uap-core.de>
parents: 124
diff changeset
96 * @param project the parent project
75
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
97 * @throws SQLException on any kind of SQL error
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
98 * @see Issue#setId(int)
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
99 */
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
100 @Override
128
947d0f6a6a83 changes the way how to deal with child entities + adds component lead
Mike Becker <universe@uap-core.de>
parents: 124
diff changeset
101 void save(Issue instance, Project project) throws SQLException;
75
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
102
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
103 /**
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
104 * Retrieves the affected, scheduled and resolved versions for the specified issue.
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
105 *
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
106 * @param issue the issue to join the information for
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
107 * @throws SQLException on any kind of SQL error
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
108 */
33b6843fdf8a adds the ability to create and edit issues
Mike Becker <universe@uap-core.de>
parents: 72
diff changeset
109 void joinVersionInformation(Issue issue) throws SQLException;
38
cf85ef18f231 adds DAO for Project entity and save/update methods
Mike Becker <universe@uap-core.de>
parents:
diff changeset
110 }

mercurial