public virtual void ExportBatch(SIEESettings settings, SIEEBatch batch) { if (!isInitialized) { Init(settings); isInitialized = true; } try { foreach (SIEEDocument doc in batch) { try { ExportDocument(settings, doc, getDocumentName(settings, doc), doc.Fieldlist); doc.Succeeded = true; } catch (Exception e) { Trace.WriteError("SIEEExport failed for batch " + doc.BatchId); Trace.WriteError(e.ToString()); doc.Succeeded = false; doc.ErrorMsg = e.ToString(); } } } finally { Term(); } }
private void btn_capture_Click(object sender, EventArgs e) { Capture captureDlg = new Capture(settings, schema); captureDlg.DefaultFieldValues = defaultFieldValues; captureDlg.DefaultDocument = defaultDocument; if (Properties.Settings.Default.CaptuerSize.Width != 0) { captureDlg.Size = Properties.Settings.Default.CaptuerSize; } if (captureDlg.MyShowDialog() == DialogResult.OK) { btn_export.Enabled = true; lbl_message.Text = "Data"; batch = captureDlg.GetData(); document = captureDlg.GetDocument(); richTextBox_settings.Text = batch.ToString(); lbl_status.Text = batch.Count + " document(s) ready for export"; } Properties.Settings.Default.CaptuerSize = captureDlg.Size; //captureDlg.Dispose(); }
public override XmlDocument transform(XmlDocument data, IParameters parameters) { // The SIEEBatch is created from the schema as defined in the setting object. It contains all // fields regardless of whether they have been mapped to OCC fields. SIEEFieldlist schema = (SIEEFieldlist)SIEESerializer.StringToObject(writerSettings.SerializedSchema); // This class has no initialization by which the factory could be set beforehand. We therefore // load the factory from the SIEE_FactoryManager. (This was the only reason to invent the // SIEE_FactoryManager in the first place. SIEEFactory factory = SIEEFactoryManager.GetFromSettingsTypename(writerSettings.SettingsTypename); writerSettings.SetFactory(factory); // Create the SIEE objects wee need SIEEExport myExport = factory.CreateExport(); SIEEDescription description = factory.CreateDescription(); DataPool pool = new DataPool(data); SIEEBatch batch = new SIEEBatch(); int maxRetryCount = description.NumberOfRetries; string batchId = pool.RootNode.Fields["cc_BatchId"].Value; string profile = pool.RootNode.Fields["cc_ProfileName"].Value; SIEEExport.Trace.WriteInfo("Start exporting batch " + batchId); ExportStateParams exportStateParams = null; Dictionary <SIEEDocument, Document> siee2dataPool = new Dictionary <SIEEDocument, Document>(); Dictionary <SIEEDocument, int> annotationNumber = new Dictionary <SIEEDocument, int>(); for (int i = 0; i < pool.RootNode.Documents.Count; i++) { Document document = pool.RootNode.Documents[i]; SIEEDocument sieeDocument = documentToFieldlist(new SIEEFieldlist(schema), document, batchId, profile); sieeDocument.DocumentId = String.Format("{0:D4}", i); sieeDocument.DocumentClass = document.Name; sieeDocument.SIEEAnnotation = sieeDocument.NewSIEEAnnotation = null; int anNo = findAnnotation(document); annotationNumber[sieeDocument] = anNo; if (anNo != 0) { sieeDocument.SIEEAnnotation = document.Annotations[annotationName(anNo - 1)].Value; } exportStateParams = DataPoolWorkflowStateExtensions.GetExportStateParams(document); // Process only documents with state "ToBeProcessed" (not yet exported documents or documents whose export failed). if (exportStateParams.state == ExportState.ToBeProcessed) { siee2dataPool[sieeDocument] = document; batch.Add(sieeDocument); } } try { SIEESettings settings = writerSettings.GetEmbeddedSettings(); myExport.ExportBatch(settings, batch); } catch (Exception e) { SIEEExport.Trace.WriteError("SIEEWriterExport: Batch " + batchId + " failed", e); throw; } foreach (SIEEDocument doc in batch) { Document occDocument = siee2dataPool[doc]; int anNo = annotationNumber[doc]; if (doc.NewSIEEAnnotation != null) { occDocument.Annotations.Add(new Annotation(pool, annotationName(anNo), doc.NewSIEEAnnotation)); } exportStateParams = DataPoolWorkflowStateExtensions.GetExportStateParams(occDocument); if (doc.Succeeded) { occDocument.Annotations.Add(new Annotation(pool, "TargetDocumentId", doc.TargetDocumentId)); occDocument.Annotations.Add(new Annotation(pool, "TargetType", description.TypeName)); exportStateParams.state = ExportState.Succeeded; } else { exportStateParams.message = "Export failed: " + doc.ErrorMsg; if (doc.NonRecoverableError) { throw new Exception("Fatal export error: " + doc.ErrorMsg); } } // Set delay time for start of retry if (exportStateParams.repetitionCount == 0) { exportStateParams.delaySeconds = description.StartTimeForRetry; } DataPoolWorkflowStateExtensions.HandleExportStateParams(occDocument, maxRetryCount, exportStateParams); } SIEEExport.Trace.WriteInfo("Done exporting batch " + batchId); return(data); }