import java.io.IOException;\r
import java.util.ArrayList;\r
import java.util.Arrays;\r
-import java.util.HashSet;\r
import java.util.List;\r
import java.util.Set;\r
import java.util.UUID;\r
\r
+import javax.persistence.EntityNotFoundException;\r
import javax.servlet.http.HttpServletRequest;\r
import javax.servlet.http.HttpServletResponse;\r
\r
import org.springframework.web.bind.annotation.PathVariable;\r
import org.springframework.web.bind.annotation.RequestMapping;\r
import org.springframework.web.bind.annotation.RequestMethod;\r
+import org.springframework.web.bind.annotation.RequestParam;\r
import org.springframework.web.servlet.ModelAndView;\r
\r
import eu.etaxonomy.cdm.api.service.INameService;\r
import eu.etaxonomy.cdm.api.service.ITaxonService;\r
import eu.etaxonomy.cdm.model.occurrence.SpecimenOrObservationBase;\r
import eu.etaxonomy.cdm.model.taxon.Classification;\r
-import eu.etaxonomy.cdm.model.taxon.Synonym;\r
import eu.etaxonomy.cdm.model.taxon.Taxon;\r
import eu.etaxonomy.cdm.model.taxon.TaxonBase;\r
import eu.etaxonomy.cdm.model.taxon.TaxonNode;\r
import eu.etaxonomy.cdm.persistence.query.OrderHint;\r
import eu.etaxonomy.cdm.persistence.query.OrderHint.SortOrder;\r
+import eu.etaxonomy.cdm.remote.controller.util.PagerParameters;\r
\r
/**\r
* TODO write controller documentation\r
* {@link #DEFAULT_INIT_STRATEGY}\r
* @throws IOException\r
*/\r
+ /**\r
+ * Get the set of accepted {@link Taxon} entities for a given\r
+ * {@link TaxonBase} entity identified by the <code>{taxon-uuid}</code>.\r
+ * <p>\r
+ * URI: <b>/{datasource-name}/portal/taxon/{taxon-uuid}/accepted</b>\r
+ *\r
+ * @param request\r
+ * @param response\r
+ * @return a Set of {@link Taxon} entities which are initialized\r
+ * using the following initialization strategy:\r
+ * {@link #SYNONYMY_INIT_STRATEGY}\r
+ * @throws IOException\r
+ * @Deprecated use getAcceptedFor() instead\r
+ */\r
+ @Deprecated\r
+ @RequestMapping(value = "accepted/{classification_uuid}", method = RequestMethod.GET)\r
+ public ModelAndView getAcceptedForWithClassificationFilter(\r
+ @PathVariable("uuid") UUID uuid,\r
+ @PathVariable("classification_uuid") UUID classification_uuid,\r
+ @RequestParam(value = "pageNumber", required = false) Integer pageNumber,\r
+ @RequestParam(value = "pageSize", required = false) Integer pageSize,\r
+ HttpServletRequest request,\r
+ HttpServletResponse response)\r
+ throws IOException {\r
+\r
+\r
+ return getAcceptedFor(uuid, classification_uuid, pageNumber, pageSize, request, response);\r
+ }\r
+\r
@RequestMapping(value = "accepted", method = RequestMethod.GET)\r
- public Set<TaxonBase> doGetAccepted(\r
+ public ModelAndView getAcceptedFor(\r
@PathVariable("uuid") UUID uuid,\r
+ @RequestParam(value = "classificationFilter", required = false) UUID classification_uuid,\r
+ @RequestParam(value = "pageNumber", required = false) Integer pageNumber,\r
+ @RequestParam(value = "pageSize", required = false) Integer pageSize,\r
HttpServletRequest request,\r
- HttpServletResponse response) throws IOException {\r
- logger.info("getAccepted() " + request.getRequestURI());\r
- TaxonBase tb = service.load(uuid);\r
- HashSet<TaxonBase> resultset = new HashSet<TaxonBase>();\r
- if(tb instanceof Taxon){\r
- //the taxon already is accepted\r
- //FIXME take the current view into account once views are implemented!!!\r
- resultset.add(tb);\r
- } else {\r
- Synonym syn = (Synonym)tb;\r
- resultset.addAll(syn.getAcceptedTaxa());\r
- //TODO init Synonyms\r
+ HttpServletResponse response)\r
+ throws IOException {\r
+ if(request != null){\r
+ logger.info("getAccepted() " + requestPathAndQuery(request));\r
}\r
- return resultset;\r
+\r
+ ModelAndView mv = new ModelAndView();\r
+\r
+ PagerParameters pagerParams = new PagerParameters(pageSize, pageNumber);\r
+ pagerParams.normalizeAndValidate(response);\r
+\r
+ try {\r
+ List<Taxon> resultset = service.listAcceptedTaxaFor(uuid, classification_uuid, pagerParams.getPageSize(), pagerParams.getPageIndex(), null, getInitializationStrategy());\r
+ mv.addObject(resultset);\r
+ } catch (EntityNotFoundException e){\r
+ HttpStatusMessage.UUID_NOT_FOUND.send(response);\r
+ }\r
+\r
+ return mv;\r
}\r
\r
@RequestMapping(value = "classifications", method = RequestMethod.GET)\r
return mv;\r
}\r
\r
- /**\r
- * FIXME change @RequestMapping to /taxon/findBestMatchingTaxon and also move into TaxonListController\r
- */\r
- @RequestMapping(value = "/bestMatchingTaxon/{taxonName}", method = RequestMethod.GET)\r
- public TaxonBase doFindBestMatchingTaxon(\r
- @PathVariable("taxonName") String taxonName,\r
- HttpServletRequest request,\r
- HttpServletResponse response)throws IOException {\r
-\r
- Taxon bestMatchingTaxon = taxonService.findBestMatchingTaxon(taxonName);\r
-\r
- return bestMatchingTaxon;\r
-\r
-\r
- }\r
\r
}
\ No newline at end of file
import java.util.Set;\r
import java.util.UUID;\r
\r
-import javax.persistence.EntityNotFoundException;\r
import javax.servlet.http.HttpServletRequest;\r
import javax.servlet.http.HttpServletResponse;\r
\r
*/\r
@Controller\r
@RequestMapping(value = {"/portal/taxon/{uuid}"})\r
-public class TaxonPortalController extends BaseController<TaxonBase, ITaxonService>\r
+public class TaxonPortalController extends TaxonController\r
{\r
\r
public static final Logger logger = Logger.getLogger(TaxonPortalController.class);\r
return mv;\r
}\r
\r
- /**\r
- * Get the set of accepted {@link Taxon} entities for a given\r
- * {@link TaxonBase} entity identified by the <code>{taxon-uuid}</code>.\r
- * <p>\r
- * URI: <b>/{datasource-name}/portal/taxon/{taxon-uuid}/accepted</b>\r
- *\r
- * @param request\r
- * @param response\r
- * @return a Set of {@link Taxon} entities which are initialized\r
- * using the following initialization strategy:\r
- * {@link #SYNONYMY_INIT_STRATEGY}\r
- * @throws IOException\r
- */\r
- @RequestMapping(value = "accepted/{classification_uuid}", method = RequestMethod.GET)\r
- public ModelAndView getAccepted(\r
- @PathVariable("uuid") UUID uuid,\r
- @PathVariable("classification_uuid") UUID classification_uuid,\r
- @RequestParam(value = "pageNumber", required = false) Integer pageNumber,\r
- @RequestParam(value = "pageSize", required = false) Integer pageSize,\r
- HttpServletRequest request,\r
- HttpServletResponse response)\r
- throws IOException {\r
-\r
- if(request != null){\r
- logger.info("getAccepted() " + requestPathAndQuery(request));\r
- }\r
-\r
- ModelAndView mv = new ModelAndView();\r
-\r
- PagerParameters pagerParams = new PagerParameters(pageSize, pageNumber);\r
- pagerParams.normalizeAndValidate(response);\r
-\r
- try {\r
- List<Taxon> resultset = service.listAcceptedTaxaFor(uuid, classification_uuid, pagerParams.getPageSize(), pagerParams.getPageIndex(), null, getInitializationStrategy());\r
- mv.addObject(resultset);\r
- } catch (EntityNotFoundException e){\r
- HttpStatusMessage.UUID_NOT_FOUND.send(response);\r
- }\r
-\r
- return mv;\r
- }\r
\r
/**\r
* Get the list of {@link TaxonRelationship}s for the given\r
return p.getRecords();\r
}\r
\r
+ @Override\r
@RequestMapping(value = "taxonNodes", method = RequestMethod.GET)\r
public Set<TaxonNode> doGetTaxonNodes(\r
@PathVariable("uuid") UUID uuid,\r