Julien Duponchelle 0f66856fa7 SHA1 => MD5
2015-05-28 15:23:18 +02:00

122 lines
4.4 KiB
Python
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Copyright (C) 2015 GNS3 Technologies Inc.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import hashlib
import json
import os
import re
import urllib.request
from gns3registry.image import Image
class Registry:
def __init__(self, download_progress_callback=None):
"""
:param download_progress_callback: Callback called when a file is downloaded
"""
self._download_progress_callback = download_progress_callback
def detect_images(self, images_path):
"""
:param images_path: Array of path to images
:returns: Array of configuration corresponding to the image
"""
images = []
for path in images_path:
images.append(Image(path))
configurations = []
#TODO: Manage open error
for config in self._all_configs():
matched = False
for image in images:
if self._image_match(image, config):
matched = True
if matched:
configurations.append(config)
return configurations
def download_image(self, md5sum, images_dir):
for config in self._all_configs():
for image_type in config.get("images", {}):
for file in config["images"].get(image_type, []):
if file["md5sum"] == md5sum:
path = os.path.join(images_dir, "QEMU", file["filename"])
if "direct_download_url" in file:
print("Download {} to {}".format(file["direct_download_url"], path))
#TODO: Skip download if file already exist with same sha1
urllib.request.urlretrieve(file["direct_download_url"], path, reporthook=self._download_progress_callback)
return path
else:
print("You need to manually download the image {filename} from:\n{download_url}\n\nAnd run: ./bin/gns3-get --add {filename}".format(filename=file["filename"], download_url=file["download_url"]))
return None
def search_device(self, query):
results = []
for config in self._all_configs():
if re.match(r".*{}.*".format(query), config["name"], flags=re.IGNORECASE):
results.append(config)
return results
def _all_configs(self):
"""
Iterate on all configs available on devices
"""
devices_path = self._get_devices_path()
for (dirpath, dirnames, filenames) in os.walk(devices_path):
for filename in filenames:
file = os.path.join(dirpath, filename)
if file.endswith(".json"):
with open(os.path.join(devices_path, file)) as f:
config = json.load(f)
yield config
def _image_match(self, image, config):
"""
:returns: True if image is present in configuration
"""
matched = False
for image_type in config.get("images", {}):
images = config["images"].get(image_type, [])
# If it's not a list it's mean we have already detect the image
if not isinstance(images, list):
continue
for file in images:
if isinstance(file, dict):
if file.get("md5sum", None) == image.md5sum:
image.version = file["version"]
config["images"][image_type] = image
matched = True
return matched
def _get_devices_path(self):
"""
Get the path where the registry files are located
"""
path = os.path.abspath(os.path.dirname(__file__))
return os.path.join(path, "..", "devices")