def run(self) -> bool: try: dataset_id = self._cmd_params.dataset_id chart_id = self._cmd_params.chart_id actor = self._cmd_params.actor key = self._cmd_params.key form_data = self._cmd_params.form_data check_access(dataset_id, chart_id, actor) state: TemporaryExploreState = cache_manager.explore_form_data_cache.get( key) if state and form_data: user_id = actor.get_user_id() if state["owner"] != user_id: raise KeyValueAccessDeniedError() new_state: TemporaryExploreState = { "owner": actor.get_user_id(), "dataset_id": dataset_id, "chart_id": chart_id, "form_data": form_data, } return cache_manager.explore_form_data_cache.set( key, new_state) return False except SQLAlchemyError as ex: logger.exception("Error running update command") raise KeyValueUpdateFailedError() from ex
def update(self, cmd_params: CommandParameters) -> Optional[str]: resource_id = cmd_params.resource_id actor = cmd_params.actor key = cmd_params.key value = cmd_params.value dashboard = DashboardDAO.get_by_id_or_slug(str(resource_id)) if dashboard and value: entry: Entry = cache_manager.filter_state_cache.get( cache_key(resource_id, key)) if entry: user_id = actor.get_user_id() if entry["owner"] != user_id: raise KeyValueAccessDeniedError() # Generate a new key if tab_id changes or equals 0 contextual_key = cache_key(session.get("_id"), cmd_params.tab_id, resource_id) key = cache_manager.filter_state_cache.get(contextual_key) if not key or not cmd_params.tab_id: key = random_key() cache_manager.filter_state_cache.set(contextual_key, key) new_entry: Entry = { "owner": actor.get_user_id(), "value": value } cache_manager.filter_state_cache.set( cache_key(resource_id, key), new_entry) return key
def delete(self, actor: User, resource_id: int, key: str) -> Optional[bool]: dashboard = DashboardDAO.get_by_id_or_slug(str(resource_id)) if dashboard: entry: Entry = cache_manager.filter_state_cache.get( cache_key(resource_id, key)) if entry: if entry["owner"] != actor.get_user_id(): raise KeyValueAccessDeniedError() return cache_manager.filter_state_cache.delete( cache_key(resource_id, key)) return False
def delete(self, cmd_params: CommandParameters) -> bool: resource_id = cmd_params.resource_id actor = cmd_params.actor key = cache_key(resource_id, cmd_params.key) dashboard = DashboardDAO.get_by_id_or_slug(str(resource_id)) if dashboard: entry: Entry = cache_manager.filter_state_cache.get(key) if entry: if entry["owner"] != actor.get_user_id(): raise KeyValueAccessDeniedError() return cache_manager.filter_state_cache.delete(key) return False
def run(self) -> bool: try: actor = self._cmd_params.actor key = self._cmd_params.key state: TemporaryExploreState = cache_manager.explore_form_data_cache.get( key) if state: check_access(state["dataset_id"], state["chart_id"], actor) if state["owner"] != actor.get_user_id(): raise KeyValueAccessDeniedError() return cache_manager.explore_form_data_cache.delete(key) return False except SQLAlchemyError as ex: logger.exception("Error running delete command") raise KeyValueDeleteFailedError() from ex
def update(self, actor: User, resource_id: int, key: str, value: str) -> Optional[bool]: dashboard = DashboardDAO.get_by_id_or_slug(str(resource_id)) if dashboard: entry: Entry = cache_manager.filter_state_cache.get( cache_key(resource_id, key)) if entry: user_id = actor.get_user_id() if entry["owner"] != user_id: raise KeyValueAccessDeniedError() new_entry: Entry = { "owner": actor.get_user_id(), "value": value } return cache_manager.filter_state_cache.set( cache_key(resource_id, key), new_entry) return False
def update(self, cmd_params: CommandParameters) -> bool: resource_id = cmd_params.resource_id actor = cmd_params.actor key = cache_key(resource_id, cmd_params.key) value = cmd_params.value dashboard = DashboardDAO.get_by_id_or_slug(str(resource_id)) if dashboard and value: entry: Entry = cache_manager.filter_state_cache.get(key) if entry: user_id = actor.get_user_id() if entry["owner"] != user_id: raise KeyValueAccessDeniedError() new_entry: Entry = { "owner": actor.get_user_id(), "value": value } return cache_manager.filter_state_cache.set(key, new_entry) return False
def run(self) -> Optional[str]: try: dataset_id = self._cmd_params.dataset_id chart_id = self._cmd_params.chart_id actor = self._cmd_params.actor key = self._cmd_params.key form_data = self._cmd_params.form_data check_access(dataset_id, chart_id, actor) state: TemporaryExploreState = cache_manager.explore_form_data_cache.get( key ) if state and form_data: user_id = actor.get_user_id() if state["owner"] != user_id: raise KeyValueAccessDeniedError() # Generate a new key if tab_id changes or equals 0 tab_id = self._cmd_params.tab_id contextual_key = cache_key( session.get("_id"), tab_id, dataset_id, chart_id ) key = cache_manager.explore_form_data_cache.get(contextual_key) if not key or not tab_id: key = random_key() cache_manager.explore_form_data_cache.set(contextual_key, key) new_state: TemporaryExploreState = { "owner": actor.get_user_id(), "dataset_id": dataset_id, "chart_id": chart_id, "form_data": form_data, } cache_manager.explore_form_data_cache.set(key, new_state) return key except SQLAlchemyError as ex: logger.exception("Error running update command") raise KeyValueUpdateFailedError() from ex