view vagrant_newvm.py @ 40:984f31ae74d5

Fix student identifier
author atton
date Sun, 15 Nov 2015 12:20:00 +0900
parents fb9f3738a8e6
children
line wrap: on
line source

#!/usr/bin/python
# -*- encoding: utf-8 -*-
import shutil
import sys,os
from optparse import OptionParser

FILE = "metadata.json"
PROVIDER_VB = "virtualbox"
PROVIDER_KVM = "kvm"
BASE_DIR = "/root/.vagrant.d/boxes/"

# read json file
# return list of file contents

def change_kvm_metadata():
    box_base = os.path.join(BASE_DIR, name)
    dir_name = os.path.join(box_base, PROVIDER_KVM)
    return os.path.join(dir_name, FILE)


def read_metadata_json():
    metadata = change_kvm_metadata()
    f = open(metadata, 'r')
    result = []
    for l in f:
        result.append(l)
    f.close()
    return result

# write json file

def write_metadata_json(data):
    metadata = change_kvm_metadata()
    f = open(metadata, 'w')
    for l in data:
        f.write(l)
    f.close()

def replace_data(data):
    data1 = []
    for l in data:
        if 'provider' in l:
            data1.append(l.replace(PROVIDER_VB, PROVIDER_KVM))
        else:
            data1.append(l)
    return data1

def fix_provider_name(name):
    box_base = os.path.join(BASE_DIR, name)
    before_name = os.path.join(box_base, PROVIDER_VB)
    if not os.path.exists(before_name):
        print(before_name + "not found.")
        return
    after_name = os.path.join(box_base, PROVIDER_KVM)
    shutil.move(before_name, after_name)

parser = OptionParser()
parser.add_option("-n", "--name", dest="name", help="VM name")

(options, args) = parser.parse_args()

name = options.name

fix_provider_name(name)

data = read_metadata_json()

data1 = replace_data(data)

write_metadata_json(data1)