场景:我已经坚持了很长时间,我认为解决方案可能很容易,但我看不到它,这就是场景:
cURL POST to http://localhost:8080/my_imports (raw JSON data on body)
->
MyImportsCustomHandler (extends ThreadedHttpRequestHandler [Validations]
->
MyObjectProcessor (extends Processor) [JSON deserialize and data massage]
->
MyFirstDocumentProcessor (extends DocumentProcessor) [Set some fields and save]
问题是执行永远不会到达MyFirstDocumentProcessor
,可能是因为请求不是从document_api
端点开始的(故意)。没有抛出错误,只是处理路线永远不会到达文档处理器链,我认为应该是因为MyObjectProcessor
我正在做:
DocumentType type =
localDocHandler.getDocumentTypeManager().getDocumentType("my_doc");
DocumentId id = new DocumentId("id:default:my_doc::2");
Document document = new Document(type, id);
DocumentPut docPut = new DocumentPut(document);
Processing proc = com.yahoo.docproc.Processing.of(docPut);
我从这里得到了这个想法:https ://github.com/vespa-engine/vespa/blob/master/docproc/src/test/java/com/yahoo/docproc/util/SplitterJoinerTestCase.java
但在那个测试中我看到了这条线splitter.process(p);
,我无法找到在处理器内工作的合适替代品,在这种情况下,我只有Request
,Execution
和DocumentProcessingHandler
我希望精通 Vespa con 的人对此有所了解,这只是我无法桥接的处理链上的最后一跳:|