def handle_get(self, request, user, *args, **kwargs): """Treat requests GET to list all the Script. URL: script/all """ try: self.log.info("GET to list all the Script") # User permission if not has_perm(user, AdminPermission.SCRIPT_MANAGEMENT, AdminPermission.READ_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) id_script = kwargs.get('id_script') if id_script is not None: script = Roteiro.get_by_pk(int(id_script)) script = model_to_dict(script) return self.response(dumps_networkapi({'script': script})) script_list = [] for script in Roteiro.objects.all(): script_list.append(model_to_dict(script)) return self.response(dumps_networkapi({'script': script_list})) except UserNotAuthorizedError: return self.not_authorized() except RoteiroError: return self.response_error(1)
def handle_get(self, request, user, *args, **kwargs): """Treat requests GET to list all the Script. URL: script/all """ try: self.log.info("GET to list all the Script") # User permission if not has_perm(user, AdminPermission.SCRIPT_MANAGEMENT, AdminPermission.READ_OPERATION): self.log.error(u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) id_script = kwargs.get('id_script') if id_script is not None: script = Roteiro.get_by_pk(int(id_script)) script = model_to_dict(script) return self.response(dumps_networkapi({'script': script})) script_list = [] for script in Roteiro.objects.all(): script_list.append(model_to_dict(script)) return self.response(dumps_networkapi({'script': script_list})) except UserNotAuthorizedError: return self.not_authorized() except RoteiroError: return self.response_error(1)
def handle_delete(self, request, user, *args, **kwargs): """Treat requests DELETE to remove Equipment Script. URL: equipmentscript/<id_equipment>/<id_script>/ """ try: self.log.info("Remove Equipment Script") id_equipment = kwargs.get('id_equipment') id_script = kwargs.get('id_script') # Valid ID Equipment if not is_valid_int_greater_zero_param(id_equipment): self.log.error( u'The id_equipment parameter is not a valid value: %s.', id_equipment) raise InvalidValueError(None, 'id_equipment', id_equipment) # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error( u'The id_script parameter is not a valid value: %s.', id_script) raise InvalidValueError(None, 'id_script', id_script) # Find Equipment by ID to check if it exist Equipamento.get_by_pk(id_equipment) # Find Script by ID to check if it exist Roteiro.get_by_pk(id_script) # User permission if not has_perm(user, AdminPermission.EQUIPMENT_MANAGEMENT, AdminPermission.WRITE_OPERATION, None, id_equipment, AdminPermission.EQUIP_WRITE_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) with distributedlock(LOCK_EQUIPMENT_SCRIPT % id_script): EquipamentoRoteiro.remove(user, id_equipment, id_script) return self.response(dumps_networkapi({})) except InvalidValueError, e: return self.response_error(269, e.param, e.value)
def handle_delete(self, request, user, *args, **kwargs): """Treat requests DELETE to remove Equipment Script. URL: equipmentscript/<id_equipment>/<id_script>/ """ try: self.log.info("Remove Equipment Script") id_equipment = kwargs.get("id_equipment") id_script = kwargs.get("id_script") # Valid ID Equipment if not is_valid_int_greater_zero_param(id_equipment): self.log.error(u"The id_equipment parameter is not a valid value: %s.", id_equipment) raise InvalidValueError(None, "id_equipment", id_equipment) # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error(u"The id_script parameter is not a valid value: %s.", id_script) raise InvalidValueError(None, "id_script", id_script) # Find Equipment by ID to check if it exist Equipamento.get_by_pk(id_equipment) # Find Script by ID to check if it exist Roteiro.get_by_pk(id_script) # User permission if not has_perm( user, AdminPermission.EQUIPMENT_MANAGEMENT, AdminPermission.WRITE_OPERATION, None, id_equipment, AdminPermission.EQUIP_WRITE_OPERATION, ): self.log.error(u"User does not have permission to perform the operation.") raise UserNotAuthorizedError(None) with distributedlock(LOCK_EQUIPMENT_SCRIPT % id_script): EquipamentoRoteiro.remove(user, id_equipment, id_script) return self.response(dumps_networkapi({})) except InvalidValueError, e: return self.response_error(269, e.param, e.value)
def handle_delete(self, request, user, *args, **kwargs): """Treat requests DELETE to remove Script. URL: script/<id_script>/ """ try: self.log.info("Remove Script") # User permission if not has_perm(user, AdminPermission.SCRIPT_MANAGEMENT, AdminPermission.WRITE_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) id_script = kwargs.get('id_script') # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error( u'The id_script parameter is not a valid value: %s.', id_script) raise InvalidValueError(None, 'id_script', id_script) # Find Script by ID to check if it exist script = Roteiro.get_by_pk(id_script) with distributedlock(LOCK_SCRIPT % id_script): try: if script.equipamentoroteiro_set.count() != 0: raise RoteiroHasEquipamentoError( None, u'Existe equipamento associado ao roteiro %s' % script.id) # remove Script script.delete() except RoteiroHasEquipamentoError, e: raise e except Exception, e: self.log.error(u'Failed to remove the Script.') raise RoteiroError(e, u'Failed to remove the Script.')
def handle_delete(self, request, user, *args, **kwargs): """Treat requests DELETE to remove Script. URL: script/<id_script>/ """ try: self.log.info("Remove Script") # User permission if not has_perm(user, AdminPermission.SCRIPT_MANAGEMENT, AdminPermission.WRITE_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) id_script = kwargs.get('id_script') # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error( u'The id_script parameter is not a valid value: %s.', id_script) raise InvalidValueError(None, 'id_script', id_script) # Find Script by ID to check if it exist script = Roteiro.get_by_pk(id_script) with distributedlock(LOCK_SCRIPT % id_script): try: if script.equipamentoroteiro_set.count() != 0: raise RoteiroHasEquipamentoError( None, u'Existe equipamento associado ao roteiro %s' % script.id) # remove Script script.delete(user) except RoteiroHasEquipamentoError, e: raise e except Exception, e: self.log.error(u'Failed to remove the Script.') raise RoteiroError(e, u'Failed to remove the Script.')
def handle_put(self, request, user, *args, **kwargs): """Treat requests PUT to edit Script. URL: script/<id_script>/ """ try: self.log.info("Edit Script") # User permission if not has_perm(user, AdminPermission.SCRIPT_MANAGEMENT, AdminPermission.WRITE_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) id_script = kwargs.get('id_script') # Load XML data xml_map, attrs_map = loads(request.raw_post_data) # XML data format networkapi_map = xml_map.get('networkapi') if networkapi_map is None: return self.response_error(3, u'There is no value to the networkapi tag of XML request.') script_map = networkapi_map.get('script') if script_map is None: return self.response_error(3, u'There is no value to the script tag of XML request.') # Get XML data script = script_map.get('script') id_script_type = script_map.get('id_script_type') description = script_map.get('description') # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error( u'The id_script parameter is not a valid value: %s.', id_script) raise InvalidValueError(None, 'id_script', id_script) # Valid Script if not is_valid_string_minsize(script, 3) or not is_valid_string_maxsize(script, 40): self.log.error( u'Parameter script is invalid. Value: %s', script) raise InvalidValueError(None, 'script', script) # Valid ID Script Type if not is_valid_int_greater_zero_param(id_script_type): self.log.error( u'The id_script_type parameter is not a valid value: %s.', id_script_type) raise InvalidValueError(None, 'id_script_type', id_script_type) # Valid description if not is_valid_string_minsize(description, 3) or not is_valid_string_maxsize(description, 100): self.log.error( u'Parameter description is invalid. Value: %s', description) raise InvalidValueError(None, 'description', description) # Find Script by ID to check if it exist scr = Roteiro.get_by_pk(id_script) # Find Script Type by ID to check if it exist script_type = TipoRoteiro.get_by_pk(id_script_type) with distributedlock(LOCK_SCRIPT % id_script): try: if not (scr.roteiro.lower() == script.lower() and scr.tipo_roteiro.id == id_script_type): Roteiro.get_by_name_script(script, id_script_type) raise RoteiroNameDuplicatedError( None, u'Já existe um roteiro com o nome %s com tipo de roteiro %s.' % (script, script_type.tipo)) except RoteiroNotFoundError: pass # set variables scr.roteiro = script scr.tipo_roteiro = script_type scr.descricao = description try: # update Script scr.save(user) except Exception, e: self.log.error(u'Failed to update the Script.') raise RoteiroError(e, u'Failed to update the Script.') return self.response(dumps_networkapi({})) except InvalidValueError, e: return self.response_error(269, e.param, e.value)
def handle_post(self, request, user, *args, **kwargs): """Treat requests POST to add Equipment Script. URL: equipmentscript/ """ try: self.log.info('Add Equipment Script') # Load XML data xml_map, attrs_map = loads(request.raw_post_data) # XML data format networkapi_map = xml_map.get('networkapi') if networkapi_map is None: return self.response_error(3, u'There is no value to the networkapi tag of XML request.') equipment_script_map = networkapi_map.get('equipment_script') if equipment_script_map is None: return self.response_error(3, u'There is no value to the equipment_script tag of XML request.') # Get XML data id_equipment = equipment_script_map.get('id_equipment') id_script = equipment_script_map.get('id_script') # Valid ID Equipment if not is_valid_int_greater_zero_param(id_equipment): self.log.error( u'The id_equipment parameter is not a valid value: %s.', id_equipment) raise InvalidValueError(None, 'id_equipment', id_equipment) # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error( u'The id_script parameter is not a valid value: %s.', id_script) raise InvalidValueError(None, 'id_script', id_script) # Find Equipment by ID to check if it exist equipment = Equipamento.get_by_pk(id_equipment) # User permission if not has_perm(user, AdminPermission.EQUIPMENT_MANAGEMENT, AdminPermission.WRITE_OPERATION, None, id_equipment, AdminPermission.EQUIP_WRITE_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) # Find Script by ID to check if it exist script = Roteiro.get_by_pk(id_script) equip_script = EquipamentoRoteiro() # set variables equip_script.equipamento = equipment equip_script.roteiro = script # save Equipment Type equip_script.create(user) equip_script_map = dict() equip_script_map['id'] = equip_script.id networkapi_map = dict() networkapi_map['equipamento_roteiro'] = equip_script_map return self.response(dumps_networkapi(networkapi_map)) except InvalidValueError, e: return self.response_error(269, e.param, e.value)
def handle_put(self, request, user, *args, **kwargs): """Treat requests PUT to edit Script. URL: script/<id_script>/ """ try: self.log.info("Edit Script") # User permission if not has_perm(user, AdminPermission.SCRIPT_MANAGEMENT, AdminPermission.WRITE_OPERATION): self.log.error(u"User does not have permission to perform the operation.") raise UserNotAuthorizedError(None) id_script = kwargs.get("id_script") # Load XML data xml_map, attrs_map = loads(request.raw_post_data) # XML data format networkapi_map = xml_map.get("networkapi") if networkapi_map is None: return self.response_error(3, u"There is no value to the networkapi tag of XML request.") script_map = networkapi_map.get("script") if script_map is None: return self.response_error(3, u"There is no value to the script tag of XML request.") # Get XML data script = script_map.get("script") id_script_type = script_map.get("id_script_type") models = script_map.get("model") description = script_map.get("description") # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error(u"The id_script parameter is not a valid value: %s.", id_script) raise InvalidValueError(None, "id_script", id_script) # Valid Script if not is_valid_string_minsize(script, 3) or not is_valid_string_maxsize(script, 40): self.log.error(u"Parameter script is invalid. Value: %s", script) raise InvalidValueError(None, "script", script) # Valid ID Script Type if not is_valid_int_greater_zero_param(id_script_type): self.log.error(u"The id_script_type parameter is not a valid value: %s.", id_script_type) raise InvalidValueError(None, "id_script_type", id_script_type) # Valid description if not is_valid_string_minsize(description, 3) or not is_valid_string_maxsize(description, 100): self.log.error(u"Parameter description is invalid. Value: %s", description) raise InvalidValueError(None, "description", description) # Find Script by ID to check if it exist scr = Roteiro.get_by_pk(id_script) # Find Script Type by ID to check if it exist script_type = TipoRoteiro.get_by_pk(id_script_type) models_old = [] scr_models = ModeloRoteiro.objects.all().filter(roteiro__id=scr.id) for i in scr_models: models_old.append(int(i.modelo.id)) if models is not None and type(models) is not list: var = int(models) models = [] models.append(var) else: models = [int(x) for x in models] desassociar = set(models_old) - set(models) for i in desassociar: scr_model = ModeloRoteiro() scr_model.remover(user, int(i), int(scr.id)) associar = set(models) - set(models_old) for i in associar: scr_models = ModeloRoteiro() scr_models.roteiro = scr scr_models.modelo = Modelo.get_by_pk(i) scr_models.create(user) # verificar se há equipamento daquele modelo que não está associado a um roteiro for ids in models: equipamentos = Equipamento.objects.filter(modelo__id=int(ids)) for equip in equipamentos: try: equip_roteiro = EquipamentoRoteiro.objects.filter( equipamento__id=equip.id, roteiro__tipo_roteiro__id=scr.tipo_roteiro.id ).uniqueResult() equip_roteiro.id except: equip_rot = EquipamentoRoteiro() equip_rot.equipamento = equip equip_rot.roteiro = scr equip_rot.create(user) pass with distributedlock(LOCK_SCRIPT % id_script): try: if not scr.roteiro.lower() == script.lower() and not scr.tipo_roteiro.id == id_script_type: Roteiro.get_by_name_script(script, id_script_type) raise RoteiroNameDuplicatedError( None, u"Já existe um roteiro com o nome %s com tipo de roteiro %s." % (script, script_type.tipo), ) except RoteiroNotFoundError: pass # set variables scr.roteiro = script scr.tipo_roteiro = script_type scr.descricao = description try: # update Script scr.save() except Exception, e: self.log.error(u"Failed to update the Script.") raise RoteiroError(e, u"Failed to update the Script.") return self.response(dumps_networkapi({})) except InvalidValueError, e: return self.response_error(269, e.param, e.value)
def handle_post(self, request, user, *args, **kwargs): """Treat requests POST to add Equipment Script. URL: equipmentscript/ """ try: self.log.info('Add Equipment Script') # Load XML data xml_map, attrs_map = loads(request.raw_post_data) # XML data format networkapi_map = xml_map.get('networkapi') if networkapi_map is None: return self.response_error( 3, u'There is no value to the networkapi tag of XML request.' ) equipment_script_map = networkapi_map.get('equipment_script') if equipment_script_map is None: return self.response_error( 3, u'There is no value to the equipment_script tag of XML request.' ) # Get XML data id_equipment = equipment_script_map.get('id_equipment') id_script = equipment_script_map.get('id_script') # Valid ID Equipment if not is_valid_int_greater_zero_param(id_equipment): self.log.error( u'The id_equipment parameter is not a valid value: %s.', id_equipment) raise InvalidValueError(None, 'id_equipment', id_equipment) # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error( u'The id_script parameter is not a valid value: %s.', id_script) raise InvalidValueError(None, 'id_script', id_script) # Find Equipment by ID to check if it exist equipment = Equipamento.get_by_pk(id_equipment) # User permission if not has_perm(user, AdminPermission.EQUIPMENT_MANAGEMENT, AdminPermission.WRITE_OPERATION, None, id_equipment, AdminPermission.EQUIP_WRITE_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) # Find Script by ID to check if it exist script = Roteiro.get_by_pk(id_script) equip_script = EquipamentoRoteiro() # set variables equip_script.equipamento = equipment equip_script.roteiro = script # save Equipment Type equip_script.create(user) equip_script_map = dict() equip_script_map['id'] = equip_script.id networkapi_map = dict() networkapi_map['equipamento_roteiro'] = equip_script_map return self.response(dumps_networkapi(networkapi_map)) except InvalidValueError, e: return self.response_error(269, e.param, e.value)
def handle_put(self, request, user, *args, **kwargs): """Treat requests PUT to edit Script. URL: script/<id_script>/ """ try: self.log.info("Edit Script") # User permission if not has_perm(user, AdminPermission.SCRIPT_MANAGEMENT, AdminPermission.WRITE_OPERATION): self.log.error( u'User does not have permission to perform the operation.') raise UserNotAuthorizedError(None) id_script = kwargs.get('id_script') # Load XML data xml_map, attrs_map = loads(request.raw_post_data) # XML data format networkapi_map = xml_map.get('networkapi') if networkapi_map is None: return self.response_error( 3, u'There is no value to the networkapi tag of XML request.' ) script_map = networkapi_map.get('script') if script_map is None: return self.response_error( 3, u'There is no value to the script tag of XML request.') # Get XML data script = script_map.get('script') id_script_type = script_map.get('id_script_type') models = script_map.get('model') description = script_map.get('description') # Valid ID Script if not is_valid_int_greater_zero_param(id_script): self.log.error( u'The id_script parameter is not a valid value: %s.', id_script) raise InvalidValueError(None, 'id_script', id_script) # Valid Script if not is_valid_string_minsize( script, 3) or not is_valid_string_maxsize(script, 40): self.log.error(u'Parameter script is invalid. Value: %s', script) raise InvalidValueError(None, 'script', script) # Valid ID Script Type if not is_valid_int_greater_zero_param(id_script_type): self.log.error( u'The id_script_type parameter is not a valid value: %s.', id_script_type) raise InvalidValueError(None, 'id_script_type', id_script_type) # Valid description if not is_valid_string_minsize(description, 3) or not is_valid_string_maxsize( description, 100): self.log.error(u'Parameter description is invalid. Value: %s', description) raise InvalidValueError(None, 'description', description) # Find Script by ID to check if it exist scr = Roteiro.get_by_pk(id_script) # Find Script Type by ID to check if it exist script_type = TipoRoteiro.get_by_pk(id_script_type) models_old = [] scr_models = ModeloRoteiro.objects.all().filter(roteiro__id=scr.id) for i in scr_models: models_old.append(int(i.modelo.id)) if models is not None and type(models) is not list: var = int(models) models = [] models.append(var) else: models = [int(x) for x in models] desassociar = set(models_old) - set(models) for i in desassociar: scr_model = ModeloRoteiro() scr_model.remover(user, int(i), int(scr.id)) associar = set(models) - set(models_old) for i in associar: scr_models = ModeloRoteiro() scr_models.roteiro = scr scr_models.modelo = Modelo.get_by_pk(i) scr_models.create(user) #verificar se há equipamento daquele modelo que não está associado a um roteiro for ids in models: equipamentos = Equipamento.objects.filter(modelo__id=int(ids)) for equip in equipamentos: try: equip_roteiro = EquipamentoRoteiro.objects.filter( equipamento__id=equip.id, roteiro__tipo_roteiro__id=scr.tipo_roteiro.id ).uniqueResult() equip_roteiro.id except: equip_rot = EquipamentoRoteiro() equip_rot.equipamento = equip equip_rot.roteiro = scr equip_rot.create(user) pass with distributedlock(LOCK_SCRIPT % id_script): try: if not scr.roteiro.lower() == script.lower( ) and not scr.tipo_roteiro.id == id_script_type: Roteiro.get_by_name_script(script, id_script_type) raise RoteiroNameDuplicatedError( None, u'Já existe um roteiro com o nome %s com tipo de roteiro %s.' % (script, script_type.tipo)) except RoteiroNotFoundError: pass # set variables scr.roteiro = script scr.tipo_roteiro = script_type scr.descricao = description try: # update Script scr.save() except Exception, e: self.log.error(u'Failed to update the Script.') raise RoteiroError(e, u'Failed to update the Script.') return self.response(dumps_networkapi({})) except InvalidValueError, e: return self.response_error(269, e.param, e.value)