Skip to content

Commit

Permalink
Fixes #3470: adds possibility to pass query manager to AnalysisServic…
Browse files Browse the repository at this point in the history
…e to avoid "Object with id 'x' is managed by a different persistence manager" error types

Signed-off-by: Sebastien Delcoigne <[email protected]>
  • Loading branch information
sebD committed Apr 7, 2024
1 parent fcf7c6c commit 5dffd9f
Show file tree
Hide file tree
Showing 5 changed files with 24 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
* limitations under the License.
*
* SPDX-License-Identifier: Apache-2.0
* Copyright (c) Steve Springett. All Rights Reserved.
* Copyright (c) OWASP Foundation. All Rights Reserved.
*/
package org.dependencytrack.exception;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ public void applyVex(final QueryManager qm, final Bom bom, final Project project
continue;
}

try (AnalysisService analysisService = new AnalysisService()) {
try (AnalysisService analysisService = new AnalysisService(qm)) {
for (org.cyclonedx.model.vulnerability.Vulnerability.Affect affect : vexVuln.getAffects()) {
final ObjectLocator ol = new ObjectLocator(bom, affect.getRef()).locate();
if ((ol.found() && ol.isMetadataComponent()) || (!ol.found() && BomLink.isBomLink(affect.getRef()))) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
* limitations under the License.
*
* SPDX-License-Identifier: Apache-2.0
* Copyright (c) Steve Springett. All Rights Reserved.
* Copyright (c) OWASP Foundation. All Rights Reserved.
*/
package org.dependencytrack.services;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
* limitations under the License.
*
* SPDX-License-Identifier: Apache-2.0
* Copyright (c) Steve Springett. All Rights Reserved.
* Copyright (c) OWASP Foundation. All Rights Reserved.
*/
package org.dependencytrack.services;

Expand Down
27 changes: 20 additions & 7 deletions src/main/java/org/dependencytrack/services/AnalysisService.java
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
* limitations under the License.
*
* SPDX-License-Identifier: Apache-2.0
* Copyright (c) Steve Springett. All Rights Reserved.
* Copyright (c) OWASP Foundation. All Rights Reserved.
*/
package org.dependencytrack.services;

Expand All @@ -40,11 +40,20 @@
public class AnalysisService implements AutoCloseable {

private final QueryManager qm;
private final boolean hasBorrowedQueryManager;

public AnalysisService() {
hasBorrowedQueryManager = false;
this.qm = new QueryManager();
}

public AnalysisService(QueryManager queryManager) {
hasBorrowedQueryManager = true;
this.qm = queryManager;
}



/**
* Retrieves an analysis from the database
*
Expand Down Expand Up @@ -159,11 +168,13 @@ public Analysis updateAnalysis(AnalysisDescription analysisDescription, Componen
analysisStateChange = true; // this is a new analysis - so set to true because it was previously null
makeFirstStateComment(qm, analysis, commenter);
makeFirstJustificationComment(qm, analysis, commenter);
for (int i=0; i<analysisDescription.getAnalysisResponses().size(); i++) {
if (i == 0) {
makeFirstAnalysisResponseComment(qm, analysis, analysisDescription.getAnalysisResponses().get(i), commenter);
} else {
makeAnalysisResponseComment(qm, analysis, analysisDescription.getAnalysisResponses().get(i), commenter);
if (analysisDescription.getAnalysisResponses() != null) {
for (int i = 0; i < analysisDescription.getAnalysisResponses().size(); i++) {
if (i == 0) {
makeFirstAnalysisResponseComment(qm, analysis, analysisDescription.getAnalysisResponses().get(i), commenter);
} else {
makeAnalysisResponseComment(qm, analysis, analysisDescription.getAnalysisResponses().get(i), commenter);
}
}
}
makeFirstDetailsComment(qm, analysis, commenter);
Expand Down Expand Up @@ -267,6 +278,8 @@ private boolean makeAnalysisSuppressionComment(final QueryManager qm, final Anal

@Override
public void close() {
this.qm.close();
if (!hasBorrowedQueryManager) {
this.qm.close();
}
}
}

0 comments on commit 5dffd9f

Please sign in to comment.