geosolutions-it / evo-odas

Code Repository for the EVO-ODAS
https://waffle.io/geosolutions-it/evo-odas
MIT License
31 stars 15 forks source link

TC-46 Multidimensional WMTS domain discovery #265

Closed randomorder closed 6 years ago

randomorder commented 6 years ago

We should discuss the status of support for multidimensional WMTS domain discovery in GeoServer as per TC-46. @torse reported now working using GeoServer WMTS module ( (http://docs.geoserver.org/latest/en/user/community/wmts-multidimensional/index.html )

The tested request is:

http://oda.dlr.de/geoserver/gwc/service/wmts?REQUEST=DescribeDomains&Version=1.0.0&Layer=evoodas:S2_MSI_L1C_TCI&TileMatrixSet=EPSG:4326

With following response

<ExceptionReport xmlns="http://www.opengis.net/ows/1.1" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="1.1.0" xsi:schemaLocation="http://www.opengis.net/ows/1.1 http://geowebcache.org/schema/ows/1.1.0/owsExceptionReport.xsd">

<Exception exceptionCode="NoApplicableCode" locator="">
<ExceptionText>
Error executing describe domains operation:java.lang.RuntimeException: Error reading domain values.
</ExceptionText>
</Exception>
</ExceptionReport>

And log message:

geoserver_1 | ERROR: 'Error reading domain values.' geoserver_1 | 25 Oct 15:35:26 ERROR [gwc.wmts] - Error executing describe domains operation. geoserver_1 | javax.xml.transform.TransformerException: java.lang.RuntimeException: Error reading domain values. geoserver_1 | at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:746) geoserver_1 | at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:351) geoserver_1 | at org.geotools.xml.transform.TransformerBase$Task.run(TransformerBase.java:300) geoserver_1 | at org.geotools.xml.transform.TransformerBase.transform(TransformerBase.java:133) geoserver_1 | at org.geotools.xml.transform.TransformerBase.transform(TransformerBase.java:112) geoserver_1 | at org.geoserver.gwc.wmts.MultiDimensionalExtension.executeDescribeDomainsOperation(MultiDimensionalExtension.java:179) geoserver_1 | at org.geoserver.gwc.wmts.MultiDimensionalExtension.handleRequest(MultiDimensionalExtension.java:101) geoserver_1 | at org.geowebcache.service.wmts.WMTSService.handleRequest(WMTSService.java:300) geoserver_1 | at org.geowebcache.service.wmts.WMTSService$$FastClassBySpringCGLIB$$e221a779.invoke(<generated>) geoserver_1 | at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) geoserver_1 | at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:721) geoserver_1 | at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157) geoserver_1 | at org.geoserver.gwc.config.GWCServiceEnablementInterceptor.invoke(GWCServiceEnablementInterceptor.java:57) geoserver_1 | at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) geoserver_1 | at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:656) geoserver_1 | at org.geowebcache.service.wmts.WMTSService$$EnhancerBySpringCGLIB$$8c666fc3.handleRequest(<generated>) geoserver_1 | at org.geowebcache.GeoWebCacheDispatcher.handleServiceRequest(GeoWebCacheDispatcher.java:375) geoserver_1 | at org.geowebcache.GeoWebCacheDispatcher.handleRequestInternal(GeoWebCacheDispatcher.java:270) geoserver_1 | at org.springframework.web.servlet.mvc.AbstractController.handleRequest(AbstractController.java:174) geoserver_1 | at org.geoserver.gwc.dispatch.GwcServiceProxy.dispatch(GwcServiceProxy.java:95) geoserver_1 | at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) geoserver_1 | at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) geoserver_1 | at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) geoserver_1 | at java.lang.reflect.Method.invoke(Method.java:498) geoserver_1 | at org.geoserver.ows.Dispatcher.execute(Dispatcher.java:857) geoserver_1 | at org.geoserver.ows.Dispatcher.handleRequestInternal(Dispatcher.java:268) geoserver_1 | at org.springframework.web.servlet.mvc.AbstractController.handleRequest(AbstractController.java:174) geoserver_1 | at org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter.handle(SimpleControllerHandlerAdapter.java:50) geoserver_1 | at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:963) geoserver_1 | at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:897) geoserver_1 | at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) geoserver_1 | at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861) geoserver_1 | at javax.servlet.http.HttpServlet.service(HttpServlet.java:635) geoserver_1 | at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) geoserver_1 | at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.ThreadLocalsCleanupFilter.doFilter(ThreadLocalsCleanupFilter.java:28) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:75) geoserver_1 | at org.geoserver.wms.animate.AnimatorFilter.doFilter(AnimatorFilter.java:71) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.opensearch.eo.OSEOFilter.doFilter(OSEOFilter.java:41) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.flow.controller.IpBlacklistFilter.doFilter(IpBlacklistFilter.java:94) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.flow.ControlFlowCallback.doFilter(ControlFlowCallback.java:245) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.params.extractor.Filter.doFilter(Filter.java:56) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter.doFilter(SpringDelegatingFilter.java:46) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.platform.AdvancedDispatchFilter.doFilter(AdvancedDispatchFilter.java:50) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:316) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:126) geoserver_1 | at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:90) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:114) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerAnonymousAuthenticationFilter.doFilter(GeoServerAnonymousAuthenticationFilter.java:54) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.authentication.www.BasicAuthenticationFilter.doFilterInternal(BasicAuthenticationFilter.java:158) geoserver_1 | at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.geoserver.security.filter.GeoServerBasicAuthenticationFilter.doFilter(GeoServerBasicAuthenticationFilter.java:84) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91) geoserver_1 | at org.geoserver.security.filter.GeoServerSecurityContextPersistenceFilter$1.doFilter(GeoServerSecurityContextPersistenceFilter.java:53) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213) geoserver_1 | at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176) geoserver_1 | at org.geoserver.security.GeoServerSecurityFilterChainProxy.doFilter(GeoServerSecurityFilterChainProxy.java:152) geoserver_1 | at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) geoserver_1 | at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.LoggingFilter.doFilter(LoggingFilter.java:88) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.XFrameOptionsFilter.doFilter(XFrameOptionsFilter.java:89) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.GZIPFilter.doFilter(GZIPFilter.java:42) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.SessionDebugFilter.doFilter(SessionDebugFilter.java:48) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.FlushSafeFilter.doFilter(FlushSafeFilter.java:44) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197) geoserver_1 | at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198) geoserver_1 | at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) geoserver_1 | at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478) geoserver_1 | at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140) geoserver_1 | at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80) geoserver_1 | at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650) geoserver_1 | at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) geoserver_1 | at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342) geoserver_1 | at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:799) geoserver_1 | at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) geoserver_1 | at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868) geoserver_1 | at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1457) geoserver_1 | at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) geoserver_1 | at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) geoserver_1 | at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) geoserver_1 | at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) geoserver_1 | at java.lang.Thread.run(Thread.java:745) geoserver_1 | Caused by: java.lang.RuntimeException: Error reading domain values. geoserver_1 | at org.geoserver.gwc.wmts.dimensions.CoverageDimensionsReader$WrapStructuredGridCoverageDimensions2DReader.getValues(CoverageDimensionsReader.java:162) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.CoverageDimensionsReader.readWithoutDuplicates(CoverageDimensionsReader.java:59) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.Dimension.getRasterDomainValues(Dimension.java:244) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.RasterTimeDimension.getDomainValues(RasterTimeDimension.java:34) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.Dimension.getDomainValuesAsStrings(Dimension.java:128) geoserver_1 | at org.geoserver.gwc.wmts.DescribeDomainsTransformer$TranslatorSupport.lambda$encode$0(DescribeDomainsTransformer.java:59) geoserver_1 | at java.util.ArrayList.forEach(ArrayList.java:1249) geoserver_1 | at org.geoserver.gwc.wmts.DescribeDomainsTransformer$TranslatorSupport.encode(DescribeDomainsTransformer.java:58) geoserver_1 | at org.geotools.xml.transform.TransformerBase$XMLReaderSupport.parse(TransformerBase.java:1026) geoserver_1 | at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transformIdentity(TransformerImpl.java:668) geoserver_1 | at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:737) geoserver_1 | ... 129 more geoserver_1 | Caused by: java.io.IOException geoserver_1 | at org.geotools.gce.imagemosaic.catalog.AbstractGTDataStoreGranuleCatalog.getGranules(AbstractGTDataStoreGranuleCatalog.java:502) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.RepositoryDataStoreCatalog.getGranules(RepositoryDataStoreCatalog.java:39) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.CachingDataStoreGranuleCatalog.getGranules(CachingDataStoreGranuleCatalog.java:128) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.GranuleCatalogSource.getGranules(GranuleCatalogSource.java:56) geoserver_1 | at org.geoserver.catalog.StructuredCoverageViewReader$GranuleStoreView.getGranules(StructuredCoverageViewReader.java:108) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.CoverageDimensionsReader$WrapStructuredGridCoverageDimensions2DReader.getValues(CoverageDimensionsReader.java:153) geoserver_1 | ... 139 more geoserver_1 | Caused by: java.io.IOException: Could not find a type name 'S2_MSI_L1C_TCI' geoserver_1 | at org.geotools.gce.imagemosaic.catalog.DataAccessStoreWrapper.getNameFromLocal(DataAccessStoreWrapper.java:140) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.DataAccessStoreWrapper.getFeatureSource(DataAccessStoreWrapper.java:123) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.AbstractGTDataStoreGranuleCatalog.getGranules(AbstractGTDataStoreGranuleCatalog.java:494) geoserver_1 | ... 144 more geoserver_1 | --------- geoserver_1 | java.lang.RuntimeException: Error reading domain values. geoserver_1 | at org.geoserver.gwc.wmts.dimensions.CoverageDimensionsReader$WrapStructuredGridCoverageDimensions2DReader.getValues(CoverageDimensionsReader.java:162) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.CoverageDimensionsReader.readWithoutDuplicates(CoverageDimensionsReader.java:59) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.Dimension.getRasterDomainValues(Dimension.java:244) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.RasterTimeDimension.getDomainValues(RasterTimeDimension.java:34) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.Dimension.getDomainValuesAsStrings(Dimension.java:128) geoserver_1 | at org.geoserver.gwc.wmts.DescribeDomainsTransformer$TranslatorSupport.lambda$encode$0(DescribeDomainsTransformer.java:59) geoserver_1 | at java.util.ArrayList.forEach(ArrayList.java:1249) geoserver_1 | at org.geoserver.gwc.wmts.DescribeDomainsTransformer$TranslatorSupport.encode(DescribeDomainsTransformer.java:58) geoserver_1 | at org.geotools.xml.transform.TransformerBase$XMLReaderSupport.parse(TransformerBase.java:1026) geoserver_1 | at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transformIdentity(TransformerImpl.java:668) geoserver_1 | at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:737) geoserver_1 | at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:351) geoserver_1 | at org.geotools.xml.transform.TransformerBase$Task.run(TransformerBase.java:300) geoserver_1 | at org.geotools.xml.transform.TransformerBase.transform(TransformerBase.java:133) geoserver_1 | at org.geotools.xml.transform.TransformerBase.transform(TransformerBase.java:112) geoserver_1 | at org.geoserver.gwc.wmts.MultiDimensionalExtension.executeDescribeDomainsOperation(MultiDimensionalExtension.java:179) geoserver_1 | at org.geoserver.gwc.wmts.MultiDimensionalExtension.handleRequest(MultiDimensionalExtension.java:101) geoserver_1 | at org.geowebcache.service.wmts.WMTSService.handleRequest(WMTSService.java:300) geoserver_1 | at org.geowebcache.service.wmts.WMTSService$$FastClassBySpringCGLIB$$e221a779.invoke(<generated>) geoserver_1 | at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) geoserver_1 | at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:721) geoserver_1 | at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157) geoserver_1 | at org.geoserver.gwc.config.GWCServiceEnablementInterceptor.invoke(GWCServiceEnablementInterceptor.java:57) geoserver_1 | at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) geoserver_1 | at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:656) geoserver_1 | at org.geowebcache.service.wmts.WMTSService$$EnhancerBySpringCGLIB$$8c666fc3.handleRequest(<generated>) geoserver_1 | at org.geowebcache.GeoWebCacheDispatcher.handleServiceRequest(GeoWebCacheDispatcher.java:375) geoserver_1 | at org.geowebcache.GeoWebCacheDispatcher.handleRequestInternal(GeoWebCacheDispatcher.java:270) geoserver_1 | at org.springframework.web.servlet.mvc.AbstractController.handleRequest(AbstractController.java:174) geoserver_1 | at org.geoserver.gwc.dispatch.GwcServiceProxy.dispatch(GwcServiceProxy.java:95) geoserver_1 | at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) geoserver_1 | at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) geoserver_1 | at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) geoserver_1 | at java.lang.reflect.Method.invoke(Method.java:498) geoserver_1 | at org.geoserver.ows.Dispatcher.execute(Dispatcher.java:857) geoserver_1 | at org.geoserver.ows.Dispatcher.handleRequestInternal(Dispatcher.java:268) geoserver_1 | at org.springframework.web.servlet.mvc.AbstractController.handleRequest(AbstractController.java:174) geoserver_1 | at org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter.handle(SimpleControllerHandlerAdapter.java:50) geoserver_1 | at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:963) geoserver_1 | at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:897) geoserver_1 | at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) geoserver_1 | at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:861) geoserver_1 | at javax.servlet.http.HttpServlet.service(HttpServlet.java:635) geoserver_1 | at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) geoserver_1 | at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.ThreadLocalsCleanupFilter.doFilter(ThreadLocalsCleanupFilter.java:28) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:75) geoserver_1 | at org.geoserver.wms.animate.AnimatorFilter.doFilter(AnimatorFilter.java:71) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.opensearch.eo.OSEOFilter.doFilter(OSEOFilter.java:41) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.flow.controller.IpBlacklistFilter.doFilter(IpBlacklistFilter.java:94) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.flow.ControlFlowCallback.doFilter(ControlFlowCallback.java:245) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.params.extractor.Filter.doFilter(Filter.java:56) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71) geoserver_1 | at org.geoserver.filters.SpringDelegatingFilter.doFilter(SpringDelegatingFilter.java:46) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.platform.AdvancedDispatchFilter.doFilter(AdvancedDispatchFilter.java:50) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:316) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:126) geoserver_1 | at org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:90) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:114) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerAnonymousAuthenticationFilter.doFilter(GeoServerAnonymousAuthenticationFilter.java:54) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.authentication.www.BasicAuthenticationFilter.doFilterInternal(BasicAuthenticationFilter.java:158) geoserver_1 | at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.geoserver.security.filter.GeoServerBasicAuthenticationFilter.doFilter(GeoServerBasicAuthenticationFilter.java:84) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69) geoserver_1 | at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91) geoserver_1 | at org.geoserver.security.filter.GeoServerSecurityContextPersistenceFilter$1.doFilter(GeoServerSecurityContextPersistenceFilter.java:53) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73) geoserver_1 | at org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92) geoserver_1 | at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330) geoserver_1 | at org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213) geoserver_1 | at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176) geoserver_1 | at org.geoserver.security.GeoServerSecurityFilterChainProxy.doFilter(GeoServerSecurityFilterChainProxy.java:152) geoserver_1 | at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) geoserver_1 | at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.LoggingFilter.doFilter(LoggingFilter.java:88) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.XFrameOptionsFilter.doFilter(XFrameOptionsFilter.java:89) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.GZIPFilter.doFilter(GZIPFilter.java:42) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.SessionDebugFilter.doFilter(SessionDebugFilter.java:48) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.geoserver.filters.FlushSafeFilter.doFilter(FlushSafeFilter.java:44) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197) geoserver_1 | at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) geoserver_1 | at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) geoserver_1 | at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198) geoserver_1 | at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) geoserver_1 | at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478) geoserver_1 | at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140) geoserver_1 | at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80) geoserver_1 | at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650) geoserver_1 | at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) geoserver_1 | at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342) geoserver_1 | at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:799) geoserver_1 | at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) geoserver_1 | at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868) geoserver_1 | at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1457) geoserver_1 | at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) geoserver_1 | at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) geoserver_1 | at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) geoserver_1 | at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) geoserver_1 | at java.lang.Thread.run(Thread.java:745) geoserver_1 | Caused by: java.io.IOException geoserver_1 | at org.geotools.gce.imagemosaic.catalog.AbstractGTDataStoreGranuleCatalog.getGranules(AbstractGTDataStoreGranuleCatalog.java:502) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.RepositoryDataStoreCatalog.getGranules(RepositoryDataStoreCatalog.java:39) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.CachingDataStoreGranuleCatalog.getGranules(CachingDataStoreGranuleCatalog.java:128) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.GranuleCatalogSource.getGranules(GranuleCatalogSource.java:56) geoserver_1 | at org.geoserver.catalog.StructuredCoverageViewReader$GranuleStoreView.getGranules(StructuredCoverageViewReader.java:108) geoserver_1 | at org.geoserver.gwc.wmts.dimensions.CoverageDimensionsReader$WrapStructuredGridCoverageDimensions2DReader.getValues(CoverageDimensionsReader.java:153) geoserver_1 | ... 139 more geoserver_1 | Caused by: java.io.IOException: Could not find a type name 'S2_MSI_L1C_TCI' geoserver_1 | at org.geotools.gce.imagemosaic.catalog.DataAccessStoreWrapper.getNameFromLocal(DataAccessStoreWrapper.java:140) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.DataAccessStoreWrapper.getFeatureSource(DataAccessStoreWrapper.java:123) geoserver_1 | at org.geotools.gce.imagemosaic.catalog.AbstractGTDataStoreGranuleCatalog.getGranules(AbstractGTDataStoreGranuleCatalog.java:494) geoserver_1 | ... 144 more

nmco commented 6 years ago

This error seems to happen when WMTS Multidimensional module tries to read the domain values of a certain dimension from a coverage:

https://github.com/nmco/geoserver/blob/3df5898c427a020ef8d625086df9b803af542d81/src/community/wmts-multi-dimensional/src/main/java/org/geoserver/gwc/wmts/dimensions/CoverageDimensionsReader.java#L153

The granules reader fails with this exception:

Caused by: java.io.IOException: Could not find a type name 'S2_MSI_L1C_TCI'
 at org.geotools.gce.imagemosaic.catalog.DataAccessStoreWrapper.getNameFromLocal(DataAccessStoreWrapper.java:140)
 at org.geotools.gce.imagemosaic.catalog.DataAccessStoreWrapper.getFeatureSource(DataAccessStoreWrapper.java:123)
 at org.geotools.gce.imagemosaic.catalog.AbstractGTDataStoreGranuleCatalog.getGranules(AbstractGTDataStoreGranuleCatalog.java:494)
 ... 144 more