Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Story/cite 177: There needs to be an import from Crossref #271

Open
wants to merge 22 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
2b1ce80
[CITE-177] setup and created service to query crossref
jdamerow Jun 20, 2022
557f26f
[CITE-177] front end and backend changes to start crossref import
jdamerow Jul 6, 2022
dacc76f
[CITE-177] Clearing the div before fetching the results
PratikGiri Mar 7, 2023
709aa15
[CITE-177] Added group ID to Kafka message
PradnyaC11 Apr 26, 2024
4791750
[CITE-177] Updated JobInfoController to add groupId to response
PradnyaC11 Apr 30, 2024
0e74de6
[CITE-177] Added test cases for ImportCrossrefJobManager & ImportCros…
PradnyaC11 Jun 12, 2024
90e71d2
Merge branch 'develop' into story/CITE-177
PradnyaC11 Jun 13, 2024
8faa45c
[CITE-177] Updated crossref.html to show alert
PradnyaC11 Jun 13, 2024
8b219a6
Merge branch 'story/CITE-177' of https://github.com/diging/citesphere…
PradnyaC11 Jun 13, 2024
836705d
[CITE-177] Addressing the PR comments
PradnyaC11 Jul 2, 2024
5495a62
[CITE-177] Changed crossref-connect-version in pom.xml
PradnyaC11 Jul 2, 2024
d9ad221
[CITE-177] Addressed PR comments
PradnyaC11 Jul 11, 2024
3fffd0e
[CITE-177] Addressing PR comments
PradnyaC11 Aug 1, 2024
7324581
[CITE-177] Addressing PR comments
PradnyaC11 Aug 2, 2024
fc238b9
[CITE-177] Addressed PR comments
PradnyaC11 Sep 6, 2024
4c7f0d9
[CITE-177] Corrected indentation for crossref.html
PradnyaC11 Sep 6, 2024
4c8c5ac
Merge branch 'story/CITE-177' of https://github.com/diging/citesphere…
PradnyaC11 Sep 6, 2024
ba4a409
[CITE-177] Addressed PR comments
PradnyaC11 Sep 20, 2024
baf03ad
[CITE-177] Addressing PR comments
PradnyaC11 Oct 25, 2024
9afba45
[CITE-177] Addressed PR comments
PradnyaC11 Oct 28, 2024
476f31c
Merge branch 'develop' into story/CITE-177
PradnyaC11 Dec 9, 2024
00c7a7c
[CITE-177] Addressed PR comments
PradnyaC11 Jan 14, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 8 additions & 1 deletion citesphere/pom.xml
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
Expand All @@ -24,8 +24,10 @@
<javers.version>6.2.3</javers.version>
<spring.kafka.version>2.2.6.RELEASE</spring.kafka.version>
<spring-social-zotero.version>0.12</spring-social-zotero.version>
<citesphere.messages.version>0.4</citesphere.messages.version>

<citesphere.messages.version>0.5</citesphere.messages.version>
<citesphere.model.version>1.23</citesphere.model.version>
<crossref-connect-version>0.2</crossref-connect-version>

<admin.password>$2a$04$oQo44vqcDIFRoYKiAXoNheurzkwX9dcNmowvTX/hsWuBMwijqn44i</admin.password>

Expand Down Expand Up @@ -157,6 +159,11 @@
<artifactId>citesphere-model</artifactId>
<version>${citesphere.model.version}</version>
</dependency>
<dependency>
<groupId>edu.asu.diging</groupId>
<artifactId>crossref-connect</artifactId>
<version>${crossref-connect-version}</version>
</dependency>

<!-- Spring -->
<dependency>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
package edu.asu.diging.citesphere.api.v1.user;

import java.util.HashMap;
import java.util.Map;
import java.util.function.BiConsumer;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
Expand All @@ -8,15 +14,21 @@
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RequestMapping;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ArrayNode;
import com.fasterxml.jackson.databind.node.ObjectNode;

import edu.asu.diging.citesphere.core.export.IExportTaskManager;
import edu.asu.diging.citesphere.core.model.IZoteroToken;
import edu.asu.diging.citesphere.core.model.export.IExportTask;
import edu.asu.diging.citesphere.core.model.jobs.IExportJob;
import edu.asu.diging.citesphere.core.model.jobs.IImportCrossrefJob;
import edu.asu.diging.citesphere.core.model.jobs.IJob;
import edu.asu.diging.citesphere.core.model.jobs.IUploadJob;
import edu.asu.diging.citesphere.core.model.jobs.impl.ExportJob;
import edu.asu.diging.citesphere.core.model.jobs.impl.ImportCrossrefJob;
import edu.asu.diging.citesphere.core.model.jobs.impl.UploadJob;
import edu.asu.diging.citesphere.core.service.jobs.IUploadJobManager;
import edu.asu.diging.citesphere.core.service.jwt.IJobApiTokenContents;
import edu.asu.diging.citesphere.core.user.IUserManager;
Expand All @@ -25,6 +37,8 @@
@Controller
public class JobInfoController extends BaseJobInfoController {

private final Logger logger = LoggerFactory.getLogger(getClass());

@Autowired
private IUserManager userManager;

Expand All @@ -35,11 +49,19 @@ public class JobInfoController extends BaseJobInfoController {
private IUploadJobManager jobManager;

@Autowired
private IExportTaskManager exportTaskManager;
private IExportTaskManager exportTaskManager;

private Map<Class<?>, BiConsumer<ObjectNode, Object>> jobHandlers = new HashMap<>();

public JobInfoController() {
// Map each job class to its respective handling method
jobHandlers.put(UploadJob.class, (node, job) -> handleUploadJob(node, (IUploadJob) job));
jobHandlers.put(ExportJob.class, (node, job) -> handleExportJob(node, (IExportJob) job));
jobHandlers.put(ImportCrossrefJob.class, (node, job) -> handleImportCrossrefJob(node, (IImportCrossrefJob) job));
}

@RequestMapping(value="/job/info")
public ResponseEntity<String> getProfile(@RequestHeader HttpHeaders headers) {
public ResponseEntity<String> getProfile(@RequestHeader HttpHeaders headers) throws JsonProcessingException {
ResponseEntity<String> entity = checkForToken(headers);
if (entity != null) {
return entity;
Expand All @@ -53,25 +75,40 @@ public ResponseEntity<String> getProfile(@RequestHeader HttpHeaders headers) {

IJob job = jobManager.findJob(tokenContents.getJobId());
IZoteroToken zoteroToken = tokenManager.getToken(userManager.findByUsername(job.getUsername()));

ObjectMapper mapper = new ObjectMapper();
ObjectNode node = mapper.createObjectNode();
node.put("zotero", zoteroToken.getToken());
node.put("zoteroId", zoteroToken.getUserId());
node.put("username", job.getUsername());
// FIXME: ugly, needs better solution
if (job instanceof IUploadJob) {
node.put("groupId", ((IUploadJob)job).getCitationGroup());
}
if (job instanceof IExportJob) {
IExportTask exportTask = exportTaskManager.get(((IExportJob)job).getTaskId());
node.put("groupId", exportTask.getGroupId());
node.put("collectionId", exportTask.getCollectionId());
node.put("exportType", exportTask.getExportType().name());
node.put("taskId", exportTask.getId());
BiConsumer<ObjectNode, Object> handler = jobHandlers.get(job.getClass());
if (handler != null) {
handler.accept(node, job);
} else {
logger.error("No handler found for job type: " + job.getClass());
return new ResponseEntity<>("No handler found for job type: " + job.getClass(), HttpStatus.INTERNAL_SERVER_ERROR);
}



return new ResponseEntity<>(node.toString(), HttpStatus.OK);
}

private void handleUploadJob(ObjectNode node, IUploadJob job) {
node.put("groupId", job.getCitationGroup());
}

private void handleExportJob(ObjectNode node, IExportJob job) {
IExportTask exportTask = exportTaskManager.get(job.getTaskId());
node.put("groupId", exportTask.getGroupId());
node.put("collectionId", exportTask.getCollectionId());
node.put("exportType", exportTask.getExportType().name());
node.put("taskId", exportTask.getId());
}

@SuppressWarnings("deprecation")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what's deprecated here? is there not a version that is not deprecated?

private void handleImportCrossrefJob(ObjectNode node, IImportCrossrefJob job) {
ObjectMapper mapper = new ObjectMapper();
ArrayNode arrayNode = mapper.valueToTree(job.getDois());
node.put("dois", arrayNode);
node.put("groupId", job.getCitationGroup());
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package edu.asu.diging.citesphere.core.model.jobs;

import java.util.List;

import edu.asu.diging.citesphere.model.bib.ICitationGroup;

public interface IImportCrossrefJob extends IJob {

/**
* Get the DOIs of the resources to be imported from Crossref.
* @return list of resources to be imported
*/
List<String> getDois();

void setDois(List<String> dois);

void setCitationGroup(String citationGroup);

String getCitationGroup();

ICitationGroup getCitationGroupDetail();

void setCitationGroupDetail(ICitationGroup citationGroupDetail);


}
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
package edu.asu.diging.citesphere.core.model.jobs.impl;

import java.util.List;

import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.Transient;

import edu.asu.diging.citesphere.core.model.jobs.IImportCrossrefJob;
import edu.asu.diging.citesphere.model.bib.ICitationGroup;

@Entity
public class ImportCrossrefJob extends Job implements IImportCrossrefJob {

@ElementCollection
private List<String> dois;
private String citationGroup;
@Transient
private ICitationGroup citationGroupDetail;

/**
* Get the DOIs of the resources to be imported from Crossref.
* @return list of resources to be imported
*/
@Override
public List<String> getDois() {
return dois;
}

@Override
public void setDois(List<String> dois) {
this.dois = dois;
}

@Override
public String getCitationGroup() {
return citationGroup;
}

@Override
public void setCitationGroup(String citationGroup) {
this.citationGroup = citationGroup;
}

@Override
public ICitationGroup getCitationGroupDetail() {
return citationGroupDetail;
}

@Override
public void setCitationGroupDetail(ICitationGroup citationGroupDetail) {
this.citationGroupDetail = citationGroupDetail;
}




}
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package edu.asu.diging.citesphere.core.model.jobs.impl;

import java.time.OffsetDateTime;
import java.util.ArrayList;
import java.util.List;

import javax.persistence.CascadeType;
Expand Down Expand Up @@ -42,7 +43,7 @@ public class Job implements IJob {

@JsonIgnore
@OneToMany(cascade=CascadeType.ALL)
private List<JobPhase> phases;
private List<JobPhase> phases = new ArrayList<>();


/* (non-Javadoc)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
package edu.asu.diging.citesphere.core.repository.jobs;

import org.springframework.data.repository.CrudRepository;

import edu.asu.diging.citesphere.core.model.jobs.impl.ImportCrossrefJob;

public interface ImportCrossrefJobRepository extends CrudRepository<ImportCrossrefJob, String> {

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package edu.asu.diging.citesphere.core.service.crossref;

import java.io.IOException;
import java.util.List;

import edu.asu.diging.crossref.exception.RequestFailedException;
import edu.asu.diging.crossref.model.Item;

public interface CrossrefService {

List<Item> search(String query, int page) throws RequestFailedException, IOException;

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package edu.asu.diging.citesphere.core.service.crossref.impl;

import java.io.IOException;
import java.util.List;

import javax.annotation.PostConstruct;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Service;

import edu.asu.diging.citesphere.core.service.crossref.CrossrefService;
import edu.asu.diging.crossref.exception.RequestFailedException;
import edu.asu.diging.crossref.model.Item;
import edu.asu.diging.crossref.service.CrossrefConfiguration;
import edu.asu.diging.crossref.service.CrossrefWorksService;
import edu.asu.diging.crossref.service.impl.CrossrefWorksServiceImpl;

@Service
@PropertySource("classpath:config.properties")
public class CrossrefServiceImpl implements CrossrefService {

@Value("${_crossref_default_pagesize}")
private int defaultPageSize;

private CrossrefWorksService service;

@PostConstruct
public void init() {
service = new CrossrefWorksServiceImpl(CrossrefConfiguration.getDefaultConfig());
}


@Override
public List<Item> search(String query, int page) throws RequestFailedException, IOException {
return service.search(query, defaultPageSize, (page-1)*defaultPageSize);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package edu.asu.diging.citesphere.core.service.jobs;

import java.util.List;

import edu.asu.diging.citesphere.core.exceptions.GroupDoesNotExistException;
import edu.asu.diging.citesphere.core.model.jobs.IImportCrossrefJob;
import edu.asu.diging.citesphere.user.IUser;

public interface IImportCrossrefJobManager {

IImportCrossrefJob createJob(IUser user, String groupId, List<String> dois) throws GroupDoesNotExistException;

}
Loading