+ //
+ // PRIVATE METHODS
+ //
+
+ /**
+ * Updates the contents of the given Sone from the given fetch result.
+ *
+ * @param sone
+ * The Sone to update
+ * @param fetchResult
+ * The fetch result
+ */
+ private void updateSoneFromXml(Sone sone, FetchResult fetchResult) {
+ logger.log(Level.FINEST, "Persing FetchResult (%d bytes, %s) for %s…", new Object[] { fetchResult.size(), fetchResult.getMimeType(), sone });
+ /* TODO - impose a size limit? */
+ InputStream xmlInputStream = null;
+ Bucket xmlBucket = null;
+ try {
+ xmlBucket = fetchResult.asBucket();
+ xmlInputStream = xmlBucket.getInputStream();
+ Document document = XML.transformToDocument(xmlInputStream);
+ SimpleXML soneXml = SimpleXML.fromDocument(document);
+
+ /* check ID. */
+ String soneId = soneXml.getValue("id", null);
+ if (!sone.getId().equals(soneId)) {
+ /* TODO - mark Sone as bad. */
+ logger.log(Level.WARNING, "Downloaded ID for Sone %s (%s) does not match known ID (%s)!", new Object[] { sone, sone.getId(), soneId });
+ return;
+ }
+
+ String soneName = soneXml.getValue("name", null);
+ if (soneName == null) {
+ /* TODO - mark Sone as bad. */
+ logger.log(Level.WARNING, "Downloaded name for Sone %s was null!", new Object[] { sone });
+ return;
+ }
+
+ SimpleXML profileXml = soneXml.getNode("profile");
+ if (profileXml == null) {
+ /* TODO - mark Sone as bad. */
+ logger.log(Level.WARNING, "Downloaded Sone %s has no profile!", new Object[] { sone });
+ return;
+ }
+
+ /* parse profile. */
+
+ } catch (IOException ioe1) {
+ logger.log(Level.WARNING, "Could not read XML file from " + sone + "!", ioe1);
+ } finally {
+ if (xmlBucket != null) {
+ xmlBucket.free();
+ }
+ Closer.close(xmlInputStream);
+ }
+ }
+