Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...


mod-data-export-worker is intended to receive events from mod-data-export-spring,andexecute its jobs. The module is built based on Spring Batch Framework, and jobs are configured by a set of steps. The execution of a job happens in 3-stages: retrieve data, process data, and write data to the temporary file. Uploading files to some vendor-specific storage (AWS S3 bucket) is preconfigured already by the listener and happens when the file is completely written.
What should be done in this module:
      - create a Reader extending base functionality (CsvItemReader.java, see CirculationLogCsvItemReader.java as an example). The reader should retrieve packages/titles using REST clients, taking search parameters from the incoming Kafka event (from job parameters);
      - create a Processor (implementing ItemProcessor). The processor has to take only selected fields for export from the incoming packages/titles. The list of fields for export comes from job parameters; [Use 2 processors]
      - create a Writer extending base functionality (we can just use CsvWriter.java if nothing special is needed);
      - create a Configurationto Configuration to build a job and set Reader, Writer, and Processor (see CirculationLogJobConfig.java);
      - configure a cleaner to purge deprecated files (that we generated more than 30 days back);

Jira Legacy
serverSystem Jira
serverId01505d01-b853-3c2e-90f1-ee9b165564fc
keyMODEXPW-107


ui-eholdings will be able to create and send the export jobs from UI
      What should be done in this module:
        - store the fields available to export (see attached user story);
        - send jobs to mod-data-export-spring;
        - show a green toast message with the name of generating file, and the approximate duration of export. Duration is defined based on the number of records for export;

...