From f15a0b8474d488f50e60586dce6cfaee669e3b2b Mon Sep 17 00:00:00 2001 From: Tony Mack Date: Wed, 5 Dec 2012 14:01:58 -0500 Subject: [PATCH] Provision requires the geni_rspec_version option --- sfa/managers/aggregate_manager.py | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/sfa/managers/aggregate_manager.py b/sfa/managers/aggregate_manager.py index 0bb9553c..9960eec3 100644 --- a/sfa/managers/aggregate_manager.py +++ b/sfa/managers/aggregate_manager.py @@ -4,6 +4,8 @@ from sfa.util.version import version_core from sfa.util.xrn import Xrn from sfa.util.callids import Callids from sfa.util.sfalogging import logger +from sfa.util.faults import SfaInvalidArgument, InvalidRSpecVersion + class AggregateManager: @@ -119,6 +121,16 @@ class AggregateManager: """ call_id = options.get('call_id') if Callids().already_handled(call_id): return "" + + # make sure geni_rspec_version is specified in options + if 'geni_rspec_version' not in options: + msg = 'geni_rspec_version is required and must be set in options struct' + raise SfaInvalidArgument('geni_rspec_version', msg + # make sure we support the requested rspec version + version_manager = VersionManager() + if not version_manager.get(options['geni_rspec_version']): + raise InvalidRSpecVersion(options['geni_rspec_version']) + return self.driver.provision(xrns, options) def Delete(self, api, xrns, creds, options): -- 2.43.0