Skip to content

Latest commit

 

History

History
124 lines (94 loc) · 5.78 KB

Readme.md

File metadata and controls

124 lines (94 loc) · 5.78 KB

DELIS

ERST integration of eDelivery and eInvoicing

This is the code repository for DELIS, the integration of eDelivery and eInvoicing for Danish public organisations, open source project of the ERST.

Project name is defined as "e-DELI-very-S".

The main goal of the project is to simplify implementation of eDelivery and eInvoicing from CEF building blocks by Danish public organisations.

Key functionality of the project is registration of Danish organisations in OpenPEPPOL network and implementation of corner three in 4 corner model (documents receiving) and corner two for message responses (documents sending). To simplify integration with OpenPEPPOL, documents can be converted to OIOUBL format, already supported by all public Danish organisations.

This includes:

  1. Support of multiple organisations on the same instance of the application, with own setup, user access and list of identifiers
  2. Automatic synchronization of the list of identifiers of organisation
  3. Automatic publishing of identifiers to SMP with configured list of profiles
  4. Receiving documents by AS4 and AS2 protocols via CEF Domibus and DIFI Oxalis
  5. On-the-fly validation during document receiving of receiver identifier and supported profiles by message details
  6. Ingoing document format and receiver identification by document contents
  7. Validation of ingoing format by XML schema and multiple schematron files
  8. Transformation of ingoing format according to organisation configuration
  9. Supported formats:
  • Cross Industry Invoice (v. 16B), conversion to BIS3 Invoice/CreditNote
  • BIS3 Invoice/CreditNote, conversion to OIOUBL
  • OIOUBL Invoice/CreditNote
  • BIS3 Invoice Response
  • BIS3 Message Level Response
  1. Automatic generation of BIS3 Message Level Response in case of validation error of ingoing or transformed format as a technical rejection
  2. Sending documents by AS4 and AS4 protocols by dynamic lookup in OpenPEPPOL network
  3. Web GUI for reviewing list of received and sent documents by corresponding organisation, processing details and downloading of technical receipts
  4. Web GUI for manual generation of BIS3 Invoice Response as a business response on received document
  5. Automatic forwarding of generated BIS3 Message Level Response to ERST Error Statistics module
  6. Error Statistics module for analysis of found schema/schematron errors in processed documents and loaded from BIS3 Message Level Response files

To build DELIS for Tomcat:

mvn clean install

Prepare database

MySQL example:

drop schema if exists delis;
create schema delis;
alter database delis charset=utf8 collate=utf8_bin; 
create user delis@localhost identified by 'delis';
grant all on delis.* to delis@localhost;

For access outside of localhost, last 2 lines should look like:

create user 'delis'@'%' identified by 'delis';
grant all on delis.* to 'delis'@'%';

There are two test classes. Separated by naming convention.

  1. Unit tests ends with *Test - run every time on build (by surefire plugin)
  2. Integration tests ends with *IT - run with goal 'mvg failsafe:integration-test' and 'mvn failsafe:verify'

Test Coverage Check

  1. Copy settings.xml file from project root to your ./m2 folder
  2. mvn clean clover:setup test failsafe:integration-test clover:aggregate clover:clover
  3. Open /delis/target/site/clover/index.html

Liquibase

No DB update with spring.jpa.hibernate.ddl-auto from now. Update and versioning with Liquibase only.

  1. If you commit requires changes of DB, you 'must' to add changelog script as well. See liquibase docs or ask co-worker how to do it. Changelog example: \delis\delis-web\src\main\resources\db\changelog\changes\changelog-1.02-organisation_id-nullable.xml

Hint: To automatically create diff change log for two tables, original and changed, use command

liquibase.sh --driver=com.mysql.jdbc.Driver \
        --url=jdbc:mysql://localhost:3306/<delis_orig>?useSSL=false \
        --username=delis_name \
        --password=delis_pass \
    diffChangeLog \
        --referenceUrl=jdbc:mysql://localhost:3306/<delis_modified>?useSSL=false \
        --referenceUsername=delis_name \
        --referencePassword=delis_pass \
        > <changelog_filename.xml>
  1. There are 2 ways to create-update tables (precondition: you have empty delis scheme or partially updated with older changelogs):
  • run delis-web application - it creates-updates all automatically
  • run maven goal in delis-web folder 'mvn liquibase:update' Note: run maven goal in delis-data module
    Note: if you got error "Validation Failed: 1 change sets check sum", run maven 'mvn liquibase:clearCheckSums' and try update again

Identifier Validation Skip Values

You can set env variable "identifier.check.step.skip" to skip Service or Action checks Values: Any letters combinations that contains (or not) "SERVICE" and-or "ACTION"

DELIS :: Schematron -> XSLT Converter

  1. Set /delis/delis-sch2xslt-converter current dir
  2. Copy schematron file into /delis/delis-sch2xslt-converter/sch folder
  3. Run mvn clean install
  4. Look fo converted files in /delis/delis-sch2xslt-converter/xslt folder Note. Currently, /sch and /xslt contain example file "PEPPOLBIS-T111" - schematron and converted xslt.