19package org.sleuthkit.autopsy.datasourcesummary.datamodel;
21import java.util.ArrayList;
22import java.util.Arrays;
23import java.util.Collection;
24import java.util.Collections;
25import java.util.HashSet;
28import java.util.stream.Collectors;
29import java.util.stream.Stream;
30import org.apache.commons.lang3.tuple.Pair;
31import org.sleuthkit.autopsy.casemodule.NoCurrentCaseException;
32import org.sleuthkit.autopsy.centralrepository.ingestmodule.CentralRepoIngestModuleFactory;
33import org.sleuthkit.autopsy.datasourcesummary.datamodel.SleuthkitCaseProvider.SleuthkitCaseProviderException;
34import org.sleuthkit.datamodel.Blackboard;
35import org.sleuthkit.datamodel.BlackboardArtifact;
36import org.sleuthkit.datamodel.BlackboardArtifact.ARTIFACT_TYPE;
37import org.sleuthkit.datamodel.BlackboardAttribute;
38import org.sleuthkit.datamodel.Content;
39import org.sleuthkit.datamodel.DataSource;
40import org.sleuthkit.datamodel.SleuthkitCase;
41import org.sleuthkit.datamodel.TskCoreException;
112 ARTIFACT_TYPE.TSK_PREVIOUSLY_SEEN.getTypeID(),
113 ARTIFACT_TYPE.TSK_PREVIOUSLY_NOTABLE.getTypeID()
119 ARTIFACT_TYPE.TSK_DEVICE_ATTACHED.getTypeID(),
120 ARTIFACT_TYPE.TSK_DEVICE_INFO.getTypeID(),
121 ARTIFACT_TYPE.TSK_SIM_ATTACHED.getTypeID(),
122 ARTIFACT_TYPE.TSK_WIFI_NETWORK_ADAPTER.getTypeID()
128 private final java.util.logging.Logger
logger;
136 org.sleuthkit.autopsy.coreutils.Logger.getLogger(
PastCasesSummary.class.getName())
151 java.util.logging.Logger
logger) {
153 this.caseProvider = provider;
167 if (sources ==
null) {
171 return sources.stream().anyMatch((str) -> {
185 if (artifact ==
null) {
186 return Collections.emptyList();
189 BlackboardAttribute commentAttr =
null;
191 commentAttr = artifact.getAttribute(BlackboardAttribute.Type.TSK_OTHER_CASES);
192 }
catch (TskCoreException ignored) {
209 if (commentAttr ==
null) {
210 return Collections.emptyList();
214 return Collections.emptyList();
217 String justCasesStr = commentAttr.getValueString().trim();
220 .collect(Collectors.toList());
233 private static List<Pair<String, Long>>
getCaseCounts(Stream<String> cases) {
234 Collection<List<String>> groupedCases = cases
236 .collect(Collectors.groupingBy((caseStr) -> caseStr.toUpperCase().trim()))
242 .filter((lst) -> lst !=
null && lst.size() > 0)
244 .map((lst) -> Pair.of(lst.get(0), (
long) lst.size()))
246 .sorted((a, b) -> -Long.compare(a.getValue(), b.getValue()))
247 .collect(Collectors.toList());
259 List<String> cases =
new ArrayList<>();
260 for (BlackboardArtifact art : artifacts) {
280 BlackboardArtifact sourceArtifact =
null;
282 Content content = skCase.getContentById(artifact.getObjectID());
283 if (content instanceof BlackboardArtifact) {
284 sourceArtifact = (BlackboardArtifact) content;
286 return sourceArtifact;
301 if (parent ==
null) {
322 if (dataSource ==
null) {
326 long dataSourceId = dataSource.getId();
328 Blackboard blackboard =
caseProvider.get().getBlackboard();
330 List<BlackboardArtifact> previouslyNotableArtifacts
331 = blackboard.getArtifacts(BlackboardArtifact.Type.TSK_PREVIOUSLY_NOTABLE.getTypeID(), dataSourceId);
333 List<BlackboardArtifact> previouslySeenArtifacts
334 = blackboard.getArtifacts(BlackboardArtifact.Type.TSK_PREVIOUSLY_SEEN.getTypeID(), dataSourceId);
336 List<BlackboardArtifact> previouslySeenDevice =
new ArrayList<>();
337 List<BlackboardArtifact> previouslySeenNoDevice =
new ArrayList<>();
339 for (BlackboardArtifact art : previouslySeenArtifacts) {
341 previouslySeenDevice.add(art);
343 previouslySeenNoDevice.add(art);
static String getModuleName()
List< Pair< String, Long > > getPreviouslyNotable()
PastCasesResult(List< Pair< String, Long > > previouslyNotable, List< Pair< String, Long > > previouslySeenDevices, List< Pair< String, Long > > previouslySeenResults)
final List< Pair< String, Long > > previouslySeenResults
List< Pair< String, Long > > getPreviouslySeenResults()
final List< Pair< String, Long > > previouslySeenDevices
final List< Pair< String, Long > > previouslyNotable
List< Pair< String, Long > > getPreviouslySeenDevices()
final SleuthkitCaseProvider caseProvider
static List< String > getCasesFromAttr(BlackboardAttribute commentAttr)
static final String CASE_SEPARATOR
boolean hasDeviceAssociatedArtifact(BlackboardArtifact artifact)
static final Set< Integer > CR_DEVICE_TYPE_IDS
static final Set< Integer > ARTIFACT_UPDATE_TYPE_IDS
final java.util.logging.Logger logger
static List< String > getCasesFromArtifact(BlackboardArtifact artifact)
static boolean isCentralRepoGenerated(List< String > sources)
static List< Pair< String, Long > > getCaseCounts(Stream< String > cases)
static final String CENTRAL_REPO_INGEST_NAME
BlackboardArtifact getParentArtifact(BlackboardArtifact artifact)
PastCasesSummary(SleuthkitCaseProvider provider, java.util.logging.Logger logger)
static List< Pair< String, Long > > getCaseCountsFromArtifacts(List< BlackboardArtifact > artifacts)
PastCasesResult getPastCasesData(DataSource dataSource)
SleuthkitCaseProvider DEFAULT