qubes/vm: make VM QubesDB interface as much compatible as possible

All the base keys can be kept easily the same, so do it.

QubesOS/qubes-issues#1812
This commit is contained in:
Marek Marczykowski-Górecki 2016-09-07 03:12:03 +02:00
parent d5a41e838f
commit aa0674e8bb
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724
2 changed files with 12 additions and 61 deletions

View File

@ -21,7 +21,6 @@
# with this program; if not, write to the Free Software Foundation, Inc., # with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
# #
import base64
import datetime import datetime
import qubes.ext import qubes.ext
import qubes.vm.qubesvm import qubes.vm.qubesvm
@ -63,55 +62,6 @@ class R3Compatibility(qubes.ext.Extension):
vmtype = 'AppVM' vmtype = 'AppVM'
vm.qdb.write('/qubes-vm-type', vmtype) vm.qdb.write('/qubes-vm-type', vmtype)
# /qubes-vm-updateable
vm.qdb.write('/qubes-vm-updateable', str(vm.updateable))
# /qubes-base-template
try:
if vm.template:
vm.qdb.write('/qubes-base-template', str(vm.template))
else:
vm.qdb.write('/qubes-base-template', '')
except AttributeError:
vm.qdb.write('/qubes-base-template', '')
# /qubes-debug-mode: 0, 1
vm.qdb.write('/qubes-debug-mode', str(int(vm.debug)))
# /qubes-timezone
timezone = vm.qdb.read('/timezone')
if timezone:
vm.qdb.write('/qubes-timezone', timezone)
# /qubes-vm-persistence
persistence = vm.qdb.read('/persistence')
if persistence:
vm.qdb.write('/qubes-vm-persistence', persistence)
# /qubes-random-seed
# write a new one, to make sure it wouldn't be reused/leaked
vm.qdb.write('/qubes-random-seed',
base64.b64encode(qubes.utils.urandom(64)))
# /qubes-keyboard
# not needed for now - the old one is still present
# Networking
if vm.provides_network:
# '/qubes-netvm-network' value is only checked for being non empty
vm.qdb.write('/qubes-netvm-network', vm.gateway)
vm.qdb.write('/qubes-netvm-netmask', vm.netmask)
vm.qdb.write('/qubes-netvm-gateway', vm.gateway)
vm.qdb.write('/qubes-netvm-primary-dns', vm.dns[0])
vm.qdb.write('/qubes-netvm-secondary-dns', vm.dns[1])
if vm.netvm is not None:
vm.qdb.write('/qubes-ip', vm.ip)
vm.qdb.write('/qubes-netmask', vm.netvm.netmask)
vm.qdb.write('/qubes-gateway', vm.netvm.gateway)
vm.qdb.write('/qubes-primary-dns', vm.dns[0])
vm.qdb.write('/qubes-secondary-dns', vm.dns[1])
vm.qdb.write("/qubes-iptables-error", '') vm.qdb.write("/qubes-iptables-error", '')
self.write_iptables_qubesdb_entry(vm) self.write_iptables_qubesdb_entry(vm)

View File

@ -28,7 +28,6 @@ from __future__ import absolute_import
import copy import copy
import base64 import base64
import datetime import datetime
import itertools
import os import os
import os.path import os.path
import re import re
@ -1456,7 +1455,7 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
# pylint: disable=no-member # pylint: disable=no-member
self.qdb.write('/name', self.name) self.qdb.write('/name', self.name)
self.qdb.write('/qubes-vm-type', self.__class__.__name__) self.qdb.write('/type', self.__class__.__name__)
self.qdb.write('/qubes-vm-updateable', str(self.updateable)) self.qdb.write('/qubes-vm-updateable', str(self.updateable))
self.qdb.write('/qubes-vm-persistence', self.qdb.write('/qubes-vm-persistence',
'full' if self.updateable else 'rw-only') 'full' if self.updateable else 'rw-only')
@ -1470,19 +1469,21 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
base64.b64encode(qubes.utils.urandom(64))) base64.b64encode(qubes.utils.urandom(64)))
if self.provides_network: if self.provides_network:
self.qdb.write('/network-provider/gateway', self.gateway) # '/qubes-netvm-network' value is only checked for being non empty
self.qdb.write('/network-provider/netmask', self.netmask) self.qdb.write('/qubes-netvm-network', self.gateway)
self.qdb.write('/qubes-netvm-gateway', self.gateway)
self.qdb.write('/qubes-netvm-netmask', self.netmask)
for i, addr in zip(itertools.count(start=1), self.dns): for i, addr in zip(('primary', 'secondary'), self.dns):
self.qdb.write('/network-provider/dns-{}'.format(i), addr) self.qdb.write('/qubes-netvm-{}-dns'.format(i), addr)
if self.netvm is not None: if self.netvm is not None:
self.qdb.write('/network/ip', self.ip) self.qdb.write('/qubes-ip', self.ip)
self.qdb.write('/network/netmask', self.netvm.netmask) self.qdb.write('/qubes-netmask', self.netvm.netmask)
self.qdb.write('/network/gateway', self.netvm.gateway) self.qdb.write('/qubes-gateway', self.netvm.gateway)
for i, addr in zip(itertools.count(start=1), self.dns): for i, addr in zip(('primary', 'secondary'), self.dns):
self.qdb.write('/network/dns-{}'.format(i), addr) self.qdb.write('/qubes-{}-dns'.format(i), addr)
tzname = qubes.utils.get_timezone() tzname = qubes.utils.get_timezone()