3 * Copyright (C) 2007 EDIT
4 * European Distributed Institute of Taxonomy
5 * http://www.e-taxonomy.eu
7 * The contents of this file are subject to the Mozilla Public License Version 1.1
8 * See LICENSE.TXT at the top of this package for the full license terms.
11 package eu
.etaxonomy
.cdm
.remote
.controller
;
13 import java
.io
.IOException
;
14 import java
.util
.Arrays
;
15 import java
.util
.List
;
16 import java
.util
.UUID
;
18 import javax
.servlet
.http
.HttpServletRequest
;
19 import javax
.servlet
.http
.HttpServletResponse
;
21 import org
.springframework
.beans
.factory
.annotation
.Autowired
;
22 import org
.springframework
.stereotype
.Controller
;
23 import org
.springframework
.web
.bind
.annotation
.PathVariable
;
24 import org
.springframework
.web
.bind
.annotation
.RequestMapping
;
25 import org
.springframework
.web
.bind
.annotation
.RequestMethod
;
26 import org
.springframework
.web
.servlet
.ModelAndView
;
28 import eu
.etaxonomy
.cdm
.api
.service
.IDescriptionService
;
29 import eu
.etaxonomy
.cdm
.api
.service
.INameService
;
30 import eu
.etaxonomy
.cdm
.api
.service
.pager
.Pager
;
31 import eu
.etaxonomy
.cdm
.database
.UpdatableRoutingDataSource
;
32 import eu
.etaxonomy
.cdm
.model
.description
.TaxonNameDescription
;
33 import eu
.etaxonomy
.cdm
.model
.name
.TaxonNameBase
;
34 import eu
.etaxonomy
.cdm
.model
.name
.TypeDesignationBase
;
37 * The NamePortalController class is a Spring MVC Controller.
39 * The syntax of the mapped service URIs contains the the {datasource-name} path element.
40 * The available {datasource-name}s are defined in a configuration file which
41 * is loaded by the {@link UpdatableRoutingDataSource}. If the
42 * UpdatableRoutingDataSource is not being used in the actual application
43 * context any arbitrary {datasource-name} may be used.
45 * Methods mapped at type level, inherited from super classes ({@link BaseController}):
47 * URI: <b>/{datasource-name}/portal/name/{name-uuid}</b>
49 * Get the {@link TaxonNameBase} instance identified by the <code>{name-uuid}</code>.
50 * The returned TaxonNameBase is initialized by
51 * the following strategy: -- NONE --
54 * @author a.kohlbecker
59 @RequestMapping(value
= {"/portal/name/{uuid}"})
60 public class NamePortalController
extends BaseController
<TaxonNameBase
, INameService
>
63 private static final List
<String
> TYPEDESIGNATION_INIT_STRATEGY
= Arrays
.asList(new String
[]{
66 "typeStatus.representations",
67 "typifiedNames.nomenclaturalReference.authorTeam",
68 "citation.authorTeam.$",
73 private static final List
<String
> NAMEDESCRIPTION_INIT_STRATEGY
= Arrays
.asList(new String
[]{
77 "elements.multilanguageText",
82 // public NamePortalController(){
84 // setInitializationStrategy(Arrays.asList(new String[]{"$"})); //TODO required???
88 * @see eu.etaxonomy.cdm.remote.controller.GenericController#setService(eu.etaxonomy.cdm.api.service.IService)
92 public void setService(INameService service
) {
93 this.service
= service
;
97 private IDescriptionService descriptionService
;
100 * Get the list of {@link TypeDesignationBase}s of the
101 * {@link TaxonNameBase} instance identified by the <code>{name-uuid}</code>.
103 * URI: <b>/{datasource-name}/portal/name/{name-uuid}/typeDesignations</b>
107 * @return a List of {@link TypeDesignationBase} entities which are initialized
108 * using the following initialization strategy:
109 * {@link #TYPEDESIGNATION_INIT_STRATEGY}
110 * @throws IOException
112 @SuppressWarnings("unchecked")
114 value
= {"typeDesignations"},
115 method
= RequestMethod
.GET
)
116 public List
<TypeDesignationBase
> doGetTypeDesignations(@PathVariable("uuid") UUID uuid
,
117 HttpServletRequest request
, HttpServletResponse response
)throws IOException
{
118 ModelAndView mv
= new ModelAndView();
119 TaxonNameBase tnb
= getCdmBaseInstance(uuid
, response
, (List
<String
>)null);
120 Pager
<TypeDesignationBase
> p
= service
.getTypeDesignations(tnb
, null, null, null, TYPEDESIGNATION_INIT_STRATEGY
);
121 return p
.getRecords();
125 * Get the list of {@link TaxonNameDescription}s of the Name associated with the
126 * {@link TaxonNameBase} instance identified by the <code>{name-uuid}</code>.
128 * URI: <b>/{datasource-name}/portal/name/{name-uuid}/descriptions</b>
132 * @return a List of {@link TaxonNameDescription} entities which are initialized
133 * using the following initialization strategy:
134 * {@link #NAMEDESCRIPTION_INIT_STRATEGY}
135 * @throws IOException
138 value
= {"taxonNameDescriptions"},
139 method
= RequestMethod
.GET
)
140 public List
<TaxonNameDescription
> doGetNameDescriptions(@PathVariable("uuid") UUID uuid
,
141 HttpServletRequest request
, HttpServletResponse response
)throws IOException
{
142 logger
.info("doGetNameDescriptions()" + request
.getRequestURI());
143 TaxonNameBase tnb
= service
.load(uuid
, null);
144 Pager
<TaxonNameDescription
> p
= descriptionService
.getTaxonNameDescriptions(tnb
, null, null, NAMEDESCRIPTION_INIT_STRATEGY
);
145 return p
.getRecords();