Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 1 | import os |
| 2 | import base64 |
| 3 | from django.db.models import F, Q |
| 4 | from xos.config import Config |
Sapan Bhatia | 16be143 | 2016-01-14 11:41:38 -0500 | [diff] [blame] | 5 | from synchronizers.base.openstacksyncstep import OpenStackSyncStep |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 6 | from core.models.image import Image |
Scott Baker | 3586c55 | 2016-01-14 15:30:20 -0800 | [diff] [blame] | 7 | from xos.logger import observer_logger as logger |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 8 | |
| 9 | class SyncImages(OpenStackSyncStep): |
| 10 | provides=[Image] |
| 11 | requested_interval=0 |
| 12 | observes=Image |
| 13 | |
| 14 | def fetch_pending(self, deleted): |
| 15 | # Images come from the back end |
| 16 | # You can't delete them |
| 17 | if (deleted): |
Scott Baker | 745cfa4 | 2015-03-09 16:25:38 -0700 | [diff] [blame] | 18 | logger.info("SyncImages: returning because deleted=True") |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 19 | return [] |
| 20 | |
| 21 | # get list of images on disk |
S.Çağlar Onur | 347f444 | 2015-02-12 12:36:14 -0500 | [diff] [blame] | 22 | images_path = Config().observer_images_directory |
| 23 | |
Scott Baker | 745cfa4 | 2015-03-09 16:25:38 -0700 | [diff] [blame] | 24 | logger.info("SyncImages: deleted=False, images_path=%s" % images_path) |
| 25 | |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 26 | available_images = {} |
S.Çağlar Onur | 347f444 | 2015-02-12 12:36:14 -0500 | [diff] [blame] | 27 | if os.path.exists(images_path): |
| 28 | for f in os.listdir(images_path): |
| 29 | filename = os.path.join(images_path, f) |
| 30 | if os.path.isfile(filename): |
| 31 | available_images[f] = filename |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 32 | |
Scott Baker | 745cfa4 | 2015-03-09 16:25:38 -0700 | [diff] [blame] | 33 | logger.info("SyncImages: available_images = %s" % str(available_images)) |
| 34 | |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 35 | images = Image.objects.all() |
| 36 | image_names = [image.name for image in images] |
| 37 | |
| 38 | for image_name in available_images: |
| 39 | #remove file extension |
| 40 | clean_name = ".".join(image_name.split('.')[:-1]) |
| 41 | if clean_name not in image_names: |
Scott Baker | 745cfa4 | 2015-03-09 16:25:38 -0700 | [diff] [blame] | 42 | logger.info("SyncImages: adding %s" % clean_name) |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 43 | image = Image(name=clean_name, |
| 44 | disk_format='raw', |
| 45 | container_format='bare', |
| 46 | path = available_images[image_name]) |
| 47 | image.save() |
S.Çağlar Onur | 347f444 | 2015-02-12 12:36:14 -0500 | [diff] [blame] | 48 | |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 49 | return Image.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None)) |
| 50 | |
| 51 | def sync_record(self, image): |
| 52 | image.save() |