dnet-applications/apps/dnet-orgs-database-application/src/main/java/eu/dnetlib/organizations/controller/OpenaireInternalApiControll...

67 lines
2.4 KiB
Java
Raw Normal View History

2020-09-29 11:34:31 +02:00
package eu.dnetlib.organizations.controller;
import java.util.Arrays;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
2021-01-27 12:17:38 +01:00
import eu.dnetlib.common.controller.AbstractDnetController;
import eu.dnetlib.organizations.importer.ImportExecution;
2021-09-30 09:16:06 +02:00
import eu.dnetlib.organizations.importer.ImportExecutor;
2020-09-29 11:34:31 +02:00
import eu.dnetlib.organizations.utils.DatabaseUtils;
@RestController
@RequestMapping("/oa_api")
2021-01-27 12:17:38 +01:00
public class OpenaireInternalApiController extends AbstractDnetController {
2020-09-29 11:34:31 +02:00
@Autowired
private DatabaseUtils databaseUtils;
@Value("${openaire.api.https.proxy}")
private String httpsProxy;
@Autowired
2021-09-30 09:16:06 +02:00
private ImportExecutor importExecutor;
2020-09-29 11:34:31 +02:00
private static final Log log = LogFactory.getLog(OpenaireInternalApiController.class);
2021-04-22 15:42:35 +02:00
@GetMapping("/import/dedupEvents")
2021-04-22 15:42:35 +02:00
public ImportExecution importDedupEvents(final HttpServletRequest req) {
2020-09-29 11:34:31 +02:00
if (req.getRemoteAddr().equals(httpsProxy)) {
log.warn("Call received by blaklisted ip (https proxy): " + req.getRemoteAddr());
throw new RuntimeException("Call received by blaklisted ip (https proxy): " + req.getRemoteAddr());
}
2020-10-14 16:28:00 +02:00
2021-09-30 09:16:06 +02:00
return importExecutor.startImport("IP " + req.getRemoteAddr());
2021-04-22 15:42:35 +02:00
}
@GetMapping("/import/dedupEvents/status")
public final ImportExecution statusDedupEvents(final HttpServletRequest req) {
if (req.getRemoteAddr().equals(httpsProxy)) {
log.warn("Call received by blaklisted ip (https proxy): " + req.getRemoteAddr());
throw new RuntimeException("Call received by blaklisted ip (https proxy): " + req.getRemoteAddr());
}
2021-09-30 09:16:06 +02:00
return importExecutor.getLastImportExecution();
2020-09-29 11:34:31 +02:00
}
2021-01-15 12:21:10 +01:00
@GetMapping("/refresh/fulltextIndex")
2021-04-22 15:42:35 +02:00
public final List<String> updateFulltextIndex(final HttpServletRequest req) {
2021-01-15 12:21:10 +01:00
if (req.getRemoteAddr().equals(httpsProxy)) {
log.warn("Call received by blaklisted ip (https proxy): " + req.getRemoteAddr());
throw new RuntimeException("Call received by blaklisted ip (https proxy): " + req.getRemoteAddr());
}
new Thread(databaseUtils::updateFulltextIndex).start();
return Arrays.asList("Updating ...");
}
2021-04-22 15:42:35 +02:00
2020-09-29 11:34:31 +02:00
}