public class DefaultXhtmlContent extends Object implements XhtmlContent
Constructor and Description |
---|
DefaultXhtmlContent(Marshaller<MacroDefinition> viewMacroMarshaller,
Marshaller<MacroDefinition> storageMacroMarshaller,
Marshaller<Link> viewLinkMarshaller,
Marshaller<Link> storageLinkMarshaller,
Marshaller<EmbeddedImage> viewEmbeddedImageMarshaller,
Marshaller<EmbeddedImage> storageEmbeddedImageMarshaller,
Marshaller<InlineTaskList> viewInlineTaskMarshaller,
Marshaller<InlineTaskList> storageInlineTaskMarshaller,
Renderer viewRenderer,
XmlEventReaderFactory xmlEventReaderFactory,
ContentTransformerFactory contentTransformerFactory,
ExceptionTolerantMigrator wikiToXhtmlMigrator) |
Modifier and Type | Method and Description |
---|---|
String |
convertEmbeddedImageToStorage(EmbeddedImage embeddedImage,
ConversionContext context)
Returns a storage format fragment for the supplied
embeddedImage . |
String |
convertEmbeddedImageToView(EmbeddedImage embeddedImage,
ConversionContext context)
Returns a view format fragment for the supplied
embeddedImage . |
String |
convertInlineTaskListToStorage(InlineTaskList inlineTaskList,
ConversionContext context)
Returns a storage format fragment for the supplied
inlineTaskList . |
String |
convertInlineTaskListToView(InlineTaskList inlineTaskList,
ConversionContext context)
Returns a view format fragment for the supplied
inlineTaskList . |
String |
convertLinkToStorage(Link link,
ConversionContext context)
Returns a storage format fragment for the supplied
link . |
String |
convertLinkToView(Link link,
ConversionContext context)
Returns a view format fragment for the supplied
link . |
String |
convertMacroDefinitionToStorage(MacroDefinition macroDefinition,
ConversionContext context)
Returns an storage format fragment for the supplied
macroDefinition . |
String |
convertMacroDefinitionToView(MacroDefinition macroDefinition,
ConversionContext context)
Returns a view format fragment for the supplied
macroDefinition . |
List<BatchedRenderResult> |
convertStorageToView(BatchedRenderRequest... renderRequests)
Returns a view format fragments for the supplied
renderRequests . |
String |
convertStorageToView(String storageFragment,
ConversionContext context)
Returns a view format fragment for the supplied
storageFragment . |
<T extends ContentEntityObject> |
convertWikiBodyToStorage(T ceo)
Convert the body of the supplied ContentEntityObject to Confluence Storage Format XHTML (if necessary).
|
String |
convertWikiToStorage(String wikiContent,
ConversionContext context,
List<RuntimeException> migrationExceptions)
Returns the XHTML storage format equivalent of the supplied
wikiContent (wiki markup). |
String |
convertWikiToView(String wikiContent,
ConversionContext context,
List<RuntimeException> migrationExceptions)
Returns the HTML view format equivalent of the supplied
wikiContent . |
void |
handleMacroDefinitions(String storageFragment,
ConversionContext context,
MacroDefinitionHandler handler)
Perform an operation on
MacroDefinition s in the supplied storageFragment without making changes
to the storage representation. |
void |
handleMacroDefinitions(String storageFragment,
ConversionContext context,
MacroDefinitionHandler handler,
MacroDefinitionMarshallingStrategy strategy)
Perform an operation on
MacroDefinition s in the supplied storageFragment , with optional changes
to the storage representation defined by the MacroDefinitionMarshallingStrategy . |
void |
handleXhtmlElements(String storageFragment,
ConversionContext context,
List<? extends XhtmlVisitor> visitors)
Provides a mechanism for finding arbitrary Xhtml elements in the supplied
storageFormat . |
String |
replaceMacroDefinitionsWithString(String storageFragment,
ConversionContext context,
MacroDefinitionReplacer replacer)
Replaces
MacroDefinition s in the supplied storageFragment with a String. |
String |
updateMacroDefinitions(String storageFragment,
ConversionContext context,
MacroDefinitionUpdater updater)
Updates
MacroDefinition s in the supplied storageFragment . |
public DefaultXhtmlContent(Marshaller<MacroDefinition> viewMacroMarshaller, Marshaller<MacroDefinition> storageMacroMarshaller, Marshaller<Link> viewLinkMarshaller, Marshaller<Link> storageLinkMarshaller, Marshaller<EmbeddedImage> viewEmbeddedImageMarshaller, Marshaller<EmbeddedImage> storageEmbeddedImageMarshaller, Marshaller<InlineTaskList> viewInlineTaskMarshaller, Marshaller<InlineTaskList> storageInlineTaskMarshaller, Renderer viewRenderer, XmlEventReaderFactory xmlEventReaderFactory, ContentTransformerFactory contentTransformerFactory, ExceptionTolerantMigrator wikiToXhtmlMigrator)
public String convertWikiToStorage(String wikiContent, ConversionContext context, List<RuntimeException> migrationExceptions)
XhtmlContent
wikiContent
(wiki markup).convertWikiToStorage
in interface XhtmlContent
wikiContent
- to be converted.context
- for the conversion.migrationExceptions
- that will be populated with any exceptions that take place during the migration.
There may be multiple exceptions if there are multiple wiki markup sections.public <T extends ContentEntityObject> T convertWikiBodyToStorage(T ceo)
XhtmlContent
Convert the body of the supplied ContentEntityObject to Confluence Storage Format XHTML (if necessary).
Since for now and the near future Confluence may have both wiki formatted and XHTML formatted ContentEntityObjects in the system (wiki formatted historical versions may be present in an upgraded installation) this method provides a convenient way to ensure you only need to handle ContentEntityObjects with the new XHTML format of body.
Note that the returned ceo is a clone of the passed in version, even if no conversion was necessary.
convertWikiBodyToStorage
in interface XhtmlContent
ceo
- the ContentEntityObject to be converted (if necessary).public String convertWikiToView(String wikiContent, ConversionContext context, List<RuntimeException> migrationExceptions) throws XMLStreamException, XhtmlException
XhtmlContent
wikiContent
.convertWikiToView
in interface XhtmlContent
wikiContent
- to be converted.context
- for the conversion.migrationExceptions
- that will be populated with any exceptions that take place during the migration.
There may be multiple exceptions if there are multiple wiki markup sections.XMLStreamException
- if there was a problem reading intermediate storage format data that is created during the conversion.XhtmlException
- if there was a problem creating the view format output.public String convertStorageToView(String storageFragment, ConversionContext context) throws XMLStreamException, XhtmlException
XhtmlContent
storageFragment
.convertStorageToView
in interface XhtmlContent
storageFragment
- to be converted (for example the body of a macro).context
- for the conversion.XMLStreamException
- if there was a problem reading the storage fragment.XhtmlException
- if there was a problem creating the view fragment.public List<BatchedRenderResult> convertStorageToView(BatchedRenderRequest... renderRequests)
XhtmlContent
renderRequests
.
Failed renders will be flagged in the results, rather than throwing an XMLStreamException or XhtmlException.
convertStorageToView
in interface XhtmlContent
renderRequests
- batches of storageFragments to be converted with their associated contextspublic String convertMacroDefinitionToView(MacroDefinition macroDefinition, ConversionContext context) throws XhtmlException
XhtmlContent
macroDefinition
.convertMacroDefinitionToView
in interface XhtmlContent
macroDefinition
- that describes the macro.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String convertLinkToView(Link link, ConversionContext context) throws XhtmlException
XhtmlContent
link
.convertLinkToView
in interface XhtmlContent
link
- that describes the link.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String convertEmbeddedImageToView(EmbeddedImage embeddedImage, ConversionContext context) throws XhtmlException
XhtmlContent
embeddedImage
.convertEmbeddedImageToView
in interface XhtmlContent
embeddedImage
- that describes the embedded image.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String convertInlineTaskListToView(InlineTaskList inlineTaskList, ConversionContext context) throws XhtmlException
XhtmlContent
inlineTaskList
.convertInlineTaskListToView
in interface XhtmlContent
inlineTaskList
- that describes the inline task list.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String convertMacroDefinitionToStorage(MacroDefinition macroDefinition, ConversionContext context) throws XhtmlException
XhtmlContent
macroDefinition
.convertMacroDefinitionToStorage
in interface XhtmlContent
macroDefinition
- that describes the macro.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String convertLinkToStorage(Link link, ConversionContext context) throws XhtmlException
XhtmlContent
link
.convertLinkToStorage
in interface XhtmlContent
link
- that describes the link.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String convertEmbeddedImageToStorage(EmbeddedImage embeddedImage, ConversionContext context) throws XhtmlException
XhtmlContent
embeddedImage
.convertEmbeddedImageToStorage
in interface XhtmlContent
embeddedImage
- that describes the embedded image.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String convertInlineTaskListToStorage(InlineTaskList inlineTaskList, ConversionContext context) throws XhtmlException
XhtmlContent
inlineTaskList
.convertInlineTaskListToStorage
in interface XhtmlContent
inlineTaskList
- that describes the inline task list.context
- for the conversion.XhtmlException
- if there was a problem creating the fragment.public String updateMacroDefinitions(String storageFragment, ConversionContext context, MacroDefinitionUpdater updater) throws XhtmlException
XhtmlContent
MacroDefinition
s in the supplied storageFragment
.
// Changes the name of all "mice" macros to "cheese". page.setBodyAsString(xhtmlContent.updateMacroDefinitions(page.getBodyAsString(), context, new XhtmlContent.MacroDefinitionUpdater() { public MacroDefinition update(MacroDefinition macroDefinition) { if ("mice".equals(macroDefinition.getName())) macroDefinition.setName("cheese"); return macroDefinition; } }));
updateMacroDefinitions
in interface XhtmlContent
storageFragment
- or more typically the storage representation of a complete ContentEntityObject
which might contain macro definitions.context
- for the conversion.updater
- which is called to update each MacroDefinition found.XhtmlException
- if there was a problem reading the storage fragment, creating the MacroDefinition or
creating the modified fragment.public String replaceMacroDefinitionsWithString(String storageFragment, ConversionContext context, MacroDefinitionReplacer replacer) throws XhtmlException
XhtmlContent
MacroDefinition
s in the supplied storageFragment
with a String. Use {link #updateMacroDefinitions}
rather than this method if you wish to replace or update one definition with another.
// Replaces "cheese" macros with some XHTML. page.setBodyAsString(xhtmlContent.replaceMacroDefinitionsWithString(page.getBodyAsString(), context, new MacroDefinitionReplacer() { public String replace(MacroDefinition macroDefinition) throws XhtmlException { if ("cheese".equals(macroDefinition.getName())) return "I hate cheese!
"; return xhtmlContent.convertMacroDefinitionToStorage(macroDefinition, context); } }));
replaceMacroDefinitionsWithString
in interface XhtmlContent
storageFragment
- or more typically the storage representation of a complete ContentEntityObject
which might contain macro definitions.context
- for the conversion.replacer
- which is called to replace each MacroDefinition found with a replacement in storage format
(typically XHTML).XhtmlException
- if there was a problem reading the storage fragment, creating the MacroDefinition or
creating the modified fragment.public void handleMacroDefinitions(String storageFragment, ConversionContext context, MacroDefinitionHandler handler) throws XhtmlException
XhtmlContent
MacroDefinition
s in the supplied storageFragment
without making changes
to the storage representation.
// Finds the last macro on a page final AtomicReferenceatomicMacroDefinition = new AtomicReference (); xhtmlContent.handleMacroDefinitions(page.getBodyAsString(), context, new MacroDefinitionHandler() { public void handle(MacroDefinition macroDefinition) { atomicMacroDefinition.set(macroDefinition); } }); MacroDefinition lastMacro = atomicMacroDefinition.get();
handleMacroDefinitions
in interface XhtmlContent
storageFragment
- or more typically the storage representation of a complete ContentEntityObject
which might contain macro definitions.context
- for the conversion.handler
- which is called each MacroDefinition found.XhtmlException
- if there was a problem reading the storage fragment or creating the MacroDefinition.public void handleMacroDefinitions(String storageFragment, ConversionContext context, MacroDefinitionHandler handler, MacroDefinitionMarshallingStrategy strategy) throws XhtmlException
XhtmlContent
MacroDefinition
s in the supplied storageFragment
, with optional changes
to the storage representation defined by the MacroDefinitionMarshallingStrategy
.
// Finds the last macro on a page, maintaining any nested macros within the MacroDefinition body final AtomicReferenceatomicMacroDefinition = new AtomicReference (); xhtmlContent.handleMacroDefinitions(page.getBodyAsString(), context, new MacroDefinitionHandler() { public void handle(MacroDefinition macroDefinition) { atomicMacroDefinition.set(macroDefinition); } }, MacroDefinitionMarshallingStrategy.MARSHALL_MACRO); MacroDefinition lastMacro = atomicMacroDefinition.get();
handleMacroDefinitions
in interface XhtmlContent
storageFragment
- or more typically the storage representation of a complete ContentEntityObject
which might contain macro definitions.context
- for the conversion.handler
- which is called each MacroDefinition found.strategy
- the strategy used to transform the body of the handled macrosXhtmlException
- if there was a problem reading the storage fragment or creating the MacroDefinition.public void handleXhtmlElements(String storageFragment, ConversionContext context, List<? extends XhtmlVisitor> visitors) throws XhtmlException
XhtmlContent
storageFormat
.handleXhtmlElements
in interface XhtmlContent
storageFragment
- or more typically the storage representation of a complete ContentEntityObject
context
- for the conversionvisitors
- a list of visitorsXhtmlException
Copyright © 2003–2019 Atlassian. All rights reserved.