Update shopping_list to use async_add_executor_job (#41795)

This commit is contained in:
J. Nick Koston 2020-10-13 17:22:17 -05:00 committed by GitHub
parent 3748c3c985
commit 6c3e450117
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 24 deletions

View file

@ -77,7 +77,7 @@ async def async_setup_entry(hass, config_entry):
data = hass.data[DOMAIN] data = hass.data[DOMAIN]
name = call.data.get(ATTR_NAME) name = call.data.get(ATTR_NAME)
if name is not None: if name is not None:
data.async_add(name) await data.async_add(name)
async def complete_item_service(call): async def complete_item_service(call):
"""Mark the item provided via `name` as completed.""" """Mark the item provided via `name` as completed."""
@ -90,7 +90,7 @@ async def async_setup_entry(hass, config_entry):
except IndexError: except IndexError:
_LOGGER.error("Removing of item failed: %s cannot be found", name) _LOGGER.error("Removing of item failed: %s cannot be found", name)
else: else:
data.async_update(item["id"], {"name": name, "complete": True}) await data.async_update(item["id"], {"name": name, "complete": True})
data = hass.data[DOMAIN] = ShoppingData(hass) data = hass.data[DOMAIN] = ShoppingData(hass)
await data.async_load() await data.async_load()
@ -139,16 +139,14 @@ class ShoppingData:
self.hass = hass self.hass = hass
self.items = [] self.items = []
@callback async def async_add(self, name):
def async_add(self, name):
"""Add a shopping list item.""" """Add a shopping list item."""
item = {"name": name, "id": uuid.uuid4().hex, "complete": False} item = {"name": name, "id": uuid.uuid4().hex, "complete": False}
self.items.append(item) self.items.append(item)
self.hass.async_add_job(self.save) await self.hass.async_add_executor_job(self.save)
return item return item
@callback async def async_update(self, item_id, info):
def async_update(self, item_id, info):
"""Update a shopping list item.""" """Update a shopping list item."""
item = next((itm for itm in self.items if itm["id"] == item_id), None) item = next((itm for itm in self.items if itm["id"] == item_id), None)
@ -157,14 +155,13 @@ class ShoppingData:
info = ITEM_UPDATE_SCHEMA(info) info = ITEM_UPDATE_SCHEMA(info)
item.update(info) item.update(info)
self.hass.async_add_job(self.save) await self.hass.async_add_executor_job(self.save)
return item return item
@callback async def async_clear_completed(self):
def async_clear_completed(self):
"""Clear completed items.""" """Clear completed items."""
self.items = [itm for itm in self.items if not itm["complete"]] self.items = [itm for itm in self.items if not itm["complete"]]
self.hass.async_add_job(self.save) await self.hass.async_add_executor_job(self.save)
async def async_load(self): async def async_load(self):
"""Load items.""" """Load items."""
@ -203,7 +200,7 @@ class UpdateShoppingListItemView(http.HomeAssistantView):
data = await request.json() data = await request.json()
try: try:
item = request.app["hass"].data[DOMAIN].async_update(item_id, data) item = await request.app["hass"].data[DOMAIN].async_update(item_id, data)
request.app["hass"].bus.async_fire(EVENT) request.app["hass"].bus.async_fire(EVENT)
return self.json(item) return self.json(item)
except KeyError: except KeyError:
@ -221,7 +218,7 @@ class CreateShoppingListItemView(http.HomeAssistantView):
@RequestDataValidator(vol.Schema({vol.Required("name"): str})) @RequestDataValidator(vol.Schema({vol.Required("name"): str}))
async def post(self, request, data): async def post(self, request, data):
"""Create a new shopping list item.""" """Create a new shopping list item."""
item = request.app["hass"].data[DOMAIN].async_add(data["name"]) item = await request.app["hass"].data[DOMAIN].async_add(data["name"])
request.app["hass"].bus.async_fire(EVENT) request.app["hass"].bus.async_fire(EVENT)
return self.json(item) return self.json(item)
@ -232,11 +229,10 @@ class ClearCompletedItemsView(http.HomeAssistantView):
url = "/api/shopping_list/clear_completed" url = "/api/shopping_list/clear_completed"
name = "api:shopping_list:clear_completed" name = "api:shopping_list:clear_completed"
@callback async def post(self, request):
def post(self, request):
"""Retrieve if API is running.""" """Retrieve if API is running."""
hass = request.app["hass"] hass = request.app["hass"]
hass.data[DOMAIN].async_clear_completed() await hass.data[DOMAIN].async_clear_completed()
hass.bus.async_fire(EVENT) hass.bus.async_fire(EVENT)
return self.json_message("Cleared completed items.") return self.json_message("Cleared completed items.")
@ -249,10 +245,10 @@ def websocket_handle_items(hass, connection, msg):
) )
@callback @websocket_api.async_response
def websocket_handle_add(hass, connection, msg): async def websocket_handle_add(hass, connection, msg):
"""Handle add item to shopping_list.""" """Handle add item to shopping_list."""
item = hass.data[DOMAIN].async_add(msg["name"]) item = await hass.data[DOMAIN].async_add(msg["name"])
hass.bus.async_fire(EVENT, {"action": "add", "item": item}) hass.bus.async_fire(EVENT, {"action": "add", "item": item})
connection.send_message(websocket_api.result_message(msg["id"], item)) connection.send_message(websocket_api.result_message(msg["id"], item))
@ -266,7 +262,7 @@ async def websocket_handle_update(hass, connection, msg):
data = msg data = msg
try: try:
item = hass.data[DOMAIN].async_update(item_id, data) item = await hass.data[DOMAIN].async_update(item_id, data)
hass.bus.async_fire(EVENT, {"action": "update", "item": item}) hass.bus.async_fire(EVENT, {"action": "update", "item": item})
connection.send_message(websocket_api.result_message(msg_id, item)) connection.send_message(websocket_api.result_message(msg_id, item))
except KeyError: except KeyError:
@ -275,9 +271,9 @@ async def websocket_handle_update(hass, connection, msg):
) )
@callback @websocket_api.async_response
def websocket_handle_clear(hass, connection, msg): async def websocket_handle_clear(hass, connection, msg):
"""Handle clearing shopping_list items.""" """Handle clearing shopping_list items."""
hass.data[DOMAIN].async_clear_completed() await hass.data[DOMAIN].async_clear_completed()
hass.bus.async_fire(EVENT, {"action": "clear"}) hass.bus.async_fire(EVENT, {"action": "clear"})
connection.send_message(websocket_api.result_message(msg["id"])) connection.send_message(websocket_api.result_message(msg["id"]))

View file

@ -24,7 +24,7 @@ class AddItemIntent(intent.IntentHandler):
"""Handle the intent.""" """Handle the intent."""
slots = self.async_validate_slots(intent_obj.slots) slots = self.async_validate_slots(intent_obj.slots)
item = slots["item"]["value"] item = slots["item"]["value"]
intent_obj.hass.data[DOMAIN].async_add(item) await intent_obj.hass.data[DOMAIN].async_add(item)
response = intent_obj.create_response() response = intent_obj.create_response()
response.async_set_speech(f"I've added {item} to your shopping list") response.async_set_speech(f"I've added {item} to your shopping list")