summaryrefslogtreecommitdiffstats
path: root/cli/objects/images.py
diff options
context:
space:
mode:
authorJose M. Guisado <jguisado@soleta.eu>2022-05-20 10:22:42 +0200
committerJose M. Guisado <jguisado@soleta.eu>2022-05-20 10:22:42 +0200
commitd90ab82cec328004e743b2bfbb7c25b32eb299ea (patch)
treefcfbfd01f3517631119b7f41ae8363e1259177bd /cli/objects/images.py
parentf88bcf78ac9ffefcedfb4e108b703dac40ca5839 (diff)
format: use autopep8
Use autopep8 for coding format, and only for whitespace changes. This change drops use of tabs in favor of spaces. Doesn't use autopep8 --aggresive option. Format command: $ autopep8 --inline --recursive . When using git-blame, use --ignore-rev in order to ignore this reformatting commit.
Diffstat (limited to 'cli/objects/images.py')
-rw-r--r--cli/objects/images.py274
1 files changed, 139 insertions, 135 deletions
diff --git a/cli/objects/images.py b/cli/objects/images.py
index 8299923..89d57c2 100644
--- a/cli/objects/images.py
+++ b/cli/objects/images.py
@@ -10,140 +10,144 @@ from cli.utils import *
import argparse
+
class OgImage():
- @staticmethod
- def list_images(rest):
- r = rest.get('/images')
- print_json(r.text)
-
- @staticmethod
- def restore_image(rest, args):
- parser = argparse.ArgumentParser()
- parser.add_argument('--disk',
- nargs='?',
- required=True,
- help='Disk')
- parser.add_argument('--part',
- nargs='?',
- required=True,
- help='Partition')
- parser.add_argument('--id',
- nargs='?',
- type=int,
- required=True,
- help='Image id to be restored')
- parser.add_argument('--type',
- nargs='?',
- required=False,
- choices=['unicast', 'unicast-direct', 'tiptorrent'],
- default='tiptorrent',
- help='Transfer method. (Default: tiptorrent)')
- parser.add_argument('--repo',
- nargs='?',
- default=urlparse(rest.URL).netloc.split(':')[0],
- help='Images repository ip')
- group = parser.add_argument_group('clients', 'Client selection args')
- group.add_argument('--center-id',
- type=int,
- action='append',
- default=[],
- required=False,
- help='Clients from given center id')
- group.add_argument('--room-id',
- type=int,
- action='append',
- default=[],
- required=False,
- help='Clients from given room id')
- group.add_argument('--client-ip',
- action='append',
- default=[],
- required=False,
- help='Specific client IP')
- parsed_args = parser.parse_args(args)
-
- r = rest.get('/scopes')
- scopes = r.json()
- ips = set()
-
- for center in parsed_args.center_id:
- center_scope = scope_lookup(center, 'center', scopes)
- ips.update(ips_in_scope(center_scope))
- for room in parsed_args.room_id:
- room_scope = scope_lookup(room, 'room', scopes)
- ips.update(ips_in_scope(room_scope))
- for l in parsed_args.client_ip:
- ips.add(l)
-
- if not ips:
- print('No clients specified.')
- return
-
- r = rest.get('/images')
- images = r.json()
- found_image = [img for img in images['images'] if img['id'] == parsed_args.id]
- if not found_image:
- print(f'Image with id {parsed_args.id} not found.')
- return
- else:
- found_image = found_image[0]
-
- payload = {'disk': parsed_args.disk, 'partition': parsed_args.part,
- 'id': str(parsed_args.id), 'name': found_image['name'],
- 'profile': str(found_image['software_id']),
- 'repository': parsed_args.repo,
- 'type': parsed_args.type.upper(), 'clients': list(ips)}
- r = rest.post('/image/restore', payload=payload)
-
- @staticmethod
- def create_image(rest, args):
- parser = argparse.ArgumentParser()
- parser.add_argument('--disk',
- nargs='?',
- required=True,
- help='Disk')
- parser.add_argument('--part',
- nargs='?',
- required=True,
- help='Partition')
- parser.add_argument('--name',
- nargs='?',
- required=True,
- help='Image name')
- parser.add_argument('--desc',
- nargs='?',
- required=False,
- help='Image description (for new images)')
- parser.add_argument('--repo',
- nargs='?',
- default=urlparse(rest.URL).netloc.split(':')[0],
- help='Images repository ip')
- group = parser.add_argument_group('clients', 'Client selection args')
- group.add_argument('--client-ip',
- action='append',
- default=[],
- required=False,
- help='Specific client IP')
- parsed_args = parser.parse_args(args)
-
- r = rest.get('/client/info', payload={'client':parsed_args.client_ip})
- center_id = r.json()['center']
-
- r = rest.get('/client/setup', payload={'client':parsed_args.client_ip})
- if r.status_code == 200:
- part_info = list(filter(lambda x: x['disk'] == int(parsed_args.disk) and
- x['partition'] == int(parsed_args.part),
- r.json()['partitions']))
- if not part_info:
- print('Partition not found.')
- return
- fs_code = list(part_info)[0]['code']
-
- payload = {'clients': parsed_args.client_ip, 'disk': parsed_args.disk, 'center_id': center_id,
- 'partition': parsed_args.part, 'code': str(fs_code), 'name': parsed_args.name,
- 'repository': parsed_args.repo, 'id': '0'}
- if parsed_args.desc:
- payload['description'] = parsed_args.desc
-
- rest.post('/image/create', payload=payload)
+ @staticmethod
+ def list_images(rest):
+ r = rest.get('/images')
+ print_json(r.text)
+
+ @staticmethod
+ def restore_image(rest, args):
+ parser = argparse.ArgumentParser()
+ parser.add_argument('--disk',
+ nargs='?',
+ required=True,
+ help='Disk')
+ parser.add_argument('--part',
+ nargs='?',
+ required=True,
+ help='Partition')
+ parser.add_argument('--id',
+ nargs='?',
+ type=int,
+ required=True,
+ help='Image id to be restored')
+ parser.add_argument('--type',
+ nargs='?',
+ required=False,
+ choices=['unicast',
+ 'unicast-direct', 'tiptorrent'],
+ default='tiptorrent',
+ help='Transfer method. (Default: tiptorrent)')
+ parser.add_argument('--repo',
+ nargs='?',
+ default=urlparse(rest.URL).netloc.split(':')[0],
+ help='Images repository ip')
+ group = parser.add_argument_group('clients', 'Client selection args')
+ group.add_argument('--center-id',
+ type=int,
+ action='append',
+ default=[],
+ required=False,
+ help='Clients from given center id')
+ group.add_argument('--room-id',
+ type=int,
+ action='append',
+ default=[],
+ required=False,
+ help='Clients from given room id')
+ group.add_argument('--client-ip',
+ action='append',
+ default=[],
+ required=False,
+ help='Specific client IP')
+ parsed_args = parser.parse_args(args)
+
+ r = rest.get('/scopes')
+ scopes = r.json()
+ ips = set()
+
+ for center in parsed_args.center_id:
+ center_scope = scope_lookup(center, 'center', scopes)
+ ips.update(ips_in_scope(center_scope))
+ for room in parsed_args.room_id:
+ room_scope = scope_lookup(room, 'room', scopes)
+ ips.update(ips_in_scope(room_scope))
+ for l in parsed_args.client_ip:
+ ips.add(l)
+
+ if not ips:
+ print('No clients specified.')
+ return
+
+ r = rest.get('/images')
+ images = r.json()
+ found_image = [img for img in images['images']
+ if img['id'] == parsed_args.id]
+ if not found_image:
+ print(f'Image with id {parsed_args.id} not found.')
+ return
+ else:
+ found_image = found_image[0]
+
+ payload = {'disk': parsed_args.disk, 'partition': parsed_args.part,
+ 'id': str(parsed_args.id), 'name': found_image['name'],
+ 'profile': str(found_image['software_id']),
+ 'repository': parsed_args.repo,
+ 'type': parsed_args.type.upper(), 'clients': list(ips)}
+ r = rest.post('/image/restore', payload=payload)
+
+ @staticmethod
+ def create_image(rest, args):
+ parser = argparse.ArgumentParser()
+ parser.add_argument('--disk',
+ nargs='?',
+ required=True,
+ help='Disk')
+ parser.add_argument('--part',
+ nargs='?',
+ required=True,
+ help='Partition')
+ parser.add_argument('--name',
+ nargs='?',
+ required=True,
+ help='Image name')
+ parser.add_argument('--desc',
+ nargs='?',
+ required=False,
+ help='Image description (for new images)')
+ parser.add_argument('--repo',
+ nargs='?',
+ default=urlparse(rest.URL).netloc.split(':')[0],
+ help='Images repository ip')
+ group = parser.add_argument_group('clients', 'Client selection args')
+ group.add_argument('--client-ip',
+ action='append',
+ default=[],
+ required=False,
+ help='Specific client IP')
+ parsed_args = parser.parse_args(args)
+
+ r = rest.get('/client/info', payload={'client': parsed_args.client_ip})
+ center_id = r.json()['center']
+
+ r = rest.get('/client/setup',
+ payload={'client': parsed_args.client_ip})
+ if r.status_code == 200:
+ part_info = list(filter(lambda x: x['disk'] == int(parsed_args.disk) and
+ x['partition'] == int(parsed_args.part),
+ r.json()['partitions']))
+ if not part_info:
+ print('Partition not found.')
+ return
+ fs_code = list(part_info)[0]['code']
+
+ payload = {'clients': parsed_args.client_ip, 'disk': parsed_args.disk, 'center_id': center_id,
+ 'partition': parsed_args.part, 'code': str(fs_code), 'name': parsed_args.name,
+ 'repository': parsed_args.repo, 'id': '0'}
+ if parsed_args.desc:
+ payload['description'] = parsed_args.desc
+
+ rest.post('/image/create', payload=payload)