-
Notifications
You must be signed in to change notification settings - Fork 7
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
Catalog resolution problems when running on AWS Lambda #2
Comments
Hi Keith, Sorry that getting it to run caused so much trouble so far. I see that you are using Calabash for Saxon 9.9. There have been some issues with Saxon 9.9. (and base URIs in particular) that I didn’t manage to look into for some time now. On the other hand idml2xml-frontend is configured to use a calabash-frontend branch as a submodule, and it seems to use a Saxon 9.9 Calabash, so I guess that it should be working in principle. I see that the steps can be located using catalog resolution. I wonder why |
Maybe there is no |
Thank you for the suggestions. I've uncommented the message you suggested and included the output logs here (it does seem to have a
|
Apparently |
I committed something. Can you pull xproc-util and xslt-util manually and see whether it will improve things? |
The issue is resolved after updating those three files you modified in xproc-util and xslt-util yesterday and I'm now getting Hub XML out of Lambda. Thanks! I appreciate you jumping on this issue so quickly. |
Despite a cold and an imminent wedding party, I might add! Filename to URI conversion will be a standard function of XProc 3.0. We will eventually migrate all transpect libraries to XProc 3.0, keeping the current modules in maintenance mode. There will be a migration tool for 1.0 pipelines. If you use non-XProc tools to postprocess the flat, DocBook-based XML that comes out of idml2xml, you won’t need to migrate that many pipelines though. You just wait until idml2xml-frontend gets migrated. |
Thanks for all your work on this family of libraries. Please let me know if you'd prefer this Issue was filed inside another project.
I'm trying to create an environment to run the idml2xml pipeline inside AWS Lambda and have found the configuration process quite challenging. The latest problem: in some cases catalog-powered URI resolution errors when it gets an encoded
%2F
value instead of the/
it expects.I would like your guidance on how to continue debugging this issue.
Here's the details I think I've established:
When the Lambda function that runs this pipeline is invoked locally (
sam local invoke --event events/S3SampleEvent.json
), the filesystem is configured as expected (by something) and completes the Lambda function invocation as expected. Good.When the function runs on the real Lambda environment, the configuration is somehow different. Bad. A
%2F
value is sometimes passed as a valid$catalog-resolved-uri
value and the system (Saxon) errors (extra<cx:message>
added by me):analyze filename
inxproc-util/file-uri/xpl/file-uri.xpl
, where I added the<cx:message>
shown above:xproc-util/file-uri/xpl/file-uri.xpl
to add a case just for this:JAVA_TOOL_OPTIONS
include-Dxml.catalog.files=/var/task/calabash/xmlcatalog/catalog.xml
and that part seems (?) to be working:What would you recommend to debug this further?
Apologies on the length of this report, but I wanted to add the context I have. My partially working code is here, although I've (clumsily, given my lack of proficiency with Java) tried to do as little as possible to get Calabash and idml2xml-frontend running as possible: https://github.com/codeburl/transpect-on-lambda
The text was updated successfully, but these errors were encountered: