#!/usr/bin/python3 """ Usage: snap-seed-parse [${chroot_dir}] <output file> This script looks for a seed.yaml path in the given root directory, parsing it and appending the parsed lines to the given output file. The $chroot_dir argument is optional and will default to the empty string. """ import argparse import os.path import re import yaml def log(msg): print("snap-seed-parse: {}".format(msg)) log("Parsing seed.yaml") parser = argparse.ArgumentParser() parser.add_argument('chroot', nargs='?', default='', help='root dir for the chroot from which to generate the ' 'manifest') parser.add_argument('file', help='Output manifest to this file') ARGS = parser.parse_args() CHROOT_ROOT = ARGS.chroot FNAME = ARGS.file # Trim any trailing slashes for correct appending log("CHROOT_ROOT: {}".format(CHROOT_ROOT)) if len(CHROOT_ROOT) > 0 and CHROOT_ROOT[-1] == '/': CHROOT_ROOT = CHROOT_ROOT[:-1] # This is where we expect to find the seed.yaml file YAML_PATH = CHROOT_ROOT + '/var/lib/snapd/seed/seed.yaml' # Snaps are prepended with this string in the manifest LINE_PREFIX = 'snap:' log("yaml path: {}".format(YAML_PATH)) if not os.path.isfile(YAML_PATH): log("WARNING: yaml path not found; no seeded snaps found.") exit(0) else: log("yaml path found.") with open(YAML_PATH, 'r') as fh: yaml_lines = yaml.safe_load(fh)['snaps'] log('Writing manifest to {}'.format(FNAME)) with open(FNAME, 'a+') as fh: for item in yaml_lines: filestring = item['file'] # Pull the revision number off the file name revision = filestring[filestring.rindex('_')+1:] revision = re.sub(r'[^0-9]', '', revision) fh.write("{}{}\t{}\t{}\n".format(LINE_PREFIX, item['name'], item['channel'], revision, )) log('Manifest output finished.')