Hi,
On Sun, Jan 10, 2010 at 4:04 AM, Thomas Mortagne
<thomas.mortagne(a)xwiki.com>wrote;wrote:
On Sat, Jan 9, 2010 at 06:11, Arun Reddy
<vipunreddy.n(a)gmail.com> wrote:
Hi,
On Fri, Jan 8, 2010 at 4:58 PM, Thomas Mortagne
<thomas.mortagne(a)xwiki.com>wrote;wrote:
> On Wed, Jan 6, 2010 at 20:22, Arun Reddy <vipunreddy.n(a)gmail.com>
wrote:
Hi Devs,
I have implemented an API for Wiki Importer.
The main component is org.xwiki.wikiimporter.WikiImporter
**WikiImporterDescriptor getDescriptor()
**void importWiki(Object object, WikiImporterListener listener)
**WikiImporterType getType()
Wiki Call back event listener:
org.xwiki.wikiimporter.WikiImporterListener
**void beginWikiPage(String pageName,
Map<String, String> params)
How Map<String, String> params is used ? If it's supposed to receive
document informations like author, date, etc... i think it's should be
well defined and typed parameters in a WikiPageParameters (otherwise
there would be too much parameters in the method and it would not be
easy to extends) instead of Map<String, String> params for example.
Otherwise i don't see how you can use them if each importer can send
any kind of document metadata. You can keep Map<String, String> params
as custom parameters but we need at least a bunch of known page
metadatas in a WikiPageParameters.
No, not for author or date etc.. Some wiki specific metadata related to
page and
other elements, like Id, ClassName. ( in short element
attributes
). As org.xwiki.rendering.Listener follows
Map<String,String> parameters.
I
have followed the same.
In almost all the cases, the metadata ( author,date, comments,
labels/tags
etc.. ) is handled with onProperty() event.
But its a good idea to use WikiPageParameters. I shall implement it.
> > **void beginWikiPageRevision(String pageName, int revision,
Map<String,
> > String> params)
> > **void beginObject(String objectType, Map<String, String> params)
> > **void onProperty(String property, Map<String, String> params, String
> value)
> > **void endObject(String objectType, Map<String, String> params)
> > **void endWikiPageRevision(String pageName, int revision, Map<String,
> > String> params)
> > **void endWikiPage(String pageName, Map<String, String> params)
> > **void beginAttachment(String attachmentName, Map<String, String>
param)
> > **void onAttachmentRevision(String
attachmentName, Map<String, String>
> > params, InputSource input)
> > **void endAttachment(String attachmentName, Map<String, String>
params)
Something is not explicit in your mail: WikiImporterListener extends
org.xwiki.rendering.listener.Listener to send page content events
right ?
The WikiImporterListener doesn't extend
org.xwiki.rendering.listener.Listener , because i never felt the need for
all those methods. I have come up with a custom listener in the lines of
org.xwiki.rendering.listener.Listener
The point of extending Listener is to handle document content. For
example a client would receive something like:
beginWikiPage
beginWikiPageRevision
beginDocument
beginParagraph
onWord
onSpace
onWord
endParagraph
endDocument
endWikiPageRevision
endPage
beginDocument -> endDocument are document content events in a generic
format (the event version of XDOM). That way the client receive
everything he needs to reconstruct the whole wiki in a purely generic
form (no specific syntax), it's WikiImporter responsibility to do all
the needed parsing and conversion to send the proper events to send
valid events representing a complete wiki in WikiImporterListener.
Said another way: Listener describe a document content and
WikiImporterListener extends it to describe the whole wiki.
It's not clear in your proposal how you where planning to send the
document content. Is it one of the onProperty ?
Yes, all the document content is handled using onProperty Tag.
But extending Listener and implementing XDOM events makes it more complete
( Its missing in the proposed API ) :)
WikiImporter parser for parsing documents (eg: XML ) :
org.xwiki.wikiimporter.WikiImporterParser
**void parse(InputSource source, WikiImporterListener listener) throws
WikiImporterParseException
This sound like an implementation details. From public API user POV
WikiImporter#importWiki(Parameters Class Object, WikiImporterListener
) is enough no need to go deeper, the importer then parse documents
internally the way it wants to. Another reason is that "InputSource
source" would be way too limited: for example I'm thinking of
importers getting resources from another wiki directly online (XMLRPC,
REST, etc...), it could also be a folder containing several files for
each document (like content in a txt and objects in xml files), etc.
Ok, Yes InputSource can't handle all the cases.
Can i use a custom
WikiImporterInputSource extending InputSource class.?
No, what i mean is that WikiImporterParser#parse is useless in the
API. The user of the wiki importer should only call
WikiImporter#importWiki(Parameters Class Object, WikiImporterListener)
and receive all needed events for the whole wiki. I don't see the
point of having this WikiImporterParser#parse method at all.
Said that its useless to have WikiImporterParser#parse method.
It shouldnt be
exposed to WikiImporter User in API
(or)
not to have it internally, i mean
WikiImporter#importWiki(Parameters Class Object, WikiImporterListener)
makes call to WikiImporterParser#parse internally inside its implementation.
?
I have the second one in my mind.
>
> > WikiImporter velocity bridge :
> > org.xwiki.wikiimporter.WikiImporterVelocityBridge
> > **public WikiImporterTypeFactory getWikiImporterTypeFactory()
> > **public WikiImporter getWikiImporter(String wikiImporterType) throws
> > WikiImporterException
> >
> > WikiImporter type factory has methods to handle the supported other
wiki
> > formats/types. :
org.xwiki.wikiimporter.WikiImporterTypeFactory
> > **WikiImporterType createTypeFromIdString(String wikiImporterType)
throws
> > WikiImporterException
> > **List<WikiImporterType> getAvailableTypes() throws
WikiImporterException
> >
> > This is a typical use case in my mind.
> >
> > 1. Get WikiImporterFactory instance with
> > WikiImporterVelocityBridge#getWikiImporterFactory
> > 2. Call the WikiImporterTypeFactory#getAvailableTypes() --> can be
used
> > at UI level to show the supported
types ( MediaWiki XML, XMLRPC
etc
> .. )
> > 3. Select the format type and call
> > WikiImporterVelocityBridge#getWikiImporter(String wikiImporterType)
to
> get
> > selected WikiImporter instance.
> > 4. Use the WikiImporterDescriptor to generate the UI. ( Similiar to
> > MacroDescriptor)
> > 5. User enters all the parameters ( UI )
> > 6. Call WikiImporter#importWiki(Parameters Class Object,
> > WikiImporterListener ) to start the import process. Parameters Class
> has all
> > the required parameters for WikiImporter
> > 7. Parser parses and WikiImporterListener events are fired.
> >
> >
> > The next step would be to create xwiki pages on the fly( one at a
time
-
> at
> > every WikiImporterListener#endWikiPage() event. )
> >
> > Remaining : API to import the generated WikiPages into XWiki
> >
> > Is it good idea to use a component which makes use of document bridge
to
> > import the Wiki Pages, Attachments etc..
into XWiki. If not, what will
be
the best way to do it?
Yes you should have a component for that but implemented in a separate
module that depends on xwiki-core because the bridge is too limited
for that so and it will be a pain. We can later refactor the
implementation to use the new model and it's ready.
--
Arun Reddy
_______________________________________________
devs mailing list
devs(a)xwiki.org
http://lists.xwiki.org/mailman/listinfo/devs
--
Thomas Mortagne
_______________________________________________
devs mailing list
devs(a)xwiki.org
http://lists.xwiki.org/mailman/listinfo/devs
--
Arun Reddy
_______________________________________________
devs mailing list
devs(a)xwiki.org
http://lists.xwiki.org/mailman/listinfo/devs
--
Thomas Mortagne
_______________________________________________
devs mailing list
devs(a)xwiki.org
http://lists.xwiki.org/mailman/listinfo/devs