InfoPath Notes
This page is outdated and no longer receives updates!
Contents
- 1 Contents
- 2 InfoPath Resources
- 3 Form Entry Use Cases
- 4 Troubleshooting
- 4.1 ClassCastException while trying to Download Schema
- 4.2 Permission Denied error when using taskpane
- 4.3 Login required when searching from taskpane
- 4.4 Same scope elements with the same name
- 4.5 When submitting an infopath form the message "form submitted successfully" appears but the data does not go into the database
- 4.6 Multiple validation errors in infopath in different locales
- 4.7 After doing an upgrade, on form sumbit, you get schema item does not match DTD definition error
InfoPath Resources
Form Entry Use Cases
Complete Form Entry Use Case
Complete Login use case.
Select Form Entry use case.
Enter patient name in search box.
System will retrieve all patients matching the entered search term.
Select appropriate form.
A request for /openmrs/formDownloadServlet is sent to server. FormDownloadServlet handles request and generates an XML response that contains the form schema (xsd) along with information that will tell the browser to open InfoPath to display the form. Unless previously instructed, the browser will prompt you to Open or Save the document. The XML below helps the browser figure out what it needs to do with the response.
<?xml version="1.0"?>
<?mso-infoPathSolution name="Demo Form" href="http://localhost:8080/openmrs/formentry/forms/DemoForm.xsn" solutionVersion="" productVersion="11.0.6357" PIVersion="1.0.0.0" ?>
<?mso-application progid="InfoPath.Document"?>
Select the "Open with InfoPath" option.
InfoPath will look for the XSN form at http://localhost:8080/openmrs/formentry/forms/DemoForm.xsn and attempt to open it. If successful, the form will be displayed. Otherwise, InfoPath will display an error message. See InfoPath_Notes#Troubleshooting for more information on specific errors.
Enter data into the form. This may require stepping through several pages of a form.
Select Submit button on last page of form.
InfoPath POSTs a request containing your form data to the FormUploadServlet.
FormUploadServlet creates a FormEntryQueue record, sets its XML data field with XML form data from the post, and stores the FormEntryQueue in the database.
Process Form Entry Queue Use Case
Scheduler spawns a ProcessFormEntryQueueTask every X seconds.
ProcessFormEntryQueueTask delegates to FormEntryQueueProcessor.
FormEntryQueueProcessor iterates through the FormEntryQueue.
FormEntryQueueProcessor transforms XML data in FormEntryQueue using an XSLT associated with the given form.
FormEntryQueueProcessor creates and stores the HL7InQueue record.
Process HL7 Queue Use Case
Scheduler spawns a ProcessHL7InQueueTask every X seconds.
ProcessHL7InQueueTask calls HL7InQueueProcessor.
HL7InQueueProcessor iterates through the HL7InQueue
HL7InQueueProcessor processes all HL7InQueue records.
HL7InQueueProcessor creates an Encounter and Observations based on the HL7 messages in the queue.
Troubleshooting
If InfoPath is not behaving as expected (changes aren't being reflected, etc), the problem can often be solved by clearing the cache. You can run the following on the Windows command line or create a batch file.
"C:\Program Files\Microsoft Office\OFFICE11\infopath.exe" /cache ClearAll
ClassCastException while trying to Download Schema
Problem
DEBUG 03.01 - (HibernateConceptDAO.java:getConceptNumeric:516) Getting CONCEPT_NUMERIC 856
WARN 03.01 - (StatefulPersistenceContext.java:narrowProxy:581) Narrowing proxy to class org.openmrs.ConceptNumeric - this operation breaks h1. ERROR 03.01 - (StandardWrapperValve.java:invoke:260) Servlet.service() for servlet formDownloadServlet threw exception
java.lang.ClassCastException: org.openmrs.Concept
at org.openmrs.api.db.hibernate.HibernateConceptDAO.getConceptNumeric(HibernateConceptDAO.java:519)
at org.openmrs.api.impl.ConceptServiceImpl.getConceptNumeric(ConceptServiceImpl.java:285)
at org.openmrs.formentry.FormSchemaBuilder.getSchema(FormSchemaBuilder.java:135)
at org.openmrs.formentry.FormDownloadServlet.doGet(FormDownloadServlet.java:115)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:252)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)
at org.openmrs.web.OpenmrsFilter.doFilter(OpenmrsFilter.java:77)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:202)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:178)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:126)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:107)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:869)
at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:664)
at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:527)
at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:80)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:684)
at java.lang.Thread.run(Unknown Source)
Solution
No solution yet. It first appeared that this was caused by a missing concept_numeric row (concept with datatype Numeric does not have a concept_numeric row). However, I've tested this theory and it now appears that I am not correct. Note the error before the exception ("Narrowing proxy to class org.openmrs.ConceptNumeric - this operation breaks"). This is just a warning, but might have something to do with the exception.
Partial solution. It seems that this problem is a side effect of a problem with fetching ConceptNumeric objects out of Hibernate's cache. If the concept has already been loaded into the cache as a Concept object, then the request for the matching ConceptNumeric returns a Concept object instead...leading to the CastCastException. This has been temporarily solved by (1) a hack in the ConceptService that refetches a ConceptNumeric object if necessary and by (2) re-arranging the schema generation so that the affected code is performed last (right before the request is completed). We are still working on (in need of) a cleaner fix.
Comments
ConceptNumeric extends Concept.
Permission Denied error when using taskpane
Problem
When opening the taskpane either in preview or edit mode, you receive:
A Runtime Error has occurred
Error: Permission Denied
This will usually occur when accessing the xml dom using:
Solution
Change your Internet Security settings:
Make sure http://localhost(or your site url) is a "Trusted Site".
(In Infopath menu) Tools -> Options -> Internet Options
Click on the Security tab
Select "Trusted Sites"
Click "Sites" button
Add http://localhost (or your site url) if it is not there
Click Ok
Make sure your "Trusted Sites" can do cross-site scripting
(In Infopath menu) Tools -> Options -> Internet Options
Click on the Security tab
Select "Trusted Sites"
Click "Custom Level"
In Miscellaneous --> Access data sources across domains
Check "Enable"
Click Ok
Login required when searching from taskpane
Problem
When opening the taskpane for a search (such as for looking up the location or a new problem) you are required to login again. When completing the form and returning to the the main OpenMRS application you are also requested to login again.
Solution
Ensure that you are using the correct URL for OpenMRS. If you have set a specific URL for infopath forms in the global properties table (so that you can access forms over a LAN, for example) be sure to use the same URL when opening OpenMRS from the local machine.
In other words, if you have a fixed IP for the server in the formentry.infopath_server_url property, don't use
http://localhost:8080/openmrs
to browse/view/open the web application, use the fixed IP you placed in the global property.
This problem also appeared when migrating to Spring 2.5 due to a reversal in the order in which module's urlMappings and the core's urlMapping are loaded. Upgrading your modules and the openMRS core to the latest builds should fix the problem. Technically, the error can be fixed by adding the 'order' property to the urlMapping beans for both the core and all modules, where the modules have a lower value than the openMRS core.
Same scope elements with the same name
Problem
When opening an InfoPath document, it reports an error of this kind.
Solution
Back up your database and run the following SQL script.
When submitting an infopath form the message "form submitted successfully" appears but the data does not go into the database
Problem
When you submit an infopath form the message "form submitted successfully" appears. However when you go to the encounter list for the patient you just entered a form for, the encounter does not appear, even after waiting a few minutes. This can be caused by the "Process Form Entry Queue" task or the "Process HL7" task not being turned on in the scheduler.
Solution
Go to "Administration" and click "Manage Scheduler". For the two tasks "Process Form Entry Queue" and "Process HL7", check that "start on startup" is true and "running" is true. If "running" is false, tick the task and click "start". If "start on startup" is false, click the task name, click "schedule", tick "start on startup" and save.
Multiple validation errors in infopath in different locales
Problem
When you open an Infopath form to perform data entry, almost every non-free-text field in the form gives validation errors.
Solution
This can occur because the form's xsn has been rebuilt in a different locale than the locale originally used to design the form in Infopath. During the 'rebuild xsn' process, the form's xsd file is updated to reflect the current locale, but the original data bindings in the pageXX.xsl files are not updated. To solve this, change your locale to the same locale that was used when the form was designed originally, rebuild the form, and the switch back to your desired locale.
After doing an upgrade, on form sumbit, you get schema item does not match DTD definition error
Problem
After upgrading from openmrs 1.4 to openmrs 1.6, we ran into a problem where forms could not be sumitted, and we were getting an error that our schema definition didn't correspond to the DTD definition of a specific element.
Solution
This has something to do with a DTD change for how infopath marks insertion points for repeating tables. After upgrading from 1.4 to 1.6, we had to identify all the infopath forms in our system that contained repeating tables, and download the xsn, resave on the desktop with a new filename, and then re-upload.