Clients often ask me how to import an existing collection of tags into Magnolia CMS. Local governments use tags such as taxes, transportation or schools to categorize their content. Travel websites use geographical terms like london, paris and bangkok to tag places to visit. Such vocabularies grow large over time. Creating them from scratch is a lot of work.
I wrote a Groovy script that imports tags from XML. The example below finds any Flickr tags that are related to the given tag london. You can customize the script to import your own tags. I am not sure why I had not used Groovy much before. Once I tried it I loved it! You will too when you see how simple it is to implement a tag importer.
Requirements
- Magnolia CMS 4.5.7 with Groovy module. It's in the add-ons folder in the bundle.
- Flickr API key. Register for an API key in order to call the Flickr API.
Creating a Groovy script
- In Magnolia CMS, go to Tools > Scripts and add a new Groovy script.
- Paste the following code into your script.
- Check the Is a script? box.
tag = 'london' hm = MgnlContext.getHierarchyManager('data') // Create a folder in the Data module flickrTags = ContentUtil.createPath(hm, "/categorization/${tag}", new ItemType("dataFolder")) hm.save() itemType = new ItemType('category') // Connect to Flickr REST API URL url = new URL("http://api.flickr.com/services/rest/?method=flickr.tags.getRelated&api_key=5f26c50b6e67110809b117da0f2bb94f&tag=${tag}") HttpURLConnection conn = (HttpURLConnection) url.openConnection() conn.setRequestMethod("GET") conn.setRequestProperty("Accept", "application/xml") if (conn.getResponseCode() != 200) { throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode()) } // Parse the response XML rsp = new XmlSlurper().parse(conn.getInputStream()) rsp.tags.tag.each{ content = ContentUtil.createPath(hm, "/categorization/${tag}/${it.text()}", itemType) content.name = it.text() } flickrTags.save() conn.disconnect() return "done"
- Create a new folder in the Data module with the parent tag name.
- Connect to the Flickr REST API and request all tags related to the parent tag.
- Parse the resulting XML.
- Create categories under the previously created data folder.
Now the tags are available for categorizing content.
Bear in mind is that there is no error handling in this code to keep it short. This solution has been developed and tested with Magnolia 4.5.7