Skip to main content

Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

Difference between revisions of "EclipseLink/Release/2.4.0/JAXB RI Extensions/ID Resolver"

Line 67: Line 67:
 
JAXBContext ctx = ...
 
JAXBContext ctx = ...
 
Unmarshaller u = ctx.createUnmarshaller();
 
Unmarshaller u = ctx.createUnmarshaller();
u..setProperty(IDResolver.class.getName(), new MyIDResolver());
+
u.setProperty(IDResolver.class.getName(), new MyIDResolver());
 +
...
 
</source>
 
</source>
 
</div>
 
</div>

Revision as of 13:23, 7 October 2011

Design Documentation: IDResolver

ER 360249

In the current JAXB RI, developed by Sun, there are a series of "proprietary" JAXB extensions that are available to provide advanced JAXB functionality outside of the JAXB spec (these extension classes reside in the com.sun.xml.bind package).

The abstract class IDResolver provided in the Sun JAXB implementation allows users to override the ID/IDREF processing of the JAXB runtime.

This document will outline the design for an EclipseLink equivalent to this extension.


Requirements

  • Deliver an abstract IDResolver class in the EclipseLink library that will provide the same functionality as the Sun extension.
    • Given a String id and Object obj, allow the user to perform custom bind code
    • Given a String id and Class type, allow the user to perform custom resolve code
    • Provide the user a hook into startDocument() and endDocument() events


Behaviour

If an IDResolver has been set on the Unmarshaller (via properties), then the following things must happen during unmarshal:

  • The IDResolver's startDocument() method must be called when unmarshalling starts.
  • When an ID value is encountered during unmarshal, the IDResolver's bind method must be called, to bind the object to the ID.
  • When an IDREF value is encountered during unmarshal, the IDResolver's resolve method must be used to obtain the object for the IDREF.
  • The IDResolver's endDocument() method must be called when unmarshalling completes.


Configuration

The user must extend the following abstract class:

package org.eclipse.persistence.jaxb;
 
import java.util.concurrent.Callable;
 
import javax.xml.bind.ValidationEventHandler;
 
import org.xml.sax.SAXException;
 
public abstract class IDResolver {
 
    public abstract Callable<?> resolve(String id, Class type) throws SAXException;
 
    public abstract void bind(String id, Object obj) throws SAXException;
 
    public void startDocument(ValidationEventHandler eventHandler) throws SAXException {
    }
 
    public void endDocument() throws SAXException {
    }
 
}

The user's IDResolver class can then be passed to the EclipseLink Unmarshaller through the addProperty() method:

...
JAXBContext ctx = ...
Unmarshaller u = ctx.createUnmarshaller();
u.setProperty(IDResolver.class.getName(), new MyIDResolver());
...


XML Bindings

???


Examples

Design

Document History

Date Author Version Description & Notes
111007 Rick Barkhouse 1.00 : First draft

Back to the top