Merge pull request #10 from akutz/bugfix/network-data

Fix issue with network data object
diff --git a/DataSourceVMwareGuestInfo.py b/DataSourceVMwareGuestInfo.py
index d4ae0c2..5c4a4bb 100644
--- a/DataSourceVMwareGuestInfo.py
+++ b/DataSourceVMwareGuestInfo.py
@@ -20,6 +20,7 @@
 
 import base64
 import collections
+import copy
 from distutils.spawn import find_executable
 import json
 import socket
@@ -266,6 +267,7 @@
     decoding the network config when required
     '''
     data = load(guestinfo('metadata'))
+    LOG.debug('loaded metadata %s', data)
 
     network = None
     if 'network' in data:
@@ -278,12 +280,20 @@
         del data['network.encoding']
 
     if network:
-        if not isinstance(network, collections.Mapping):
-            LOG.debug("decoding network data: %s", network)
+        LOG.debug('network data found')
+        if isinstance(network, collections.Mapping):
+            LOG.debug("network data copied to 'config' key")
+            network = {
+                'config': copy.deepcopy(network)
+            }
+        else:
+            LOG.debug("network data to be decoded %s", network)
             dec_net = decode('metadata.network', network_enc, network)
-            network = load(dec_net)
-        if 'config' not in network:
-            raise NetworkConfigError("missing 'config' key")
+            network = {
+                'config': load(dec_net),
+            }
+
+        LOG.debug('network data %s', network)
         data['network'] = network
 
     return data
@@ -429,7 +439,7 @@
                 key = ip_info['addr']
                 if key == '127.0.0.1':
                     continue
-                val = ip_info.copy()
+                val = copy.deepcopy(ip_info)
                 del val['addr']
                 if mac:
                     val['mac'] = mac
@@ -440,7 +450,7 @@
                 key = ip_info['addr']
                 if key == '::1':
                     continue
-                val = ip_info.copy()
+                val = copy.deepcopy(ip_info)
                 del val['addr']
                 if mac:
                     val['mac'] = mac