moved context API controller in the original package
This commit is contained in:
parent
a8f3bb6961
commit
51cbe18abf
|
@ -1,174 +0,0 @@
|
||||||
package eu.dnetlib.openaire.community;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
|
||||||
import org.apache.commons.logging.Log;
|
|
||||||
import org.apache.commons.logging.LogFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
|
||||||
import org.springframework.web.bind.annotation.CrossOrigin;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import eu.dnetlib.openaire.exporter.exceptions.CommunityException;
|
|
||||||
import eu.dnetlib.openaire.exporter.model.community.CommunityType;
|
|
||||||
import eu.dnetlib.openaire.exporter.model.community.SubCommunity;
|
|
||||||
import eu.dnetlib.openaire.exporter.model.context.CategorySummary;
|
|
||||||
import eu.dnetlib.openaire.exporter.model.context.ConceptSummary;
|
|
||||||
import eu.dnetlib.openaire.exporter.model.context.ContextSummary;
|
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
|
||||||
import io.swagger.v3.oas.annotations.responses.ApiResponse;
|
|
||||||
import io.swagger.v3.oas.annotations.responses.ApiResponses;
|
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@CrossOrigin(origins = {
|
|
||||||
"*"
|
|
||||||
})
|
|
||||||
@ConditionalOnProperty(value = "openaire.exporter.enable.community", havingValue = "true")
|
|
||||||
@Tag(name = "OpenAIRE Context API", description = "the OpenAIRE Context API")
|
|
||||||
public class ContextApiController {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private CommunityService communityService;
|
|
||||||
|
|
||||||
private static final Log log = LogFactory.getLog(ContextApiController.class);
|
|
||||||
|
|
||||||
@RequestMapping(value = "/contexts", produces = {
|
|
||||||
"application/json"
|
|
||||||
}, method = RequestMethod.GET)
|
|
||||||
@Operation(summary = "list brief information about all the context profiles", description = "list brief information about all the context profiles")
|
|
||||||
@ApiResponses(value = {
|
|
||||||
@ApiResponse(responseCode = "200", description = "OK"),
|
|
||||||
@ApiResponse(responseCode = "500", description = "unexpected error")
|
|
||||||
})
|
|
||||||
public List<ContextSummary> listContexts(@RequestParam(required = false) final Set<CommunityType> type) throws CommunityException {
|
|
||||||
return communityService.listCommunities()
|
|
||||||
.stream()
|
|
||||||
.filter(c -> type == null || type.contains(c.getType()))
|
|
||||||
.map(c -> {
|
|
||||||
final ContextSummary ctx = new ContextSummary();
|
|
||||||
ctx.setId(c.getId());
|
|
||||||
ctx.setLabel(c.getName());
|
|
||||||
ctx.setStatus(c.getStatus().toString());
|
|
||||||
ctx.setType(c.getType().toString());
|
|
||||||
return ctx;
|
|
||||||
})
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/context/{contextId}", produces = {
|
|
||||||
"application/json"
|
|
||||||
}, method = RequestMethod.GET)
|
|
||||||
@Operation(summary = "list the categories defined within a context", description = "list the categories defined within a context")
|
|
||||||
@ApiResponses(value = {
|
|
||||||
@ApiResponse(responseCode = "200", description = "OK"),
|
|
||||||
@ApiResponse(responseCode = "500", description = "unexpected error")
|
|
||||||
})
|
|
||||||
public List<CategorySummary> listCategories(
|
|
||||||
@PathVariable final String contextId,
|
|
||||||
@RequestParam(required = false, defaultValue = "false") final boolean all) throws CommunityException {
|
|
||||||
|
|
||||||
try {
|
|
||||||
return communityService.getSubCommunities(contextId)
|
|
||||||
.stream()
|
|
||||||
.filter(sc -> all || sc.isClaim())
|
|
||||||
.map(sc -> {
|
|
||||||
final String[] parts = StringUtils.split(sc.getSubCommunityId(), "::");
|
|
||||||
if (parts.length < 3) { throw new RuntimeException("Invalid conceptId (It should have 3 (or more) parts): " + sc.getSubCommunityId()); }
|
|
||||||
final CategorySummary cat = new CategorySummary();
|
|
||||||
cat.setId(parts[0] + "::" + parts[1]);
|
|
||||||
cat.setLabel(sc.getLabel());
|
|
||||||
cat.setHasConcept(true);
|
|
||||||
return cat;
|
|
||||||
})
|
|
||||||
.distinct()
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
} catch (final Throwable e) {
|
|
||||||
log.error(e);
|
|
||||||
throw new CommunityException(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/context/category/{categoryId}", produces = {
|
|
||||||
"application/json"
|
|
||||||
}, method = RequestMethod.GET)
|
|
||||||
@Operation(summary = "list the concepts defined within a category", description = "list the concepts defined within a category")
|
|
||||||
@ApiResponses(value = {
|
|
||||||
@ApiResponse(responseCode = "200", description = "OK"),
|
|
||||||
@ApiResponse(responseCode = "500", description = "unexpected error")
|
|
||||||
})
|
|
||||||
public List<ConceptSummary> listConcepts(
|
|
||||||
@PathVariable final String categoryId,
|
|
||||||
@RequestParam(required = false, defaultValue = "false") final boolean all) throws CommunityException {
|
|
||||||
|
|
||||||
final String[] parts = StringUtils.split(categoryId, "::");
|
|
||||||
if (parts.length != 2) {
|
|
||||||
log.error("Invalid category id (it should have 2 parts): " + categoryId);
|
|
||||||
throw new CommunityException("Invalid category id (it should have 2 parts): " + categoryId);
|
|
||||||
}
|
|
||||||
|
|
||||||
final String contextId = parts[0];
|
|
||||||
|
|
||||||
final List<SubCommunity> list = findSubCommunities(categoryId + "::", all, contextId);
|
|
||||||
|
|
||||||
return processSubCommunities(null, list);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/context/category/concept/{conceptId}", produces = {
|
|
||||||
"application/json"
|
|
||||||
}, method = RequestMethod.GET)
|
|
||||||
@Operation(summary = "list the concepts defined within a category", description = "list the concepts defined within a category")
|
|
||||||
@ApiResponses(value = {
|
|
||||||
@ApiResponse(responseCode = "200", description = "OK"),
|
|
||||||
@ApiResponse(responseCode = "500", description = "unexpected error")
|
|
||||||
})
|
|
||||||
public List<ConceptSummary> listSubConcepts(
|
|
||||||
@PathVariable final String conceptId,
|
|
||||||
@RequestParam(required = false, defaultValue = "false") final boolean all) throws CommunityException {
|
|
||||||
|
|
||||||
final String[] parts = StringUtils.split(conceptId, "::");
|
|
||||||
if (parts.length < 3) {
|
|
||||||
log.error("Invalid concept id (it should have 3 (or more) parts): " + conceptId);
|
|
||||||
throw new CommunityException("Invalid concept id (it should have 3 (or more) parts): " + conceptId);
|
|
||||||
}
|
|
||||||
|
|
||||||
final String contextId = parts[0];
|
|
||||||
|
|
||||||
final List<SubCommunity> list = findSubCommunities(conceptId + "::", all, contextId);
|
|
||||||
|
|
||||||
return processSubCommunities(conceptId, list);
|
|
||||||
}
|
|
||||||
|
|
||||||
private List<SubCommunity> findSubCommunities(final String prefix, final boolean all, final String contextId) throws CommunityException {
|
|
||||||
return communityService.getSubCommunities(contextId)
|
|
||||||
.stream()
|
|
||||||
.filter(sc -> all || sc.isClaim())
|
|
||||||
.filter(sc -> sc.getSubCommunityId().startsWith(prefix))
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
}
|
|
||||||
|
|
||||||
private List<ConceptSummary> processSubCommunities(final String parent, final List<SubCommunity> list) {
|
|
||||||
return list.stream()
|
|
||||||
.filter(sc -> Objects.equals(sc.getParent(), parent))
|
|
||||||
.map(sc -> {
|
|
||||||
final List<ConceptSummary> childs = processSubCommunities(sc.getSubCommunityId(), list);
|
|
||||||
final ConceptSummary concept = new ConceptSummary();
|
|
||||||
concept.setId(sc.getSubCommunityId());
|
|
||||||
concept.setLabel(sc.getLabel());
|
|
||||||
concept.setHasSubConcept(!childs.isEmpty());
|
|
||||||
concept.setConcept(childs);
|
|
||||||
return concept;
|
|
||||||
})
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,32 +1,46 @@
|
||||||
package eu.dnetlib.openaire.context;
|
package eu.dnetlib.openaire.context;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Objects;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
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.Autowired;
|
||||||
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
||||||
|
import org.springframework.web.bind.annotation.CrossOrigin;
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
import org.springframework.web.bind.annotation.PathVariable;
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
import org.springframework.web.bind.annotation.RequestMethod;
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
import eu.dnetlib.openaire.exporter.exceptions.ContextException;
|
import eu.dnetlib.openaire.community.CommunityService;
|
||||||
|
import eu.dnetlib.openaire.exporter.exceptions.CommunityException;
|
||||||
|
import eu.dnetlib.openaire.exporter.model.community.CommunityType;
|
||||||
|
import eu.dnetlib.openaire.exporter.model.community.SubCommunity;
|
||||||
import eu.dnetlib.openaire.exporter.model.context.CategorySummary;
|
import eu.dnetlib.openaire.exporter.model.context.CategorySummary;
|
||||||
import eu.dnetlib.openaire.exporter.model.context.ConceptSummary;
|
import eu.dnetlib.openaire.exporter.model.context.ConceptSummary;
|
||||||
import eu.dnetlib.openaire.exporter.model.context.ContextSummary;
|
import eu.dnetlib.openaire.exporter.model.context.ContextSummary;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
import io.swagger.v3.oas.annotations.responses.ApiResponse;
|
import io.swagger.v3.oas.annotations.responses.ApiResponse;
|
||||||
import io.swagger.v3.oas.annotations.responses.ApiResponses;
|
import io.swagger.v3.oas.annotations.responses.ApiResponses;
|
||||||
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
|
||||||
// @RestController
|
@RestController
|
||||||
// @CrossOrigin(origins = { "*" })
|
@CrossOrigin(origins = {
|
||||||
// @ConditionalOnProperty(value = "openaire.exporter.enable.context", havingValue = "true")
|
"*"
|
||||||
// @Tag(name = "OpenAIRE Context API", description = "the OpenAIRE Context API")
|
})
|
||||||
@Deprecated
|
@ConditionalOnProperty(value = "openaire.exporter.enable.community", havingValue = "true")
|
||||||
// THIS APIs HAS BEEN REIMPLEMENTED UNDER THE COMMUNITY APIs
|
@Tag(name = "OpenAIRE Context API", description = "the OpenAIRE Context API")
|
||||||
public class ContextApiController {
|
public class ContextApiController {
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private ContextApiCore contextApiCore;
|
private CommunityService communityService;
|
||||||
|
|
||||||
|
private static final Log log = LogFactory.getLog(ContextApiController.class);
|
||||||
|
|
||||||
@RequestMapping(value = "/contexts", produces = {
|
@RequestMapping(value = "/contexts", produces = {
|
||||||
"application/json"
|
"application/json"
|
||||||
|
@ -36,8 +50,19 @@ public class ContextApiController {
|
||||||
@ApiResponse(responseCode = "200", description = "OK"),
|
@ApiResponse(responseCode = "200", description = "OK"),
|
||||||
@ApiResponse(responseCode = "500", description = "unexpected error")
|
@ApiResponse(responseCode = "500", description = "unexpected error")
|
||||||
})
|
})
|
||||||
public List<ContextSummary> listContexts(@RequestParam(required = false, defaultValue = "") final List<String> type) throws ContextException {
|
public List<ContextSummary> listContexts(@RequestParam(required = false) final Set<CommunityType> type) throws CommunityException {
|
||||||
return contextApiCore.listContexts(type);
|
return communityService.listCommunities()
|
||||||
|
.stream()
|
||||||
|
.filter(c -> type == null || type.contains(c.getType()))
|
||||||
|
.map(c -> {
|
||||||
|
final ContextSummary ctx = new ContextSummary();
|
||||||
|
ctx.setId(c.getId());
|
||||||
|
ctx.setLabel(c.getName());
|
||||||
|
ctx.setStatus(c.getStatus().toString());
|
||||||
|
ctx.setType(c.getType().toString());
|
||||||
|
return ctx;
|
||||||
|
})
|
||||||
|
.collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping(value = "/context/{contextId}", produces = {
|
@RequestMapping(value = "/context/{contextId}", produces = {
|
||||||
|
@ -50,10 +75,27 @@ public class ContextApiController {
|
||||||
})
|
})
|
||||||
public List<CategorySummary> listCategories(
|
public List<CategorySummary> listCategories(
|
||||||
@PathVariable final String contextId,
|
@PathVariable final String contextId,
|
||||||
@RequestParam(required = false, defaultValue = "false") final Boolean all) throws ContextException {
|
@RequestParam(required = false, defaultValue = "false") final boolean all) throws CommunityException {
|
||||||
|
|
||||||
final Boolean allFilter = Optional.ofNullable(all).orElse(false);
|
try {
|
||||||
return contextApiCore.listCategories(contextId, allFilter);
|
return communityService.getSubCommunities(contextId)
|
||||||
|
.stream()
|
||||||
|
.filter(sc -> all || sc.isClaim())
|
||||||
|
.map(sc -> {
|
||||||
|
final String[] parts = StringUtils.split(sc.getSubCommunityId(), "::");
|
||||||
|
if (parts.length < 3) { throw new RuntimeException("Invalid conceptId (It should have 3 (or more) parts): " + sc.getSubCommunityId()); }
|
||||||
|
final CategorySummary cat = new CategorySummary();
|
||||||
|
cat.setId(parts[0] + "::" + parts[1]);
|
||||||
|
cat.setLabel(sc.getLabel());
|
||||||
|
cat.setHasConcept(true);
|
||||||
|
return cat;
|
||||||
|
})
|
||||||
|
.distinct()
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
} catch (final Throwable e) {
|
||||||
|
log.error(e);
|
||||||
|
throw new CommunityException(e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping(value = "/context/category/{categoryId}", produces = {
|
@RequestMapping(value = "/context/category/{categoryId}", produces = {
|
||||||
|
@ -66,10 +108,20 @@ public class ContextApiController {
|
||||||
})
|
})
|
||||||
public List<ConceptSummary> listConcepts(
|
public List<ConceptSummary> listConcepts(
|
||||||
@PathVariable final String categoryId,
|
@PathVariable final String categoryId,
|
||||||
@RequestParam(required = false, defaultValue = "false") final Boolean all) throws ContextException {
|
@RequestParam(required = false, defaultValue = "false") final boolean all) throws CommunityException {
|
||||||
|
|
||||||
|
final String[] parts = StringUtils.split(categoryId, "::");
|
||||||
|
if (parts.length != 2) {
|
||||||
|
log.error("Invalid category id (it should have 2 parts): " + categoryId);
|
||||||
|
throw new CommunityException("Invalid category id (it should have 2 parts): " + categoryId);
|
||||||
|
}
|
||||||
|
|
||||||
|
final String contextId = parts[0];
|
||||||
|
|
||||||
|
final List<SubCommunity> list = findSubCommunities(categoryId + "::", all, contextId);
|
||||||
|
|
||||||
|
return processSubCommunities(null, list);
|
||||||
|
|
||||||
final Boolean allFilter = Optional.ofNullable(all).orElse(false);
|
|
||||||
return contextApiCore.listConcepts(categoryId, allFilter);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping(value = "/context/category/concept/{conceptId}", produces = {
|
@RequestMapping(value = "/context/category/concept/{conceptId}", produces = {
|
||||||
|
@ -82,10 +134,42 @@ public class ContextApiController {
|
||||||
})
|
})
|
||||||
public List<ConceptSummary> listSubConcepts(
|
public List<ConceptSummary> listSubConcepts(
|
||||||
@PathVariable final String conceptId,
|
@PathVariable final String conceptId,
|
||||||
@RequestParam(required = false, defaultValue = "false") final Boolean all) throws ContextException {
|
@RequestParam(required = false, defaultValue = "false") final boolean all) throws CommunityException {
|
||||||
|
|
||||||
final Boolean allFilter = Optional.ofNullable(all).orElse(false);
|
final String[] parts = StringUtils.split(conceptId, "::");
|
||||||
return contextApiCore.listSubConcepts(conceptId, allFilter);
|
if (parts.length < 3) {
|
||||||
|
log.error("Invalid concept id (it should have 3 (or more) parts): " + conceptId);
|
||||||
|
throw new CommunityException("Invalid concept id (it should have 3 (or more) parts): " + conceptId);
|
||||||
|
}
|
||||||
|
|
||||||
|
final String contextId = parts[0];
|
||||||
|
|
||||||
|
final List<SubCommunity> list = findSubCommunities(conceptId + "::", all, contextId);
|
||||||
|
|
||||||
|
return processSubCommunities(conceptId, list);
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<SubCommunity> findSubCommunities(final String prefix, final boolean all, final String contextId) throws CommunityException {
|
||||||
|
return communityService.getSubCommunities(contextId)
|
||||||
|
.stream()
|
||||||
|
.filter(sc -> all || sc.isClaim())
|
||||||
|
.filter(sc -> sc.getSubCommunityId().startsWith(prefix))
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<ConceptSummary> processSubCommunities(final String parent, final List<SubCommunity> list) {
|
||||||
|
return list.stream()
|
||||||
|
.filter(sc -> Objects.equals(sc.getParent(), parent))
|
||||||
|
.map(sc -> {
|
||||||
|
final List<ConceptSummary> childs = processSubCommunities(sc.getSubCommunityId(), list);
|
||||||
|
final ConceptSummary concept = new ConceptSummary();
|
||||||
|
concept.setId(sc.getSubCommunityId());
|
||||||
|
concept.setLabel(sc.getLabel());
|
||||||
|
concept.setHasSubConcept(!childs.isEmpty());
|
||||||
|
concept.setConcept(childs);
|
||||||
|
return concept;
|
||||||
|
})
|
||||||
|
.collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,7 @@ import eu.dnetlib.openaire.exporter.model.context.Context;
|
||||||
import eu.dnetlib.openaire.exporter.model.context.Param;
|
import eu.dnetlib.openaire.exporter.model.context.Param;
|
||||||
import eu.dnetlib.openaire.exporter.model.funders.FunderDetails;
|
import eu.dnetlib.openaire.exporter.model.funders.FunderDetails;
|
||||||
|
|
||||||
|
@Deprecated
|
||||||
public class ContextMappingUtils {
|
public class ContextMappingUtils {
|
||||||
|
|
||||||
private static final List<String> DATE_PATTERN = Lists.newArrayList("yyyy-MM-dd'T'hh:mm:ss", "yyyy-MM-dd'T'hh:mm:ssXXX", "yyyy-MM-dd'T'hh:mm:ss+00:00");
|
private static final List<String> DATE_PATTERN = Lists.newArrayList("yyyy-MM-dd'T'hh:mm:ss", "yyyy-MM-dd'T'hh:mm:ssXXX", "yyyy-MM-dd'T'hh:mm:ss+00:00");
|
||||||
|
|
Loading…
Reference in New Issue