Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

gbif repatriation service error 500 #234

Open
peggynewman opened this issue Mar 21, 2024 · 8 comments
Open

gbif repatriation service error 500 #234

peggynewman opened this issue Mar 21, 2024 · 8 comments
Assignees

Comments

@peggynewman
Copy link

Attempting to run a repatriation from GBIF for Australian data, selected 233 out of 236 data resources, clicked go, got an error:

https://collections-test.ala.org.au/manage/updateFromExternalSources

image
@adam-collins
Copy link
Contributor

The page posts a list of resources for processing. There is pagination. Only visible rows are included. When there are >1 pages it will show this error.

The removal of pagination is recommended as the solution. Is this acceptable? Note that the max number of rows is a parameter in an earlier page.

@adam-collins adam-collins self-assigned this Mar 26, 2024
@peggynewman
Copy link
Author

My goal is to download data resources from GBIF. I have to review them first.
I'm not sure what I'm agreeing to if I say that it's ok if I see 236 on the page at once. That's not a problem for me.

Or are you saying that I should do them one page at at time by specifying say 10 as the max number of rows? Or, should I set the max number of rows to 250? It's not clear to me what the parameters are.

@adam-collins
Copy link
Contributor

By removing the pagination it means that the page size combobox at the top of the page is removed, the pagination controls under the table are removed, and all records appear on the page potentially requiring scrolling to view all rows.

A workaround is to select a page size that exceeds or is equal to the rows. Some control is available with the prior page's max value
image

This problem is caused by DataTable removing items within a form. In addition to applying this change to repatriteReview, externalLoadReview was also changed as it has the same structure.

I have only tested locally.

Please test on collections-test.

@peggynewman
Copy link
Author

Will have to wait till I return from leave, but will do

@peggynewman
Copy link
Author

Exactly the same error on test

java.lang.NullPointerException: Cannot set property 'phase' on null object 
at au.org.ala.collectory.ExternalDataService$_updateFromExternalSources_closure2.doCall(ExternalDataService.groovy:83)
	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at au.org.ala.collectory.ExternalDataService.updateFromExternalSources(ExternalDataService.groovy:82)
	at au.org.ala.collectory.ManageController.updateFromExternalSources(ManageController.groovy:150)
	at org.grails.core.DefaultGrailsControllerClass$MethodHandleInvoker.invoke(DefaultGrailsControllerClass.java:223)
	at org.grails.core.DefaultGrailsControllerClass.invoke(DefaultGrailsControllerClass.java:188)
	at org.grails.web.mapping.mvc.UrlMappingsInfoHandlerAdapter.handle(UrlMappingsInfoHandlerAdapter.groovy:90)
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1072)
	at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:965)
	at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
	at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909)
	at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
	at org.grails.web.servlet.mvc.GrailsWebRequestFilter.doFilterInternal(GrailsWebRequestFilter.java:77)
	at au.org.ala.ws.security.Pac4jProfileManagerHttpRequestWrapperFilter.doFilter(Pac4jProfileManagerHttpRequestWrapperFilter.java:51)
	at au.org.ala.web.Pac4jHttpServletRequestWrapperFilter.internalFilter(Pac4jHttpServletRequestWrapperFilter.groovy:46)
	at org.pac4j.jee.config.AbstractConfigFilter.doFilter(AbstractConfigFilter.java:72)
	at org.pac4j.jee.filter.SecurityFilter.lambda$internalFilter$0(SecurityFilter.java:94)
	at org.pac4j.core.engine.DefaultSecurityLogic.perform(DefaultSecurityLogic.java:141)
	at org.pac4j.jee.filter.SecurityFilter.internalFilter(SecurityFilter.java:92)
	at au.org.ala.web.CooperatingFilterWrapper.doFilter(CooperatingFilterWrapper.groovy:31)
	at org.grails.web.filters.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:67)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:126)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter.access$000(ErrorPageFilter.java:64)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter$1.doFilterInternal(ErrorPageFilter.java:101)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:119)
	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
	at java.base/java.lang.Thread.run(Thread.java:829)

@adam-collins
Copy link
Contributor

The test failed because this branch was not merged. The page size drop down was still on the repatriation list. It was on hold for a few weeks and I got mixed up as to where it was up to. I gave up and just merged everything into the develop branch. It can be again tested now.

@peggynewman
Copy link
Author

Tested and getting a bit further now; we end up on a screen with a list of the datasets, all marked with a red "error". The data resources are created but no connection parameters are populated.
@adam-collins @CamSlatyer

@peggynewman
Copy link
Author

peggynewman commented Dec 20, 2024

In production, we've successfully run a number of these

A few problems:

  1. This page no longer shows anything useful about the datasets generated https://collections.ala.org.au/manage/externalLoadStatus?loadGuid=03e2a0f1-a0f1-4627-8610-89011046a272

  2. Some datasets are created as duplicates, I think especially if the occurrence records didn't get loaded the first time. See:

  1. Troubleshooting an empty dataset eg https://collections.ala.org.au/dataResource/show/dr29607, go to the Data Mobilisation section and click 'Reload from GBIF' results in a nasty error
image Stack trace:
groovy.lang.MissingMethodException: No signature of method: ch.qos.logback.classic.Logger.debug() is applicable for argument types: (au.org.ala.collectory.GBIFActiveLoad) values: [au.org.ala.collectory.GBIFActiveLoad(gbifResourceUid:865df020-f762-11e1-a439-00145eb45e9a, phase:<NOT STARTED>, repatriationCountry:AU)]
Possible solutions: debug(java.lang.String), debug(java.lang.String, [Ljava.lang.Object;), debug(java.lang.String, java.lang.Object), debug(java.lang.String, java.lang.Throwable), debug(org.slf4j.Marker, java.lang.String), debug(java.lang.String, java.lang.Object, java.lang.Object)
	at au.org.ala.collectory.ManageController.gbifDatasetLoadStatus(ManageController.groovy:178)
	at org.grails.core.DefaultGrailsControllerClass$MethodHandleInvoker.invoke(DefaultGrailsControllerClass.java:223)
	at org.grails.core.DefaultGrailsControllerClass.invoke(DefaultGrailsControllerClass.java:188)
	at org.grails.web.mapping.mvc.UrlMappingsInfoHandlerAdapter.handle(UrlMappingsInfoHandlerAdapter.groovy:90)
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1072)
	at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:965)
	at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
	at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:898)
	at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
	at org.grails.web.servlet.mvc.GrailsWebRequestFilter.doFilterInternal(GrailsWebRequestFilter.java:77)
	at au.org.ala.ws.security.Pac4jProfileManagerHttpRequestWrapperFilter.doFilter(Pac4jProfileManagerHttpRequestWrapperFilter.java:51)
	at au.org.ala.web.Pac4jHttpServletRequestWrapperFilter.internalFilter(Pac4jHttpServletRequestWrapperFilter.groovy:46)
	at org.pac4j.jee.config.AbstractConfigFilter.doFilter(AbstractConfigFilter.java:72)
	at org.pac4j.jee.filter.SecurityFilter.lambda$internalFilter$0(SecurityFilter.java:94)
	at org.pac4j.core.engine.DefaultSecurityLogic.perform(DefaultSecurityLogic.java:141)
	at org.pac4j.jee.filter.SecurityFilter.internalFilter(SecurityFilter.java:92)
	at org.pac4j.jee.config.AbstractConfigFilter.doFilter(AbstractConfigFilter.java:72)
	at au.org.ala.web.CooperatingFilterWrapper.doFilter(CooperatingFilterWrapper.groovy:31)
	at org.grails.web.filters.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:67)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:126)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter.access$000(ErrorPageFilter.java:64)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter$1.doFilterInternal(ErrorPageFilter.java:101)
	at org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:119)
	at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
	at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
	at java.base/java.lang.Thread.run(Thread.java:829)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants