def _register_config_for_pack(self, pack, config_path): content = {} values = self._meta_loader.load(config_path) content['pack'] = pack content['values'] = values config_api = ConfigAPI(**content) config_api.validate(validate_against_schema=self._validate_configs) config_db = ConfigAPI.to_model(config_api) try: config_db.id = Config.get_by_pack(config_api.pack).id except StackStormDBObjectNotFoundError: LOG.debug('Config for pack "%s" not found. Creating new entry.', pack) try: config_db = Config.add_or_update(config_db) extra = {'config_db': config_db} LOG.audit('Config for pack "%s" is updated.', config_db.pack, extra=extra) except Exception: LOG.exception('Failed to config for pack %s.', pack) raise return config_db
def save_model(config_api): pack = config_api.pack config_db = ConfigAPI.to_model(config_api) try: config_db.id = Config.get_by_pack(pack).id except StackStormDBObjectNotFoundError: LOG.debug('Config for pack "%s" not found. Creating new entry.', pack) try: config_db = Config.add_or_update(config_db) extra = {'config_db': config_db} LOG.audit('Config for pack "%s" is updated.', config_db.pack, extra=extra) except Exception: LOG.exception('Failed to save config for pack %s.', pack) raise return config_db