def raster_hazards_classifications_for_layer(cls, hazard_key, layer_geometry_key, layer_mode_key, hazard_category_key): """Get vector_hazards_classifications. :param hazard_key: The hazard key :type hazard_key: str :param layer_geometry_key: The layer geometry key :type layer_geometry_key: str :param layer_mode_key: The layer mode key :type layer_mode_key: str :param hazard_category_key: The hazard category key :type hazard_category_key: str :returns: List of continuous hazard unit :rtype: list """ hazard_layer_req = cls.get_hazard_requirements() if not hazard_layer_req['raster_hazard_classifications']: return [] hazards = hazard_layer_req['hazard_types'] hazard_keys = get_list_key(hazards) if hazard_key not in hazard_keys: return [] layer_geometries = hazard_layer_req['layer_geometries'] layer_geometry_keys = get_list_key(layer_geometries) if layer_geometry_key not in layer_geometry_keys: return [] layer_mode = hazard_layer_req['layer_mode'] if layer_mode_key != layer_mode['key']: return [] hazard_categories = hazard_layer_req['hazard_categories'] hazard_category_keys = get_list_key(hazard_categories) if hazard_category_key not in hazard_category_keys: return [] return hazard_layer_req['raster_hazard_classifications']
def raster_hazards_classifications_for_layer( cls, hazard_key, layer_geometry_key, layer_mode_key, hazard_category_key): """Get vector_hazards_classifications. :param hazard_key: The hazard key :type hazard_key: str :param layer_geometry_key: The layer geometry key :type layer_geometry_key: str :param layer_mode_key: The layer mode key :type layer_mode_key: str :param hazard_category_key: The hazard category key :type hazard_category_key: str :returns: List of continuous hazard unit :rtype: list """ hazard_layer_req = cls.get_hazard_requirements() if not hazard_layer_req['raster_hazard_classifications']: return [] hazards = hazard_layer_req['hazard_types'] hazard_keys = get_list_key(hazards) if hazard_key not in hazard_keys: return [] layer_geometries = hazard_layer_req['layer_geometries'] layer_geometry_keys = get_list_key(layer_geometries) if layer_geometry_key not in layer_geometry_keys: return [] layer_mode = hazard_layer_req['layer_mode'] if layer_mode_key != layer_mode['key']: return [] hazard_categories = hazard_layer_req['hazard_categories'] hazard_category_keys = get_list_key(hazard_categories) if hazard_category_key not in hazard_category_keys: return [] return hazard_layer_req['raster_hazard_classifications']
def continuous_hazards_units_for_layer(cls, hazard_key, layer_geometry_key, layer_mode_key, hazard_category_key): """Get continuous hazard units. :param hazard_key: The hazard key :type hazard_key: str :param layer_geometry_key: The layer geometry key :type layer_geometry_key: str :param layer_mode_key: The layer mode key :type layer_mode_key: str :param hazard_category_key: The hazard category key :type hazard_category_key: str :returns: List of continuous hazard unit :rtype: list """ hazard_layer_req = cls.get_hazard_requirements() if not hazard_layer_req["continuous_hazard_units"]: return [] hazards = hazard_layer_req["hazard_types"] hazard_keys = get_list_key(hazards) if hazard_key not in hazard_keys: return [] layer_geometries = hazard_layer_req["layer_geometries"] layer_geometry_keys = get_list_key(layer_geometries) if layer_geometry_key not in layer_geometry_keys: return [] layer_mode = hazard_layer_req["layer_mode"] if layer_mode_key != layer_mode["key"]: return [] hazard_categories = hazard_layer_req["hazard_categories"] hazard_category_keys = get_list_key(hazard_categories) if hazard_category_key not in hazard_category_keys: return [] return hazard_layer_req["continuous_hazard_units"]
def exposure_units_for_layer( cls, exposure_key, layer_geometry_key, layer_mode_key): """Get exposure units. :param exposure_key: The exposure key :type exposure_key: str :param layer_geometry_key: The geometry key :type layer_geometry_key: str :param layer_mode_key: The layer mode key :type layer_mode_key: str :returns: List of exposure unit :rtype: list """ exposure_layer_req = cls.get_exposure_requirements() if not exposure_layer_req['exposure_units']: return [] exposures = exposure_layer_req['exposure_types'] exposure_keys = get_list_key(exposures) if exposure_key not in exposure_keys: return [] layer_geometries = exposure_layer_req['layer_geometries'] layer_geometry_keys = get_list_key(layer_geometries) if layer_geometry_key not in layer_geometry_keys: return [] layer_mode = exposure_layer_req['layer_mode'] if layer_mode_key != layer_mode['key']: return [] return exposure_layer_req['exposure_units']
def exposure_units_for_layer(cls, exposure_key, layer_geometry_key, layer_mode_key): """Get exposure units. :param exposure_key: The exposure key :type exposure_key: str :param layer_geometry_key: The geometry key :type layer_geometry_key: str :param layer_mode_key: The layer mode key :type layer_mode_key: str :returns: List of exposure unit :rtype: list """ exposure_layer_req = cls.get_exposure_requirements() if not exposure_layer_req['exposure_units']: return [] exposures = exposure_layer_req['exposure_types'] exposure_keys = get_list_key(exposures) if exposure_key not in exposure_keys: return [] layer_geometries = exposure_layer_req['layer_geometries'] layer_geometry_keys = get_list_key(layer_geometries) if layer_geometry_key not in layer_geometry_keys: return [] layer_mode = exposure_layer_req['layer_mode'] if layer_mode_key != layer_mode['key']: return [] return exposure_layer_req['exposure_units']
def purposes_for_layer(cls, layer_geometry_key): """Get purposes of a layer geometry id. :param layer_geometry_key: The geometry id :type layer_geometry_key: str :returns: List of purposes :rtype: list """ result = [] hazard_layer_req = cls.get_hazard_requirements() hazard_geometries = hazard_layer_req['layer_geometries'] hazard_geometry_keys = get_list_key(hazard_geometries) if layer_geometry_key in hazard_geometry_keys: result.append(layer_purpose_hazard) exposure_layer_req = cls.get_exposure_requirements() exposure_geometries = exposure_layer_req['layer_geometries'] exposure_geometry_keys = get_list_key(exposure_geometries) if layer_geometry_key in exposure_geometry_keys: result.append(layer_purpose_exposure) return result
def exposures_for_layer(cls, layer_geometry_key): """Get hazard categories form layer_geometry_key :param layer_geometry_key: The geometry id :type layer_geometry_key: str :returns: List of exposure :rtype: list """ exposure_layer_req = cls.get_exposure_requirements() layer_geometries = exposure_layer_req['layer_geometries'] layer_geometry_keys = get_list_key(layer_geometries) if layer_geometry_key in layer_geometry_keys: return exposure_layer_req['exposure_types'] else: return []
def available_hazards(cls, hazard_category_key): """Get available hazards from hazard_category_key :param hazard_category_key: The hazard category key :type hazard_category_key: str :returns: List of available hazards :rtype: list """ hazard_layer_req = cls.get_hazard_requirements() hazard_categories = hazard_layer_req['hazard_categories'] hazard_category_keys = get_list_key(hazard_categories) if hazard_category_key not in hazard_category_keys: return [] return hazard_layer_req['hazard_types']