-
Notifications
You must be signed in to change notification settings - Fork 15
CONFLUENCE-240: Make AbstractMacroConverter and the Confluence Converter public #70
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Changes from all commits
9ca1928
b631be2
7e3ed22
353f763
7f80afc
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,153 @@ | ||
| /* | ||
| * See the NOTICE file distributed with this work for additional | ||
| * information regarding copyright ownership. | ||
| * | ||
| * This is free software; you can redistribute it and/or modify it | ||
| * under the terms of the GNU Lesser General Public License as | ||
| * published by the Free Software Foundation; either version 2.1 of | ||
| * the License, or (at your option) any later version. | ||
| * | ||
| * This software is distributed in the hope that it will be useful, | ||
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| * Lesser General Public License for more details. | ||
| * | ||
| * You should have received a copy of the GNU Lesser General Public | ||
| * License along with this software; if not, write to the Free | ||
| * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
| * 02110-1301 USA, or see the FSF site: http://www.fsf.org. | ||
| */ | ||
| package org.xwiki.contrib.confluence.filter; | ||
|
|
||
| import java.util.Collection; | ||
| import java.util.Map; | ||
|
|
||
| import org.slf4j.Logger; | ||
| import org.slf4j.LoggerFactory; | ||
| import org.slf4j.Marker; | ||
| import org.slf4j.MarkerFactory; | ||
| import org.xwiki.contrib.confluence.filter.internal.macros.TracedMap; | ||
| import org.xwiki.rendering.listener.Listener; | ||
|
|
||
| /** | ||
| * Base class for {@link MacroConverter} implementations. | ||
| * @version $Id$ | ||
| * @since 9.82.0 | ||
| */ | ||
| public abstract class AbstractMacroConverter implements MacroConverter | ||
| { | ||
| private static final Marker UNHANDLED_PARAMETER_MARKER = MarkerFactory.getMarker("unhandledConfluenceParameter"); | ||
| private static final Marker UNHANDLED_PARAMETER_VALUE_MARKER = | ||
| MarkerFactory.getMarker("unhandledConfluenceParameterValue"); | ||
|
|
||
| private final Logger | ||
| logger = LoggerFactory.getLogger(AbstractMacroConverter.class.getName()); | ||
|
|
||
| @Override | ||
| public void toXWiki(String confluenceId, Map<String, String> confluenceParameters, String confluenceContent, | ||
| boolean inline, Listener listener) | ||
| { | ||
| TracedMap<String, String> tracedParameters = new TracedMap<>(confluenceParameters); | ||
| String id = toXWikiId(confluenceId, tracedParameters, confluenceContent, inline); | ||
| Map<String, String> parameters = toXWikiParameters(confluenceId, tracedParameters, confluenceContent); | ||
| String content = toXWikiContent(confluenceId, tracedParameters, confluenceContent); | ||
| printUnhandledInfo(confluenceId, tracedParameters); | ||
| listener.onMacro(id, parameters, content, inline); | ||
| } | ||
|
|
||
| /** | ||
| * Convert Confluence parameters to XWiki parameters. If you override toXWiki, toXWikiParameters won't be used. You | ||
| * should return something sensible, or an empty Map. | ||
| * @param confluenceId the name of the macro in Confluence | ||
| * @param confluenceParameters the parameters of the macro in Confluence | ||
| * @param content the content of the macro. | ||
| * @return the converted parameters | ||
| */ | ||
| protected abstract Map<String, String> toXWikiParameters(String confluenceId, | ||
| Map<String, String> confluenceParameters, | ||
| String content); | ||
|
|
||
| private void printUnhandledInfo(String confluenceId, TracedMap<String, String> confluenceParameters) | ||
| { | ||
| Collection<String> parametersWithUnhandledValues = confluenceParameters.getParametersWithUnhandledValues(); | ||
| Collection<String> unhandledParameters = confluenceParameters.getUnhandledParameters(); | ||
|
|
||
| for (String p : unhandledParameters) { | ||
| if (!parametersWithUnhandledValues.contains(p)) { | ||
| logger.info(UNHANDLED_PARAMETER_MARKER, "Unhandled parameter [{}] (with value [{}]) in macro [{}]", | ||
| p, confluenceParameters.get(p), confluenceId); | ||
| } | ||
| } | ||
|
|
||
| for (String p : parametersWithUnhandledValues) { | ||
| logger.info(UNHANDLED_PARAMETER_VALUE_MARKER, "Unhandled value [{}] for parameter [{}] in macro [{}]", | ||
| confluenceParameters.get(p), p, confluenceId); | ||
| } | ||
| } | ||
|
|
||
| @Override | ||
| public String toXWikiId(String confluenceId, Map<String, String> confluenceParameters, String confluenceContent, | ||
| boolean inline) | ||
| { | ||
| return confluenceId; | ||
| } | ||
|
|
||
| /** | ||
| * Convert the macro content. | ||
| * @param confluenceId the name of the macro in Confluence | ||
| * @param parameters the parameters of the macro | ||
| * @param confluenceContent the content in Confluence | ||
| * @return the content in XWiki | ||
| */ | ||
| protected String toXWikiContent(String confluenceId, Map<String, String> parameters, String confluenceContent) | ||
| { | ||
| return confluenceContent; | ||
| } | ||
|
|
||
| /** | ||
| * Mark a Confluence parameter as (un)handled. | ||
| * @param confluenceParameters the parameters in Confluence, as passed to toXWikiParameters | ||
| * @param name the name of the parameter to mark as handled | ||
| * @param handled whether the parameter is to be marked as handled | ||
| */ | ||
| protected void markHandledParameter(Map<String, String> confluenceParameters, String name, boolean handled) | ||
| { | ||
| if (confluenceParameters instanceof TracedMap) { | ||
| TracedMap<String, String> tracedParameters = (TracedMap<String, String>) confluenceParameters; | ||
| if (handled) { | ||
| tracedParameters.markAsUsed(name); | ||
| } else { | ||
| tracedParameters.markAsUnused(name); | ||
| } | ||
| } else { | ||
| warnCantMark(); | ||
| } | ||
| } | ||
|
|
||
| /** | ||
| * Mark a Confluence parameter value as unhandled. | ||
| * @param confluenceParameters the parameters in Confluence, as passed to toXWikiParameters | ||
| * @param parameterName the name of the parameter of which the value is unhandled. | ||
| */ | ||
| protected void markUnhandledParameterValue(Map<String, String> confluenceParameters, String parameterName) | ||
| { | ||
| if (confluenceParameters instanceof TracedMap) { | ||
| TracedMap<String, String> tracedParameters = (TracedMap<String, String>) confluenceParameters; | ||
| tracedParameters.markAsUnhandledValue(parameterName); | ||
| } else { | ||
| warnCantMark(); | ||
| } | ||
| } | ||
|
|
||
| private void warnCantMark() | ||
| { | ||
| logger.error( | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The method name suggest the intent is There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Indeed. I'll rename this to |
||
| "Can't mark parameter as (un)handled or missing. Please pass the original Confluence parameter map."); | ||
| } | ||
|
|
||
| // Code editors might suggest that supportsInlineMode already exists in MacroConverter and can be removed here, but | ||
| // one should not remove it: we want subclass to explicitly implement supportsInlineMode. The default | ||
| // implementation in the interface is there for backward-compatibility but this stuff should not be implicit. | ||
| @Override | ||
| public abstract InlineSupport supportsInlineMode(String id, Map<String, String> parameters, String content); | ||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,96 @@ | ||
| /* | ||
| * See the NOTICE file distributed with this work for additional | ||
| * information regarding copyright ownership. | ||
| * | ||
| * This is free software; you can redistribute it and/or modify it | ||
| * under the terms of the GNU Lesser General Public License as | ||
| * published by the Free Software Foundation; either version 2.1 of | ||
| * the License, or (at your option) any later version. | ||
| * | ||
| * This software is distributed in the hope that it will be useful, | ||
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| * Lesser General Public License for more details. | ||
| * | ||
| * You should have received a copy of the GNU Lesser General Public | ||
| * License along with this software; if not, write to the Free | ||
| * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
| * 02110-1301 USA, or see the FSF site: http://www.fsf.org. | ||
| */ | ||
| package org.xwiki.contrib.confluence.filter; | ||
|
|
||
| import org.xwiki.component.annotation.Role; | ||
| import org.xwiki.contrib.confluence.parser.xhtml.ConfluenceReferenceConverter; | ||
| import org.xwiki.model.reference.EntityReference; | ||
| import org.xwiki.rendering.listener.reference.ResourceReference; | ||
| import org.xwiki.rendering.listener.reference.UserResourceReference; | ||
|
|
||
| /** | ||
| * Confluence Filter Reference Converter. | ||
| * @since 9.83.0 | ||
| * @version $Id$ | ||
| */ | ||
| @Role | ||
| public interface ConfluenceFilterReferenceConverter extends ConfluenceReferenceConverter | ||
| { | ||
| /** | ||
| * @param name the name to validate | ||
| * @return the validated name | ||
| * @since 9.26.0 | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The |
||
| */ | ||
| String toEntityName(String name); | ||
|
|
||
| /** | ||
| * @param groupName the Confluence username | ||
| * @return the corresponding XWiki username, without forbidden characters | ||
| * @since 9.45.0 | ||
| */ | ||
| String toGroupReferenceName(String groupName); | ||
|
|
||
| /** | ||
| * @param userName the Confluence username | ||
| * @return the corresponding XWiki username, without forbidden characters | ||
| */ | ||
| String toUserReferenceName(String userName); | ||
|
|
||
| /** | ||
| * @param userName the Confluence username | ||
| * @return the corresponding XWiki user reference | ||
| */ | ||
| String toUserReference(String userName); | ||
|
|
||
| /** | ||
| * @param groupName the Confluence username | ||
| * @return the corresponding XWiki user reference | ||
| * @since 9.45.0 | ||
| */ | ||
| String toGroupReference(String groupName); | ||
|
|
||
| /** | ||
| * @return the serialized guest user | ||
| */ | ||
| String getGuestUser(); | ||
|
|
||
| /** | ||
| * @param reference the reference of a user that can be either a username or a user key. | ||
| * @return a XWiki user reference. | ||
| * @since 9.26 | ||
| */ | ||
| ResourceReference resolveUserReference(UserResourceReference reference); | ||
|
|
||
| /** | ||
| * Convert an external group ID to a XWiki reference. | ||
| * @param groupId confluence external group ID | ||
| * @return serialized XWiki group reference | ||
| */ | ||
| String convertGroupId(String groupId); | ||
|
|
||
| /** | ||
| * Converts a page ID into a XWiki reference. | ||
| * | ||
| * @param pageId confluence if of the page | ||
| * @param asSpace if you want the reference as a space | ||
| * @return a valid XWiki reference or null | ||
| */ | ||
| EntityReference convertDocumentReference(long pageId, boolean asSpace); | ||
| } | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't it be something like 9.83.0 ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll make sure the since annotations are up to date when I merge this