- 
                Notifications
    You must be signed in to change notification settings 
- Fork 44
Submodule phase2‐lib
This library manages the package com.helger.phase2 and all sub-packages:
- com.helger.phase2 - contains the global AS2 settings
- com.helger.phase2.cert - contains the certificate factory
- com.helger.phase2.client - contains the AS2 client for sending messages
- com.helger.phase2.crypto - contains the BouncyCastle crypto code for signing, verification, encryption and decryption of messages
- com.helger.phase2.disposition - contains code to handle content disposition
- com.helger.phase2.exception - contains basic exception classes
- com.helger.phase2.message - contains the main message and MDN classes
- com.helger.phase2.params - generic code that allows for parameterization of certain message related configuration items
- com.helger.phase2.partner - contains the partnership and factory code
- com.helger.phase2.partner.xml - contains the XML based version of a partnership factory
- com.helger.phase2.processor - contains the basic building blocks for processing of messages
- com.helger.phase2.processor.module - contains the basic classes for "active" modules (modules that can be started and stopped)
- com.helger.phase2.processor.receiver - module for receiving messages
- com.helger.phase2.processor.receiver.net - module for receiving messages from Sockets
- com.helger.phase2.processor.resender - modules for re-sending messages
- com.helger.phase2.processor.sender - module for sending messages
- com.helger.phase2.processor.storage - module for storing messages
- com.helger.phase2.util - contains utility classes used in several places in this library or in derived projects
- com.helger.phase2.util.cert - utility classes for certificate handling
- com.helger.phase2.util.http - utility classes for HTTP connection handling
- com.helger.phase2.util.javamail - utility classes for javax.mail handling
phase2 ships with a powerful client to send AS2 messages. It can easily be embedded in standalone Java applications and does not require any server part. All the necessary classes are in the package com.helger.phase2.client.
For a quick start look at https://github.com/phax/phase2/blob/master/phase2/src/test/java/com/helger/phase2/supplementary/main/MainSendToMendelsonTestServer.java as a working example on how to send an arbitrary file to the Mendelson test server.
The client basically separates between per-partnership settings (class AS2ClientSettings) and the content to be transmitted (class AS2ClientRequest). The glue that holds all of this together is the class AS2Client that takes the settings and the request, adds the possibility to define an HTTP(S) proxy server, and does the synchronous sending. The settings and the main client are thought to be reusable, whereas the request data is to be changed for every request.
The response of a client request is defined by class AS2ClientResponse. It stores the original message ID, the received MDN/the occurred exception and the execution duration. The interpretation of the received MDN is up to the user.