92 lines
4.9 KiB
Java
92 lines
4.9 KiB
Java
package eu.eudat.controllers;
|
|
|
|
import eu.eudat.authorization.Permission;
|
|
import eu.eudat.logic.managers.DepositManager;
|
|
import eu.eudat.logic.services.ApiContext;
|
|
import eu.eudat.models.data.doi.DepositCode;
|
|
import eu.eudat.models.data.doi.DepositRequest;
|
|
import eu.eudat.models.data.doi.Doi;
|
|
import eu.eudat.models.data.doi.RepositoryConfig;
|
|
import eu.eudat.models.data.helpers.responses.ResponseItem;
|
|
import eu.eudat.types.ApiMessageCode;
|
|
import gr.cite.commons.web.authz.service.AuthorizationService;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.http.HttpStatus;
|
|
import org.springframework.http.ResponseEntity;
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
import java.util.List;
|
|
|
|
@RestController
|
|
@CrossOrigin
|
|
@RequestMapping(value = {"/api/deposit/"})
|
|
public class DepositController extends BaseController {
|
|
private static final Logger logger = LoggerFactory.getLogger(DepositController.class);
|
|
|
|
private final DepositManager depositManager;
|
|
private final AuthorizationService authorizationService;
|
|
|
|
@Autowired
|
|
public DepositController(ApiContext apiContext, DepositManager depositManager, AuthorizationService authorizationService){
|
|
super(apiContext);
|
|
this.depositManager = depositManager;
|
|
this.authorizationService = authorizationService;
|
|
}
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = {"/repos"})
|
|
public @ResponseBody
|
|
ResponseEntity<ResponseItem<List<RepositoryConfig>>> getAvailableRepos() {
|
|
this.authorizationService.authorizeForce(Permission.AdminRole, Permission.ManagerRole, Permission.UserRole, Permission.AnonymousRole);
|
|
|
|
List<RepositoryConfig> ids = this.depositManager.getAvailableRepos();
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem<List<RepositoryConfig>>().status(ApiMessageCode.NO_MESSAGE).payload(ids));
|
|
}
|
|
|
|
@RequestMapping(method = RequestMethod.POST, value = {"/getAccessToken"})
|
|
public @ResponseBody
|
|
ResponseEntity<ResponseItem<String>> getAccessToken(@RequestBody DepositCode depositCode) throws Exception {
|
|
this.authorizationService.authorizeForce(Permission.AdminRole, Permission.ManagerRole, Permission.UserRole, Permission.AnonymousRole);
|
|
|
|
String accessToken = this.depositManager.authenticate(depositCode.getRepositoryId(), depositCode.getCode());
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem<String>().status(ApiMessageCode.NO_MESSAGE).payload(accessToken));
|
|
}
|
|
|
|
@RequestMapping(method = RequestMethod.POST, value = {"/createDoi"})
|
|
public @ResponseBody
|
|
ResponseEntity<ResponseItem<Doi>> createDoi(@RequestBody DepositRequest depositRequest) {
|
|
this.authorizationService.authorizeForce(Permission.AdminRole, Permission.ManagerRole, Permission.UserRole, Permission.AnonymousRole);
|
|
try {
|
|
Doi doi = this.depositManager.deposit(depositRequest);
|
|
if(doi != null){
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem<Doi>().status(ApiMessageCode.SUCCESS_MESSAGE).message("Successfully created DOI for Data Datamanagement Plan in question.").payload(doi));
|
|
}
|
|
else{
|
|
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(new ResponseItem<Doi>().status(ApiMessageCode.ERROR_MESSAGE).message("Failed to create DOI for the Data Management Plan"));
|
|
}
|
|
} catch (Exception e) {
|
|
logger.error(e.getMessage(), e);
|
|
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(new ResponseItem<Doi>().status(ApiMessageCode.ERROR_MESSAGE).message("Failed to create DOI for the Data Management Plan: " + e.getMessage()));
|
|
}
|
|
}
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = {"/logo/{repositoryId}"})
|
|
public @ResponseBody
|
|
ResponseEntity<ResponseItem<String>> getLogo(@PathVariable("repositoryId") String repositoryId) {
|
|
this.authorizationService.authorizeForce(Permission.AdminRole, Permission.ManagerRole, Permission.UserRole, Permission.AnonymousRole);
|
|
try {
|
|
String encodedLogo = this.depositManager.getRepositoryLogo(repositoryId);
|
|
if(encodedLogo != null){
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem<String>().status(ApiMessageCode.SUCCESS_MESSAGE).message("Successfully loaded " + repositoryId + "'s logo.").payload(encodedLogo));
|
|
}
|
|
else{
|
|
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(new ResponseItem<String>().status(ApiMessageCode.ERROR_MESSAGE).message(repositoryId + " has no logo").payload(null));
|
|
}
|
|
} catch (Exception e) {
|
|
logger.error(e.getMessage(), e);
|
|
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(new ResponseItem<String>().status(ApiMessageCode.ERROR_MESSAGE).message("Failed to load " + repositoryId + "'s logo: " + e.getMessage()));
|
|
}
|
|
}
|
|
}
|