~ubuntu-branches/ubuntu/precise/python-novaclient/precise

« back to all changes in this revision

Viewing changes to novaclient/v1_0/images.py

  • Committer: Package Import Robot
  • Author(s): Chuck Short
  • Date: 2012-01-13 12:30:26 UTC
  • mfrom: (1.1.9)
  • Revision ID: package-import@ubuntu.com-20120113123026-hwozywswbfdb36k7
Tags: 2012.1~e3~20120111.452-0ubuntu1
* New upstream version.
* Make running the test suite better.
* Fix argparse import. (LP: #912069) 

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright 2010 Jacob Kaplan-Moss
2
 
"""
3
 
Image interface.
4
 
"""
5
 
 
6
 
from novaclient import base
7
 
 
8
 
 
9
 
class Image(base.Resource):
10
 
    """
11
 
    An image is a collection of files used to create or rebuild a server.
12
 
    """
13
 
    def __repr__(self):
14
 
        return "<Image: %s>" % self.name
15
 
 
16
 
    def delete(self):
17
 
        """
18
 
        Delete this image.
19
 
        """
20
 
        return self.manager.delete(self)
21
 
 
22
 
 
23
 
class ImageManager(base.ManagerWithFind):
24
 
    """
25
 
    Manage :class:`Image` resources.
26
 
    """
27
 
    resource_class = Image
28
 
 
29
 
    def get(self, image):
30
 
        """
31
 
        Get an image.
32
 
 
33
 
        :param image: The ID of the image to get.
34
 
        :rtype: :class:`Image`
35
 
        """
36
 
        return self._get("/images/%s" % base.getid(image), "image")
37
 
 
38
 
    def list(self, detailed=True):
39
 
        """
40
 
        Get a list of all images.
41
 
 
42
 
        :rtype: list of :class:`Image`
43
 
        """
44
 
        detail = ""
45
 
        if detailed:
46
 
            detail = "/detail"
47
 
        return self._list("/images%s" % detail, "images")
48
 
 
49
 
    def create(self, server, name):
50
 
        """
51
 
        Create a new image by snapshotting a running :class:`Server`
52
 
 
53
 
        :param name: An (arbitrary) name for the new image.
54
 
        :param server: The :class:`Server` (or its ID) to make a snapshot of.
55
 
        :rtype: :class:`Image`
56
 
        """
57
 
        data = {"image": {"serverId": base.getid(server), "name": name}}
58
 
        return self._create("/images", data, "image")
59
 
 
60
 
    def delete(self, image):
61
 
        """
62
 
        Delete an image.
63
 
 
64
 
        It should go without saying that you can't delete an image
65
 
        that you didn't create.
66
 
 
67
 
        :param image: The :class:`Image` (or its ID) to delete.
68
 
        """
69
 
        self._delete("/images/%s" % base.getid(image))