vm/qubesvm: revert backup_timestamp to '%s' format

Human readable format `str(datetime.datetime)` is a nightmare for Admin
API level communication. Especially setting the property in a format
that it was read was not supported, and handling such format in
untrusted input handling code is a bad idea. Revert to a simple intiger
format.
This commit is contained in:
Marek Marczykowski-Górecki 2018-01-11 03:46:39 +01:00
parent be7b278032
commit 85e80f2329
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724
3 changed files with 7 additions and 10 deletions

View File

@ -819,7 +819,8 @@ class Backup(object):
# Save date of last backup, only when backup succeeded # Save date of last backup, only when backup succeeded
for qid, vm_info in files_to_backup.items(): for qid, vm_info in files_to_backup.items():
if vm_info.vm: if vm_info.vm:
vm_info.vm.backup_timestamp = datetime.datetime.now() vm_info.vm.backup_timestamp = \
int(datetime.datetime.now().strftime('%s'))
self.app.save() self.app.save()

View File

@ -513,12 +513,12 @@ class TC_90_QubesVM(QubesVMTestsMixin, qubes.tests.QubesTestCase):
timestamp = datetime.datetime(2016, 1, 1, 12, 14, 2) timestamp = datetime.datetime(2016, 1, 1, 12, 14, 2)
timestamp_str = timestamp.strftime('%s') timestamp_str = timestamp.strftime('%s')
self.assertPropertyDefaultValue(vm, 'backup_timestamp', None) self.assertPropertyDefaultValue(vm, 'backup_timestamp', None)
self.assertPropertyValue(vm, 'backup_timestamp', timestamp, self.assertPropertyValue(vm, 'backup_timestamp', int(timestamp_str),
timestamp, timestamp_str) int(timestamp_str), timestamp_str)
del vm.backup_timestamp del vm.backup_timestamp
self.assertPropertyDefaultValue(vm, 'backup_timestamp', None) self.assertPropertyDefaultValue(vm, 'backup_timestamp', None)
self.assertPropertyValue(vm, 'backup_timestamp', timestamp_str, self.assertPropertyValue(vm, 'backup_timestamp', timestamp_str,
timestamp) int(timestamp_str))
def test_401_backup_timestamp_invalid(self): def test_401_backup_timestamp_invalid(self):
vm = self.get_vm() vm = self.get_vm()

View File

@ -476,13 +476,9 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
type=bool, setter=qubes.property.bool, type=bool, setter=qubes.property.bool,
doc='If this domain is to be included in default backup.') doc='If this domain is to be included in default backup.')
# format got changed from %s to str(datetime.datetime)
backup_timestamp = qubes.property('backup_timestamp', default=None, backup_timestamp = qubes.property('backup_timestamp', default=None,
setter=(lambda self, prop, value: type=int,
value if isinstance(value, datetime.datetime) else doc='Time of last backup of the qube, in seconds since unix epoch')
datetime.datetime.fromtimestamp(int(value))),
saver=(lambda self, prop, value: value.strftime('%s')),
doc='FIXME')
default_dispvm = qubes.VMProperty('default_dispvm', default_dispvm = qubes.VMProperty('default_dispvm',
load_stage=4, load_stage=4,