With Groovy and the XML-RPC library (groovy.codehaus.org/XMLRPC) the access to Trac gets extremely easy. The older version 0.4 and 0.5 of the library could not handle basic authorization but thanks to Tim fixing the missing feature and some other xml format error, you can now access any Trac Wikipage with as little as 3 lines of Groovy code.
def serverProxy
= new XMLRPCServerProxy
("https://user:password@sometracserver.com/login/xmlrpc") // or
// def serverProxy = new XMLRPCServerProxy("http://sometracserver.com/login/xmlrpc")
serverProxy.setBasicAuth("user","password")
println serverProxy.
wiki.
getPage("TracBackup")
Remark:
At the time of this entry version 0.6 is not released yet. Check for availability at repository.codehaus.org/org/codehaus/groovy/groovy-xmlrpc/ for the new version or update your svn copy and build by yourself (see blog entry)
Update 2010-02-01: The new version was released as 0.5.1 (link)
In the previous post we used the Groovy XML-RPC library, in this snippet we will use the Apache XML-RPC library. Why ? There is no basic security implemented in the Groovy XML-RPC to access for example a
The prerequisites are still the same, just we change the library:
- Download the Apache library from here. You should download a file from the binaries folder (apache-xmlrpc-3.1.2-bin.zip), inside you will find a lib subfolder with a couple of jars we need to add to the classpath.
(commons-logging-1.1.jar, xmlrpc-client-3.1.2.jar, xmlrpc-server-3.1.2.jar, ws-commons-util-1.0.2.jar, xmlrpc-common-3.1.2.jar)
Snippet:
Remark: You can add more parameters for the server with
- config.setEncoding(“UTF-8″)
config.setBasicUserName(“[username]“);
config.setBasicPassword(“[password]“);
Comments Off
It is straight forward to access Snipplr via XML-RPC with Groovy. In this tutorial we use the Groovy Console to play with Snipplr snippets.
Requirements:
Tutorial:
The MarkupBuilder is lacking of xml declaration features, so I ported the previous sample to StreamingMarkupBuilder. Unfortunately it throws the complete XML content into 1 line without CR, to make it again human-readable, aka pretty-print it, we use the XmlUtil.serialize method.
.
.
Note: mkp is part of the XML helperclass (link)
.
Comments Off
Please note the difference between MarkupBuilder and StramingMarkupBuilder. More information about XML processing at groovy.codehaus.org
MarkupBuilder is not very flexible, but simple to use for some basic task. If you require comments, XML declarations and more, your rather use the StreamingMarkupBuilder.
Comments Off